deno-s3-lite-client
This is a lightweight S3 client for Deno, designed to offer all the key features you may need, with no dependencies outside of the Deno standard library.
This client is 100% MIT licensed, and is derived from the excellent MinIO JavaScript Client.
Supported functionality:
- Authenticated or unauthenticated requests
- List objects:
for await (const object of client.listObjects(options)) { ... }
- Handles pagination transparently
- Supports filtering using a prefix
- Supports grouping using a delimiter
(use
client.listObjectsGrouped(...)
)
- Check if an object exists:
client.exists("key")
- Get metadata about an object:
client.statObject("key")
- Download an object:
client.getObject("key", options)
- This just returns a standard HTTP
Response
object, so for large files, you can opt to consume the data as a stream (use the.body
property).
- This just returns a standard HTTP
- Download a partial object:
client.getPartialObject("key", options)
- Like
getObject
, this also supports streaming the response if you want to.
- Like
- Upload an object:
client.putObject("key", streamOrData, options)
- Can upload from a
string
,Uint8Array
, orReadableStream
- Can split large uploads into multiple parts and uploads parts in parallel.
- Can upload from a
- Copy an object:
client.copyObject({ sourceKey: "source", options }, "dest", options)
- Can copy between different buckets.
- Delete an object:
client.deleteObject("key")
- Create pre-signed URLs:
client.presignedGetObject("key", options)
orclient.getPresignedUrl(method, "key", options)
Usage examples
List data files from a public data set on Amazon S3:
import { S3Client } from "https://deno.land/x/s3_lite_client@0.5.0/mod.ts";
const s3client = new S3Client({
endPoint: "s3.us-east-1.amazonaws.com",
port: 443,
useSSL: true,
region: "us-east-1",
bucket: "openalex",
pathStyle: false,
});
for await (const obj of s3client.listObjects({ prefix: "data/concepts/" })) {
console.log(obj);
}
Upload a file to a local MinIO server:
import { S3Client } from "https://deno.land/x/s3_lite_client@0.5.0/mod.ts";
// Connecting to a local MinIO server:
const s3client = new S3Client({
endPoint: "localhost",
port: 9000,
useSSL: false,
region: "dev-region",
accessKey: "AKIA_DEV",
secretKey: "secretkey",
bucket: "dev-bucket",
pathStyle: true,
});
// Upload a file:
await s3client.putObject("test.txt", "This is the contents of the file.");
For more examples, check out the tests in integration.ts
Developer notes
To run the tests, please use:
deno lint && deno test
To format the code, use:
deno fmt
To run the integration tests, first start MinIO with this command:
docker run --rm -e MINIO_ROOT_USER=AKIA_DEV -e MINIO_ROOT_PASSWORD=secretkey -e MINIO_REGION_NAME=dev-region -p 9000:9000 -p 9001:9001 --entrypoint /bin/sh minio/minio:RELEASE.2021-10-23T03-28-24Z -c 'mkdir -p /data/dev-bucket && minio server --console-address ":9001" /data'
Then while MinIO is running, run
deno test --allow-net integration.ts
To debug what MinIO is seeing, run these two commands:
mc alias set localdebug http://localhost:9000 AKIA_DEV secretkey
mc admin trace --verbose --all localdebug