The MinIO JavaScript Client SDK provides simple APIs to access any Amazon S3 compatible object storage server.
This quickstart guide will show you how to install the client SDK and execute an example JavaScript program. For a complete list of APIs and examples, please take a look at the JavaScript Client API Reference documentation.
This document assumes that you have a working nodejs setup in place.
npm install --save miniogit clone https://github.com/minio/minio-js
cd minio-js
npm install
npm run build
npm install -gminio>7.1.0 is shipped with builtin type definition, @types/minio is no longer needed.
You need five items in order to connect to MinIO object storage server.
| Params | Description | 
|---|---|
| endPoint | URL to object storage service. | 
| port | TCP/IP port number. This input is optional. Default value set to 80for HTTP and443for HTTPs. | 
| accessKey | Access key is like user ID that uniquely identifies your account. | 
| secretKey | Secret key is the password to your account. | 
| useSSL | Set this value to 'true' to enable secure (HTTPS) access | 
import * as Minio from 'minio'
const minioClient = new Minio.Client({
  endPoint: 'play.min.io',
  port: 9000,
  useSSL: true,
  accessKey: 'Q3AM3UQ867SPQQA43P2F',
  secretKey: 'zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG',
})This example program connects to an object storage server, makes a bucket on the server and then uploads a file to the bucket.
We will use the MinIO server running at https://play.min.io in this example. Feel free to use this service for testing and development. Access credentials shown in this example are open to the public.
import * as Minio from 'minio'
// Instantiate the minio client with the endpoint
// and access keys as shown below.
const minioClient = new Minio.Client({
  endPoint: 'play.min.io',
  port: 9000,
  useSSL: true,
  accessKey: 'Q3AM3UQ867SPQQA43P2F',
  secretKey: 'zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG',
})
// File that needs to be uploaded.
const file = '/tmp/photos-europe.tar'
// Make a bucket called europetrip.
await minioClient.makeBucket('europetrip', 'us-east-1')
console.log('Bucket created successfully in "us-east-1".')
var metaData = {
  'Content-Type': 'application/octet-stream',
  'X-Amz-Meta-Testing': 1234,
  example: 5678,
}
// Using fPutObject API upload your file to the bucket europetrip.
await minioClient.fPutObject('europetrip', 'photos-europe.tar', file, metaData)
console.log('File uploaded successfully.')node file-uploader.js
Bucket created successfully in "us-east-1".
mc ls play/europetrip/
[2016-05-25 23:49:50 PDT]  17MiB photos-europe.tarThe full API Reference is available here.
- makeBucket
- listBuckets
- bucketExists
- removeBucket
- listObjects
- listObjectsV2
- listObjectsV2WithMetadata(Extension)
- listIncompleteUploads
- getBucketVersioning
- setBucketVersioning
- setBucketLifecycle
- getBucketLifecycle
- removeBucketLifecycle
- getObjectLockConfig
- setObjectLockConfig
- getObject
- putObject
- copyObject
- statObject
- removeObject
- removeObjects
- removeIncompleteUpload
- selectObjectContent
- getBucketNotification
- setBucketNotification
- removeAllBucketNotification
- listenBucketNotification(MinIO Extension)
- list-buckets.mjs
- list-objects.js
- list-objects-v2.js
- list-objects-v2-with-metadata.js (Extension)
- bucket-exists.mjs
- make-bucket.js
- remove-bucket.mjs
- list-incomplete-uploads.js
- get-bucket-versioning.mjs
- set-bucket-versioning.mjs
- set-bucket-tagging.js
- get-bucket-tagging.mjs
- remove-bucket-tagging.js
- set-bucket-lifecycle.js
- get-bucket-lifecycle.js
- remove-bucket-lifecycle.js
- get-object-lock-config.mjs
- set-object-lock-config.mjs
- set-bucket-replication.mjs
- get-bucket-replication.mjs
- remove-bucket-replication.mjs
- put-object.js
- get-object.mjs
- copy-object.js
- get-partialobject.mjs
- remove-object.js
- remove-incomplete-upload.js
- stat-object.mjs
- get-object-retention.js
- put-object-retention.js
- put-object-tagging.js
- get-object-tagging.mjs
- remove-object-tagging.js
- set-object-legal-hold.js
- get-object-legal-hold.js
- compose-object.js
- select-object-content.js
