Skip to content

Javascript client library for connecting to Bee decentralised storage

License

Notifications You must be signed in to change notification settings

ethersphere/bee-js

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Bee-JS

FOSSA Status standard-readme compliant js-standard-style

JavaScript SDK for the Swarm decentralised storage.

Supports Node.js 18+, Vite and Webpack.

Write your code in CJS, MJS or TypeScript.

Intended to be used with Bee version 2.5.0.

Quick start

Start a Swarm project using TypeScript:

npm init swarm-app@latest my-dapp node-ts

or using Vite and TypeScript:

npm init swarm-app@latest my-dapp vite-tsx

Supported types are node, node-esm, node-ts and vite-tsx. Replace my-dapp with your project name.

Install

npm install @ethersphere/bee-js

Import

CJS

const { Bee } = require('@ethersphere/bee-js')

MJS and TypeScript

import { Bee } from '@ethersphere/bee-js'

Script tag

Loading this module through a script tag will make the BeeJs object available in the global namespace.

<script src="https://unpkg.com/@ethersphere/bee-js/dist/index.browser.min.js"></script>

Overview

Type interfaces

NumberString is a branded type for marking strings that represent numbers. It interops with string and bigint types. Where NumberString is present, number is disallowed in order to avoid pitfalls with unsafe large values.

Byte primitives

All the classes below extend Bytes, therefor the following methods are available on all of them: toUint8Array, toHex, toBase64, toBase32, toUtf8, toJSON, static keccak256, static fromUtf8.

The toString method uses toHex.

Bytes and its subclasses may be constructed with new from Uint8Array or hex string.

Elliptic

Name Description Methods
PrivateKey 32 bytes private key publicKey, sign
PublicKey 64 bytes public key address, toCompressedUint8Array, toCompressedHex
EthAddress 20 bytes Ethereum address toChecksum
Signature 65 bytes signature recoverPublicKey

Swarm

Name Description Methods
Reference 32/64 bytes reference (chunk, feed) toCid
Identifier 32 bytes identifier (SOC, Feed) -
TransactionId 32 bytes transaction ID -
FeedIndex 8 bytes feed index (BE) static fromBigInt, toBigInt
Topic 32 bytes topic static fromString
PeerAddress 32 bytes peer address -
BatchId 32 bytes batch ID -
Span 8 bytes span (LE) static fromBigInt, toBigInt

Tokens

Name Description Methods
DAI ERC20 DAI token (18 digits) static fromDecimalString, static fromWei, toWeiString, toWeiBigInt, toDecimalString
BZZ ERC20 BZZ token (16 digits) static fromDecimalString, static fromPLUR, toPLURString, toPLURBigInt, toDecimalString

Swarm chunks

Name Description Creation
Chunk Span, max. 4096 bytes payload; address dervied from content makeContentAddressedChunk
SingleOwnerChunk Identifier, signature, span, max. 4096 bytes payload; address derived from identifier and owner makeSingleOwnerChunk

Swarm primitives

Name Description Methods
MantarayNode Compact trie with reference values and JSON metadata addFork, removeFork, calculateSelfAddress, find, findClosest, collect, marshal, unmarshal, saveRecursively, loadRecursively
MerkleTree Streaming BMT of chunks append, finalize, static root

Swarm objects

Name Description Creation
SOCWriter SingleOwnerChunk writer bee.makeSOCWriter
SOCReader SingleOwnerChunk reader bee.makeSOCReader
FeedWriter Feed writer bee.makeFeedWriter
FeedReader Feed reader bee.makeFeedReader

Bee API

  • βŒβŒβœ… - Full node only
  • βŒβœ…βœ… - Light node and full node
  • βœ…βœ…βœ… - Ultra-light node, light node and full node
JS Call Bee Endpoint Bee Mode
uploadFile POST /bzz πŸ”— βŒβœ…βœ…
uploadFilesFromDirectory Node.js POST /bzz πŸ”— βŒβœ…βœ…
uploadFiles POST /bzz πŸ”— βŒβœ…βœ…
uploadCollection POST /bzz πŸ”— βŒβœ…βœ…
uploadData POST /bytes πŸ”— βŒβœ…βœ…
uploadChunk POST /chunks πŸ”— βŒβœ…βœ…
streamDirectory Node.js POST /chunks πŸ”— βŒβœ…βœ…
streamFiles Browser POST /chunks πŸ”— βŒβœ…βœ…
SOCWriter.upload POST /soc/:owner/:identifier πŸ”— βŒβœ…βœ…
FeedReader.download GET /feeds/:owner/:topic πŸ”— βœ…βœ…βœ…
FeedWriter.updateFeed POST /soc/:owner/:identifier πŸ”— βŒβœ…βœ…
downloadFile GET /bzz/:reference πŸ”— βœ…βœ…βœ…
downloadFile GET /bzz/:reference/:path πŸ”— βœ…βœ…βœ…
downloadReadableFile GET /bzz/:reference πŸ”— βœ…βœ…βœ…
downloadData GET /bytes/:reference πŸ”— βœ…βœ…βœ…
downloadReadableData GET /bytes/:reference πŸ”— βœ…βœ…βœ…
downloadChunk GET /chunks/:reference πŸ”— βœ…βœ…βœ…
createFeedManifest POST /feeds/:owner/:topic πŸ”— βŒβœ…βœ…
isConnected GET / βœ…βœ…βœ…
getHealth GET /health πŸ”— βœ…βœ…βœ…
getReadiness GET /readiness πŸ”— βœ…βœ…βœ…
getNodeInfo GET /node πŸ”— βœ…βœ…βœ…
getChainState GET /chainstate πŸ”— βŒβœ…βœ…
getRedistributionState GET /redistributionstate πŸ”— βŒβŒβœ…
getReserveState GET /reservestate πŸ”— βŒβŒβœ…
getStatus GET /status πŸ”— βœ…βœ…βœ…
getWallet GET /wallet πŸ”— βŒβœ…βœ…
getTopology GET /topology πŸ”— βœ…βœ…βœ…
getAddresses GET /addresses πŸ”— βœ…βœ…βœ…
getPeers GET /peers πŸ”— βœ…βœ…βœ…
getAllBalances GET /balances πŸ”— βŒβœ…βœ…
getPeerBalance GET /balances/:peer πŸ”— βŒβœ…βœ…
getPastDueConsumptionBalances GET /consumed πŸ”— βŒβœ…βœ…
getPastDueConsumptionPeerBalance GET /consumed/:peer πŸ”— βŒβœ…βœ…
getAllSettlements GET /settlements πŸ”— βŒβœ…βœ…
getSettlements GET /settlements/:peer πŸ”— βŒβœ…βœ…
getChequebookAddress GET /chequebook/address πŸ”— βŒβœ…βœ…
getChequebookBalance GET /chequebook/balance πŸ”— βŒβœ…βœ…
getLastCheques GET /chequebook/cheque πŸ”— βŒβœ…βœ…
getLastChequesForPeer GET /chequebook/cheque/:peer πŸ”— βŒβœ…βœ…
getLastCashoutAction GET /chequebook/cashout/:peer πŸ”— βŒβœ…βœ…
cashoutLastCheque POST /chequebook/cashout/:peer πŸ”— βŒβœ…βœ…
depositTokens POST /chequebook/deposit πŸ”— βŒβœ…βœ…
withdrawTokens POST /chequebook/withdraw πŸ”— βŒβœ…βœ…
getAllPendingTransactions GET /transactions πŸ”— βŒβœ…βœ…
getPendingTransaction GET /transactions/:id πŸ”— βŒβœ…βœ…
rebroadcastTransaction POST /transactions/:id πŸ”— βŒβœ…βœ…
cancelTransaction DELETE /transactions/:id πŸ”— βŒβœ…βœ…
createTag POST /tags πŸ”— βŒβœ…βœ…
retrieveTag GET /tags/:id πŸ”— βŒβœ…βœ…
getAllTags GET /tags πŸ”— βŒβœ…βœ…
deleteTag DELETE /tags/:id πŸ”— βŒβœ…βœ…
updateTag PATCH /tags/:id πŸ”— βŒβœ…βœ…
pin POST /pins/:reference πŸ”— βœ…βœ…βœ…
getAllPins GET /pins πŸ”— βœ…βœ…βœ…
getPin GET /pins/:reference πŸ”— βœ…βœ…βœ…
isReferenceRetrievable GET /stewardship/:reference πŸ”— βœ…βœ…βœ…
reuploadPinnedData PUT /stewardship/:reference πŸ”— βŒβœ…βœ…
unpin DELETE /pins/:reference πŸ”— βœ…βœ…βœ…
getGrantees GET /grantee/:reference πŸ”— βŒβœ…βœ…
createGrantees POST /grantee πŸ”— βŒβœ…βœ…
patchGrantees PATCH /grantee/:reference πŸ”— βŒβœ…βœ…
pssSend POST /pss/send/:topic/:target πŸ”— βŒβœ…βœ…
pssSubscribe Websocket GET /pss/subscribe/:topic πŸ”— βŒβŒβœ…
pssReceive GET /pss/subscribe/:topic πŸ”— βŒβŒβœ…
getAllPostageBatch GET /stamps πŸ”— βŒβœ…βœ…
getGlobalPostageBatches GET /batches πŸ”— βŒβœ…βœ…
getPostageBatch GET /stamps/:batchId πŸ”— βŒβœ…βœ…
getPostageBatchBuckets GET /stamps/:batchId/buckets πŸ”— βŒβœ…βœ…
createPostageBatch POST /stamps/:amount/:depth πŸ”— βŒβœ…βœ…
topUpBatch PATCH /stamps/topup/:batchId/:amount πŸ”— βŒβœ…βœ…
diluteBatch PATCH /stamps/dilute/:batchId/:depth πŸ”— βŒβœ…βœ…
createEnvelope POST /envelope/:reference πŸ”— βŒβœ…βœ…
getStake GET /stake πŸ”— βŒβŒβœ…
depositStake POST /stake πŸ”— βŒβŒβœ…

Utils

General

  • getCollectionSize
  • getFolderSize

PSS

  • makeMaxTarget

Erasure Coding

  • approximateOverheadForRedundancyLevel
  • getRedundancyStat
  • getRedundancyStats

Stamps

  • getAmountForTtl
  • getDepthForCapacity
  • getStampCost
  • getStampEffectiveBytes
  • getStampMaximumCapacityBytes
  • getStampTtlSeconds
  • getStampUsage

Usage

Upload via Swarm Gateway

import { Bee, NULL_STAMP, SWARM_GATEWAY_URL } from '@ethersphere/bee-js'

main()

async function main() {
  const bee = new Bee(SWARM_GATEWAY_URL)
  const { reference } = await bee.uploadData(NULL_STAMP, 'Hello, World!')
  console.log(reference.toHex())
}

Create or select an existing postage batch

Swarm incentivizes nodes in the network to store content, therefor all uploads require a paid postage batch.

import { Bee } from '@ethersphere/bee-js'

async function getOrCreatePostageBatch() {
  const bee = new Bee('http://localhost:1633')
  let batchId

  const batches = await bee.getAllPostageBatch()
  const usable = batches.find(x => x.usable)

  if (usable) {
    batchId = usable.batchID
  } else {
    batchId = await bee.buyStorage(Size.fromGigabytes(1), Duration.fromDays(7))
  }
}

The following examples all assume an existing batchId.

Upload simple data (Browser + Node.js)

import { Bee } from '@ethersphere/bee-js'

const bee = new Bee('http://localhost:1633')

const uploadResult = await bee.uploadData(batchId, 'Bee is awesome!')
const data = await bee.downloadData(uploadResult.reference)

console.log(data.toUtf8()) // prints 'Bee is awesome!'

Upload data from a file input (React)

import { Bee } from '@ethersphere/bee-js'

const bee = new Bee('http://localhost:1633')
const result = await bee.uploadFile(batchId, file)

Upload multiple files or a directory (React)

import { Bee } from '@ethersphere/bee-js'

const bee = new Bee('http://localhost:1633')
const result = await bee.uploadFiles(batchId, fileList)

Upload arbitrary large file (Node.js)

import { Bee } from '@ethersphere/bee-js'
import { createReadStream } from 'fs'

const bee = new Bee('http://localhost:1633')
const readable = createReadStream('./path/to/large.bin')
const uploadResult = await bee.uploadFile(batchId, readable)

Upload arbitrary large directories (Node.js)

import { Bee } from '@ethersphere/bee-js'
import { createReadStream } from 'fs'

const bee = new Bee('http://localhost:1633')
const uploadResult = await bee.uploadFilesFromDirectory(batchId, './path/to/gallery/')

Customize http/https agent and headers

const bee = new Bee('http://localhost:1633', {
  httpAgent: new http.Agent({ keepAlive: true }),
  httpsAgent: new https.Agent({ keepAlive: true }),
  headers: {
    Authorization: 'Basic ' + Buffer.from('username:password').toString('base64'),
  },
})

Contribute

Stay up to date by joining the official Discord and by keeping an eye on the releases tab.

There are some ways you can make this module better:

  • Consult our open issues and take on one of them
  • Help our tests reach 100% coverage!
  • Join us in our Discord chat in the #develop-on-swarm channel if you have questions or want to give feedback

Setup

Install project dependencies:

npm install

Build the project:

npm run build

After making changes, link the package to your project by running npm link in the Bee-JS project root, and npm link @ethersphere/bee-js in your project root.

Test

Tests are currently run against a mainnet Bee nodes. This is temporary and this section will be revised in the future.

License

BSD-3-Clause

FOSSA Status