A universal API for Cloud Storage providers. Supports: Amazon AWS S3, Backblaze B2, Microsoft Azure Blob, DigitalOcean Spaces, Rackspace Cloud Storage, Wasabi Object Storage and any S3-Compatible cloud storage or Folder (e.g NAS)
#### v. 2.0.0
This version introduces a completely new API, so it contains code-breaking changes. We encorauge you to update, but please keep in mind that some refactoring will be required.
``javascript`
npm install solid-bucket
javascript
const SolidBucket = require('solid-bucket')let provider = new SolidBucket('aws', {
accessKeyId: 'accessKeyId',
secretAccessKey: 'secretAccessKey',
region: 'us-east-1' // Optional: "us-east-1" by default
})
`$3
`javascript
const SolidBucket = require('solid-bucket')let provider = new SolidBucket('b2', {
accountId: 'accountId',
applicationKey: 'applicationKey'
})
`$3
`javascript
const SolidBucket = require('solid-bucket')// How to generate a credentials JSON file: https://cloud.google.com/storage/docs/authentication (To generate a private key in JSON format)
let provider = new SolidBucket('gcs', {
keyFilename: 'keyFilename'
})
`$3
`javascript
const SolidBucket = require('solid-bucket')let provider = new SolidBucket('azure', {
accountName: 'accountName',
accountKey: 'accountKey'
})
`$3
`javascript
const SolidBucket = require('solid-bucket')let provider = new SolidBucket('digitalocean', {
accessKeyId: 'accessKeyId',
secretAccessKey: 'secretAccessKey',
region: 'nyc3' // Optional: "nyc3" by default
})
`$3
`javascript
const SolidBucket = require('solid-bucket')let provider = new SolidBucket('rackspace', {
username: 'username',
apiKey: 'apiKey',
region: 'IAD' // Optional: 'IAD' by default
})
`$3
`javascript
const SolidBucket = require('solid-bucket')let provider = new SolidBucket('wasabi', {
accessKeyId: 'accessKeyId',
secretAccessKey: 'secretAccessKey',
})
`$3
`javascript
const SolidBucket = require('solid-bucket')let provider = new SolidBucket('s3compatible', {
endpoint: 'endpoint',
accessKeyId: 'accessKeyId',
secretAccessKey: 'secretAccessKey',
})
`$3
`javascript
const SolidBucket = require('solid-bucket')let provider = new SolidBucket('folder', {
folderPath: 'folderPath'
})
`3. Universal API
$3
#### 3.1.1 Definition
`javascript
provider.createBucket(bucketName) // returns a Promise
`
#### 3.1.2 Full Example
`javascript
const SolidBucket = require('solid-bucket')let provider = new SolidBucket('azure', {
accountName: 'accountName',
accountKey: 'accountKey'
})
let bucketName = 'example'
provider.createBucket(bucketName).then((resp) => {
if (resp.status === 201) {
console.log(resp.message)
// Output: Bucket "example" was created successfully
}
}).catch((resp) => {
if (resp.status === 400){
console.log(resp.message)
// Output: Some error coming from the provider...
}
})
`
$3
#### 3.2.1 Definition
`javascript
provider.deleteBucket(bucketName) // returns a Promise
`#### 3.2.2 Full Example
`javascript
const SolidBucket = require('solid-bucket')let provider = new SolidBucket('azure', {
accountName: 'accountName',
accountKey: 'accountKey'
})
let bucketName = 'example'
provider.deleteBucket(bucketName).then((resp) => {
if (resp.status === 200) {
console.log(resp.message)
// Output: Bucket "example" was deleted successfully
}
}).catch((resp) => {
if (resp.status === 400){
console.log(resp.message)
// Output: Some error coming from the provider...
}
})
`$3
#### 3.3.1 Definition
`javascript
provider.uploadFile(bucketName, filePath) // returns a Promise
`#### 3.3.2 Full Example
`javascript
const SolidBucket = require('solid-bucket')let provider = new SolidBucket('azure', {
accountName: 'accountName',
accountKey: 'accountKey'
})
let bucketName = 'example'
let filePath = '/tmp/file.bin'
provider.uploadFile(bucketName, filePath).then((resp) => {
if (resp.status === 200) {
console.log(resp.message)
// Output: Bucket "example" was deleted successfully
}
}).catch((resp) => {
if (resp.status === 400){
console.log(resp.message)
// Output: Some error coming from the provider...
}
})
`$3
#### 3.4.1 Definition
`javascript
provider.deleteBucket(bucketName, remoteFilename downloadedFilePath) // returns a Promise
`#### 3.4.2 Full Example
`javascript
const SolidBucket = require('solid-bucket')let provider = new SolidBucket('azure', {
accountName: 'accountName',
accountKey: 'accountKey'
})
let bucketName = 'example'
let remoteFilename = 'file.bin'
let downloadedFilePath = '/tmp'
provider.downloadFile(bucketName, remoteFilename, downloadedFilePath).then((resp) => {
if (resp.status === 200) {
console.log(resp.message)
// Output: Bucket "example" was deleted successfully
}
}).catch((resp) => {
if (resp.status === 400){
console.log(resp.message)
// Output: Some error coming from the provider...
}
})
`$3
#### 3.5.1 Definition
`javascript
provider.createFileFromText(bucketName, remoteFilename, text) // returns a Promise
`#### 3.5.2 Full Example
`javascript
const SolidBucket = require('solid-bucket')let provider = new SolidBucket('azure', {
accountName: 'accountName',
accountKey: 'accountKey'
})
let bucketName = 'example'
let remoteFilename = 'my_remote_object.txt'
let text = 'This is a text that I would like to upload'
provider.createFileFromText(bucketName, remoteFilename, text).then((resp) => {
if (resp.status === 200) {
console.log(resp.message)
// Output: Object "example.txt" was saved successfully in bucket "example"
}
}).catch((resp) => {
if (resp.status === 400){
console.log(resp.message)
// Output: Some error coming from the provider...
}
})
`$3
#### 3.6.1 Definition
`javascript
provider.deleteFile(bucketName, remoteFilename) // returns a Promise
`#### 3.6.2 Full Example
`javascript
const SolidBucket = require('solid-bucket')let provider = new SolidBucket('azure', {
accountName: 'accountName',
accountKey: 'accountKey'
})
let bucketName = 'example'
let remoteFilename = 'my_remote_object.txt'
provider.deleteFile(bucketName, remoteFilename).then((resp) => {
if (resp.status === 200) {
console.log(resp.message)
// Output: Object "example.txt" was deleted successfully from bucket "example"
}
}).catch((resp) => {
if (resp.status === 400){
console.log(resp.message)
// Output: Some error coming from the provider...
}
})
`$3
#### 3.7.1 Definition
`javascript
provider.readFile(bucketName, remoteFilename) // returns a Promise
`#### 3.7.2 Full Example
`javascript
const SolidBucket = require('solid-bucket')let provider = new SolidBucket('azure', {
accountName: 'accountName',
accountKey: 'accountKey'
})
let bucketName = 'example'
let remoteFilename = 'my_remote_object.txt'
provider.readFile(bucketName, remoteFilename).then((resp) => {
if (resp.status === 200) {
console.log(resp.message)
// Output: Object "example.txt" was fetched successfully from bucket "example"
}
}).catch((resp) => {
if (resp.status === 400){
console.log(resp.message)
// Output: Some error coming from the provider...
}
})
`$3
#### 3.8.1 Definition
`javascript
provider.getListOfFiles(bucketName) // returns a Promise
`#### 3.8.2 Full Example
`javascript
const SolidBucket = require('solid-bucket')let provider = new SolidBucket('azure', {
accountName: 'accountName',
accountKey: 'accountKey'
})
let bucketName = 'example'
provider.getListOfFiles(bucketName).then((resp) => {
if (resp.status === 200) {
console.log(resp.message)
// Output: The list of objects was fetched successfully from bucket "example"
}
}).catch((resp) => {
if (resp.status === 400){
console.log(resp.message)
// Output: Some error coming from the provider...
}
})
`
4. Tests
Required Environmental vars depending on the provider:
#### Amazon AWS S3
* AWS_ACCESSKEYID
* AWS_SECRETACCESSKEY
#### Backblaze B2
* B2_ACCOUNTID
* B2_APPLICATIONKEY
#### DigitalOcean Spaces
* DIGITALOCEAN_ACCESSKEYID
* DIGITALOCEAN_SECRETACCESSKEY
#### Google Cloud Storage
* GCS_PROJECTID
* GCS_PRIVATEKEYID
* GCS_PRIVATEKEY
* GCS_CLIENTEMAIL
* GCS_CLIENTID
* GCS_CLIENTX509CERTURL
#### Microsoft Azure
* AZURE_ACCOUNTNAME
* AZURE_ACCOUNTKEY
#### Rackspace Cloud Storage
* RACKSPACE_USERNAME
* RACKSPACE_APIKEY
#### Wasabi Object Storage
* WASABI_ACCESSKEYID
* WASABI_SECRETACCESSKEY
#### Any S3 Compatible Storage
* S3COMPATIBLE_ENDPOINT
* S3COMPATIBLE_ACCESSKEYID
* S3COMPATIBLE_SECRETACCESSKEY
#### Folder
* FOLDER_FOLDERPATH
Afterwards, just run:
`javascript
npm run compile && npm test
``