gulp-s3
Version: 
Uploads files to s3
95 lines (67 loc) • 1.92 kB
Markdown
> s3 plugin for [gulp](https://github.com/wearefractal/gulp)
First, install `gulp-s3` as a development dependency:
```shell
npm install --save-dev gulp-s3
```
Then, use it in your `gulpfile.js`:
```javascript
var s3   = require('gulp-s3')
var gulp = require('gulp')
var AWS = {
  "key":    process.env.AWS_ACCESS_KEY_ID,
  "secret": process.env.AWS_SECRET_ACCESS_KEY,
  "bucket": "dev.example.com",
  "region": "eu-west-1"
}
gulp.task('default', () => {
  gulp.src('./dist/**').pipe(s3(AWS));
});
```
Type: `String`          
Default: ``
Set the remote folder on the S3 bucket
```javascript
var options = { uploadPath: 'remote-folder' } // It will upload the 'src' into '/remote-folder'
gulp.src('./dist/**', {read: false})
    .pipe(s3(AWS, options));
```
Type: `Object`          
Default: `{}`
Headers to set to each file uploaded to S3
```javascript
var options = { 
  headers: {
    'Cache-Control': 'max-age=315360000, no-transform, public',
    'x-amz-acl': 'private'
  } 
};
gulp.src('./dist/**', {read: false})
    .pipe(s3(AWS, options));
```
Type: `Boolean`          
Default: `false`
Only upload files with .gz extension, additionally it will remove the .gz suffix on destination filename and set appropriate Content-Type and Content-Encoding headers.
```javascript
var options = { gzippedOnly: true };
gulp.src('./dist/**').pipe(gzip())
    .pipe(s3(AWS, options));
```
Type: `Boolean`
Default: `false`
Throw error if upload to s3 fails.
```javascript
var options = { failOnError: true };
gulp.src('./dist/**').pipe(gzip())
    .pipe(s3(AWS, options));
```
[](http://en.wikipedia.org/wiki/MIT_License)
[]: https://npmjs.org/package/gulp-s3
[]: https://badge.fury.io/js/gulp-s3.png