0.24.0-alpha.0 • Published 8 months ago

@toa.io/extensions.storages v0.24.0-alpha.0

Weekly downloads
-
License
-
Repository
github
Last release
8 months ago

Toa Storages

Shared BLOB storage.

Entry

BLOBs are stored with the meta-information object (Entry) having the following properties:

  • id - checksum
  • size - size in bytes
  • type - MIME type
  • created - creation timestamp (UNIX time, ms)
  • variants - array of:
    • name - unique name
    • size - size in bytes
    • type - variant MIME type
  • meta - object with application-specific information, empty by default

Example

id: eecd837c
type: image/jpeg
created: 1698004822358
variants:
  - name: thumbnail.jpeg
    type: image/jpeg
  - name: thumbnail.webp
    type: image/webp
meta:
  face: true
  nudity: false

Aspect

The Storages extension provides storages aspect, containing named Storage instances, according to the annotation.

async function effect (_, context) {
  await context.storages.photos.fetch('/path/to/b4f577e0.thumbnail.jpeg')
}

Storage interface

Maybe<T> = T | Error

async put(path: string, stream: Readable, type?: TypeControl): Maybe<Entry>

interface TypeControl {
  claim?: string
  accept?: string
}

Add a BLOB to the storage and create an entry under specified path.

BLOB type is identified using magick numbers.

If the type argument is specified and the value of the claim does not match the detected BLOB type, then a TYPE_MISMATCH error is returned. If the BLOB type cannot be identified and the value of the claim is not in the list of known types, then the given value is used. If the list of acceptable types is passed and the type of the BLOB does not match any of its values, then a NOT_ACCEPTABLE error is returned.

Known types are: image/jpeg, image/png, image/gif, image/webp, image/heic, image/jxl, image/avif.

See source.

If the entry already exists, it is returned and revealed.

async get(path: string): Maybe<Entry>

Get an entry.

If the entry does not exist, a NOT_FOUND error is returned.

async fetch(path: string): Maybe<Readable>

Fetch the BLOB specified by path. If the path does not exist, a NOT_FOUND error is returned.

path can be an entry id, or a path to the entry, or a path to a variant of the entry.

  • eecd837c - fetch the BLOB by id
  • /path/to/eecd837c - fetch the BLOB by path
  • /path/to/eecd837c.thumbnail.jpeg - fetch the thumbnail.jpeg variant of the BLOB

async delete(path: string): Maybe<void>

Delete the entry specified by path.

async list(path: string): string[]

Get ordered list of ids of entries in under the path.

async permute(path: string, ids: string[]): Maybe<void>

Reorder entries under the path.

Given list must be a permutation of the current list, otherwise a PERMUTATION_MISMATCH error is returned.

async diversify(path: string, name: string, stream: Readable): Maybe<void>

Add or replace a name variant of the entry specified by path.

async conceal(path: string): Maybe<void>

Remove the entry from the list.

async reveal(path: string): Maybe<void>

Restore the entry to the list.

async annotate(path: string, key: string, value: any): Maybe<void>

Set a key property in the meta of the entry specified by path.

Providers

Storage uses underlying providers to store BLOBs and entries.

Custom providers are not supported.

Amazon S3

Annotation value formats is s3://{region}/{bucket}?endpoint={endpoint}.

Requires secrets for the access key and secret key. See toa conceal for deployment and toa env for local environment. endpoint parameter is optional.

s3://us-east-1/my-bucket?endpoint=http://s3.my-instance.com:4566

Filesystem

Annotation value format is file:///{path}.

file:///var/my-storage

Temporary

Filesystem using OS temporary directory.

Annotation value format is tmp:///{path}.

tmp:///my-storage

Deduplication

BLOBs are stored in the underlying storage with their checksum as the key, ensuring that identical BLOBs are stored only once. Variants, on the other hand, are not deduplicated across different entries.

Underlying directory structure:

/temp
  c28f4dfd            # random id
/blobs
  b4f577e0            # checksum
/storage
  /path/to
    .list             # list of entries
    /b4f577e0
      .meta           # entry
      thumbnail.jpeg  # variant BLOBs
      thumbnail.webp

Manifest

Storage extension can be enabled by adding storages key to the component manifest.

storages: [photos, videos]

Value of the storages key is an array of storage names, that should be declared in the context.

It the names are unknown, null declaration can be used:

storages: ~

Annotation

The storages context annotation is an object with keys that reference the storage name and provider-specific URLs as values.

storages:
  photos: s3://us-east-1/my-bucket
  photos@dev: file:///var/my-storage

Secrets

Secrets declared by storage providers can be deployed by toa conceal, or set locally by toa env.

1.0.0-alpha.143

8 months ago

1.0.0-alpha.125

9 months ago

1.0.0-alpha.120

9 months ago

1.0.0-alpha.113

12 months ago

1.0.0-alpha.106

1 year ago

1.0.0-alpha.52

1 year ago

1.0.0-alpha.51

1 year ago

1.0.0-alpha.54

1 year ago

1.0.0-alpha.53

1 year ago

1.0.0-alpha.50

1 year ago

1.0.0-alpha.59

1 year ago

1.0.0-alpha.56

1 year ago

1.0.0-alpha.55

1 year ago

1.0.0-alpha.58

1 year ago

1.0.0-alpha.63

1 year ago

1.0.0-alpha.62

1 year ago

1.0.0-alpha.61

1 year ago

1.0.0-alpha.67

1 year ago

1.0.0-alpha.69

1 year ago

1.0.0-alpha.38

1 year ago

1.0.0-alpha.37

1 year ago

1.0.0-alpha.39

1 year ago

1.0.0-alpha.41

1 year ago

1.0.0-alpha.40

1 year ago

1.0.0-alpha.43

1 year ago

1.0.0-alpha.42

1 year ago

1.0.0-alpha.49

1 year ago

1.0.0-alpha.48

1 year ago

1.0.0-alpha.45

1 year ago

1.0.0-alpha.44

1 year ago

1.0.0-alpha.47

1 year ago

1.0.0-alpha.46

1 year ago

1.0.0-alpha.92

1 year ago

1.0.0-alpha.91

1 year ago

1.0.0-alpha.94

1 year ago

1.0.0-alpha.93

1 year ago

1.0.0-alpha.71

1 year ago

1.0.0-alpha.78

1 year ago

1.0.0-alpha.79

1 year ago

1.0.0-alpha.90

1 year ago

1.0.0-alpha.86

1 year ago

1.0.0-alpha.89

1 year ago

1.0.0-alpha.88

1 year ago

1.0.0-alpha.34

1 year ago

1.0.0-alpha.33

1 year ago

1.0.0-alpha.36

1 year ago

1.0.0-alpha.35

1 year ago

1.0.0-alpha.32

1 year ago

1.0.0-alpha.29

1 year ago

1.0.0-alpha.30

1 year ago

1.0.0-alpha.31

1 year ago

1.0.0-alpha.27

1 year ago

1.0.0-alpha.28

1 year ago

1.0.0-alpha.26

2 years ago

1.0.0-alpha.25

2 years ago

1.0.0-alpha.24

2 years ago

1.0.0-alpha.23

2 years ago

1.0.0-alpha.22

2 years ago

1.0.0-alpha.21

2 years ago

1.0.0-alpha.20

2 years ago

1.0.0-alpha.19

2 years ago

1.0.0-alpha.18

2 years ago

1.0.0-alpha.17

2 years ago

1.0.0-alpha.16

2 years ago

1.0.0-alpha.15

2 years ago

1.0.0-alpha.14

2 years ago

1.0.0-alpha.13

2 years ago

1.0.0-alpha.12

2 years ago

1.0.0-alpha.10

2 years ago

1.0.0-alpha.11

2 years ago

1.0.0-alpha.9

2 years ago

1.0.0-alpha.8

2 years ago

1.0.0-alpha.7

2 years ago

1.0.0-alpha.6

2 years ago

1.0.0-alpha.5

2 years ago

1.0.0-alpha.4

2 years ago

1.0.0-alpha.3

2 years ago

0.24.0-alpha.23

2 years ago

1.0.0-alpha.2

2 years ago

0.24.0-alpha.22

2 years ago

0.24.0-alpha.21

2 years ago

0.24.0-alpha.20

2 years ago

0.24.0-alpha.19

2 years ago

0.24.0-alpha.16

2 years ago

0.24.0-alpha.17

2 years ago

0.24.0-alpha.18

2 years ago

0.24.0-alpha.15

2 years ago

0.24.0-alpha.13

2 years ago

0.24.0-alpha.14

2 years ago

0.24.0-alpha.12

2 years ago

0.24.0-alpha.11

2 years ago

0.24.0-alpha.10

2 years ago

0.24.0-alpha.9

2 years ago

0.24.0-alpha.8

2 years ago

0.24.0-alpha.7

2 years ago

0.24.0-alpha.6

2 years ago

0.24.0-alpha.5

2 years ago

0.24.0-alpha.4

2 years ago

0.24.0-alpha.3

2 years ago

0.24.0-alpha.2

2 years ago

0.24.0-alpha.0

2 years ago

1.0.0-alpha.0

2 years ago

0.23.0-dev.0

2 years ago

0.22.0

2 years ago

0.20.0-alpha.3

2 years ago