Skip to content

lawnstarter/gulp-sentry-release

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 

Repository files navigation

gulp-sentry-release

npm

gulp-sentry-release facilitates the process of uploading your sourcemaps / min files to sentry. Also it provides an easy way to create and delete your version.

Why use it

It's a pain in the ass using curl to upload a file.

Install

npm install gulp-sentry-release --save-dev

How do I use this awesome gulp plugin?

Go to sentry and create an API Token at https://sentry.io/api/. The token must have project:read, project:write, project:releases permissions

Include this in your gulp file:

var opt = {
  // prefix domain in the `name` param when uploading a file. Leave blank to use the path
  // verbatim. Do not include a trailing slash.
  DOMAIN: '',
  API_URL: 'https://app.getsentry.com/api/0/projects/ORGANIZATION/PROJECT/',
  API_KEY: 'MY_LONG_AUTH_TOKEN',
  debug: true,
  versionPrefix: '' // Append before the version number in package.json
  failOnError: true // Fail if Sentry upload fails to upload any file
}

// Pull the version from the package.json file.
var sentryRelease = require('gulp-sentry-release')('./package.json', opt);

// Specify the version directly.
var sentryRelease = require('gulp-sentry-release')({
  API_URL: 'https://app.getsentry.com/api/0/projects/ORGANIZATION/PROJECT/',
  API_KEY: 'MY_LONG_AUTH_TOKEN',
  version: 'v0.1.7' // If specified, uses this version number.
});

Some gulp tasks you can use

var gutil = require('gulp-util');
var sentrySrc = [
  './path/to/public/js/**/*.js',
];

/*
  gulp sentry:release // Use package.json version
  gulp sentry:release -v 'version'
  gulp sentry:release --version 'version'
*/
gulp.task('sentry:release', function () {
  var version = gutil.env.version || gutil.env.v;
  return gulp.src(sentrySrc, { base: './path/to/public' })
    .pipe(sentryRelease.release(version));
});

/*
  gulp sentry:delete -v 'version'
  gulp sentry:delete --version 'version'
*/
gulp.task('sentry:delete', function () {
  var version = gutil.env.version || gutil.env.v;
  return gulp.src(sentrySrc, { base: './path/to/public' })
    .pipe(sentryRelease.deleteVersion(version));
});

/*
  gulp sentry:create -v 'version'
  gulp sentry:create --version 'version'
*/
gulp.task('sentry:create', function () {
  var version = gutil.env.version || gutil.env.v;
  return gulp.src(sentrySrc, { base: './path/to/public' })
    .pipe(sentryRelease.createVersion(version));
});

API

sentryRelease.release(version)

Pipe your entire file stream and upload it to sentry When version is left blank, it will use the package.json version instead

sentryRelease.deleteVersion(version)

Delete a version

sentryRelease.createVersion(version)

Create a version

sentryRelease.sentryAPI

Sentry API Request Wrapper

  • create(version, cb(err, res, body))
  • delete(version, cb(err, res, body))
  • upload(version, file, cb(err, res, body))

Contribute

If you think it would make sense to add some features/methods, don't hesitate to fork and make pull requests.

License

Distributed under the MIT License.

About

Release your files to Sentry using Sentry Release API

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 100.0%