1.0.0 • Published 5 years ago

s3-file-explorer v1.0.0

Weekly downloads
-
License
SEE LICENSE IN DI...
Repository
-
Last release
5 years ago

@vergetech/s3-file-explorer

Helper functions for exploring and updating the s3 file system.

const VergeEncryption = require('@vergetech/s3-file-explorer');
const {
  list,
  upload,
  removeFile,
  renameFile,
  createDirectory,
  removeDirectory,
  renameDirectory,
} = new VergeEncryption({
  // Required: name of the bucket to be connected to
  bucketName: 'verge-testing',

  // Any S3 SDK configuration can be passed in here
  // See: AWS.config.update (aws-sdk)
  update: {
    // These configuration inputs are required
    accessKeyId: 'xxxxxxxxxxxxxxxxxxxx',
    secretAccessKey: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
    region: 'eu-central-1',
  },

  // (Optional) Keys containing these keywords will be filtered out e.g. when listing a directory, if 'DB_BACKUPS' is the folder name (or file name), the folder and all files within it will be filtered out before returning the result
  ignoreList: ['DB_BACKUPS'],
});

Installation

npm install --save @vergetech/s3-file-explorer

Testing

See test cases under /test/app.js.

AWS_KEY="xxxxxxxxxxxxxxxxxxxx" AWS_SECRET="xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" npm run ci-test

S3 Policy

List bucket is required for removing directories, since all items within the directory will be removed first.

{
    "Version": "2012-10-17",
    "Statement": [
        {
            "Effect": "Allow",
            "Action": "s3:*",
            "Resource": "arn:aws:s3:::verge-testing/*"
        },
        {
            "Effect": "Allow",
            "Action": "s3:ListBucket",
            "Resource": "arn:aws:s3:::verge-testing"
        }
    ]
}

Examples

Listing

If the contents size is zero then the contents in question is a directory and not a file.

(async () => {
  const resFolder = await list('my_folder/');
  console.log(resFolder);

  // All items in the bucket
  const resAll = await list('');
  console.log(resAll);
})();

Files

Upload

(async () => {
  const fileToUpload = fs.readFileSync('./test/data/my_file_to_upload.png');
  const uploadBufferRes = await upload({
    // Required
    Body: fileToUpload, // Buffer object to be uploaded
    Key: 'my_folder/example_file.png', // Bucket Key

    // Example Optionals
    ACL: 'public-read',
    CacheControl: 'public, max-age=50',
    ContentType: 'image/png',
    // Any other config required, see AWS.S3.upload
  });
  console.log(uploadBufferRes);

  const data = '... some base 64 string';
  const uploadBase64Res = await upload({
    // Required
    Body: Buffer.from(data.replace(/^data:\w+\/\w+;base64,/, ''), 'base64'), // Base64 data to be uploaded
    Key: 'my_folder/example_file.png',

    // Example Optionals
    ACL: 'public-read',
    CacheControl: 'public, max-age=50',

    // Optionals for uploading a base64 string instead of a buffer object
    ContentEncoding: 'base64',
    ContentType: 'image/png',
    // Any other config required, see AWS.S3.upload
  });
  console.log(uploadBase64Res);
})();

Rename

(async () => {
  const res = await renameFile(
    'my_folder/example_file_buffer.png',
    'my_folder/example_file_buffer_renamed.png',
    'public-read',
  );
  console.log(res);
})();

Remove

(async () => {
  const res = await removeFile('my_folder/example_file_base64.png');
  console.log(res);
})();

Directories

Creation

(async () => {
  const res = await createDirectory(
    // Directory to be created on bucket
    'my_folder/my_public_folder/',
    // Optional ACL to associate with the directory
    'public-read',
  );
  console.log(res);
})();

Renaming

(async () => {
  const res = await renameDirectory(
    'my_folder/',
    'my_folder_renamed/',
    'public-read',
  );
  console.log(res);
})();

Removal

(async () => {
  const res = await removeDirectory('my_folder/');
  console.log(res);
})();

Who do I talk to?

  • henco@verge.co.za

Contribution guidelines

  • follow the AirBnB coding standards and linter

License

Copyright Verge Technologies

1.0.0

5 years ago