summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--tasks/cdn.js35
-rw-r--r--tasks/config.js6
-rw-r--r--tasks/zip.js13
3 files changed, 37 insertions, 17 deletions
diff --git a/tasks/cdn.js b/tasks/cdn.js
index 481a3c9..d81eef7 100644
--- a/tasks/cdn.js
+++ b/tasks/cdn.js
@@ -12,7 +12,9 @@ var args = require('yargs').argv;
var git = require('gulp-git');
var stagingBasePath = config.paths.staging.cdn;
-var version = args.release || args.preRelease || args.autoRevert ? config.version : config.snapshotVersion;
+var version = config.version;
+var host = config.cdnHost;
+var permalink = config.permalink;
var stagingPath = stagingBasePath + '/' + version;
var testPath = process.cwd() + '/' + stagingPath + '/test';
@@ -36,16 +38,13 @@ gulp.task('cdn:stage-vaadin-components', function() {
gulp.task('stage:cdn', [ 'clean:cdn', 'cdn:stage-bower_components', 'cdn:stage-vaadin-components' ]);
-gulp.task('deploy:cdn', ['stage:cdn'], function() {
+gulp.task('upload:cdn', ['stage:cdn'], function() {
common.checkArguments(['cdnUsername', 'cdnDestination']);
- var hostName = args.cdnHostname || 'cdn.vaadin.com';
-
- gutil.log('Uploading to cdn (rsync): ' + stagingPath + ' -> '+ args.cdnUsername + '@' + hostName + ':' + args.cdnDestination + version);
-
+ gutil.log('Uploading to cdn (rsync): ' + stagingPath + ' -> '+ args.cdnUsername + '@' + host + ':' + args.cdnDestination + version);
return gulp.src(stagingPath)
.pipe(rsync({
username: args.cdnUsername,
- hostname: hostName,
+ hostname: host,
root: stagingPath,
emptyDirectories: false,
recursive: true,
@@ -55,6 +54,26 @@ gulp.task('deploy:cdn', ['stage:cdn'], function() {
}));
});
+gulp.task('deploy:cdn', ['upload:cdn'], function(done) {
+ if (permalink) {
+ var cmd = 'rm -f ' + args.cdnDestination + permalink + '; ln -s ' + version + ' ' + args.cdnDestination + permalink + '; ls -l ' + args.cdnDestination;
+ gutil.log('Deploying CDN : ssh ' + args.cdnUsername + '@' + host + ' ' + cmd);
+ require('node-ssh-exec')({
+ host: host,
+ username: args.cdnUsername,
+ privateKey: config.paths.privateKey()
+ }, cmd, function (error, response) {
+ if (error) {
+ throw error;
+ }
+ gutil.log(response);
+ done();
+ });
+ } else {
+ done();
+ }
+});
+
gulp.task('cdn-test:clean', function() {
fs.removeSync(stagingPath + '/test');
});
@@ -100,7 +119,7 @@ gulp.task('verify:cdn', ['cdn-test:stage'], function(done) {
gutil.log('Deleting folder ' + args.cdnDestination + version);
require('node-ssh-exec')({
- host: 'cdn.vaadin.com',
+ host: host,
username: args.cdnUsername,
privateKey: config.paths.privateKey()
}, 'rm -rf ' + args.cdnDestination + version, function (error, response) {
diff --git a/tasks/config.js b/tasks/config.js
index 248a927..dc48921 100644
--- a/tasks/config.js
+++ b/tasks/config.js
@@ -5,8 +5,10 @@ var userhome = process.env.HOME || process.env.HOMEPATH || process.env.USERPROFI
module.exports = {
components: ['vaadin-grid'],
- snapshotVersion: 'master',
- version: args.version || this.snapshotVersion,
+ version: args.version || 'master',
+ permalink: args.version ? 'latest' : '',
+ cdnHost: args.cdnHostname || 'cdn.vaadin.com',
+ zipHost: args.zipHostname || 'vaadin.com',
paths: {
staging: {
bower: 'target/bower',
diff --git a/tasks/zip.js b/tasks/zip.js
index fc0f854..f649d98 100644
--- a/tasks/zip.js
+++ b/tasks/zip.js
@@ -12,7 +12,8 @@ var unzip = require('gulp-unzip');
var zip = require('gulp-zip');
var stagingPath = config.paths.staging.zip;
-var version = args.release || args.preRelease ? config.version : config.snapshotVersion;
+var version = config.version;
+var host = config.zipHost;
var filename = 'vaadin-components-' + version + '.zip';
var majorMinorVersion = version.replace(/(\d+\.\d+)(\.|-)(.*)/, '$1');
@@ -29,13 +30,12 @@ gulp.task('stage:zip', ['clean:zip', 'stage:cdn'], function() {
gulp.task('zip:upload', ['stage:zip'], function(done) {
common.checkArguments(['zipUsername', 'zipDestination']);
- var hostName = args.zipHostname || 'vaadin.com';
var path = args.zipDestination + majorMinorVersion + '/' + version + '/' + filename;
- gutil.log('Uploading zip package (scp): ' + stagingPath + '/' + filename + ' -> ' + args.zipUsername + '@' + hostName + ':' + path);
+ gutil.log('Uploading zip package (scp): ' + stagingPath + '/' + filename + ' -> ' + args.zipUsername + '@' + host + ':' + path);
require('scp2').scp(stagingPath + '/' + filename, {
- host: hostName,
+ host: host,
username: args.zipUsername,
privateKey: config.paths.privateKey(),
path: path
@@ -45,11 +45,10 @@ gulp.task('zip:upload', ['stage:zip'], function(done) {
});
function ssh(command, done) {
- var hostName = args.sshHostname || 'vaadin.com';
- gutil.log('SSH: ' + hostName + ' -> ' + command);
+ gutil.log('SSH: ' + host + ' -> ' + command);
require('node-ssh-exec')({
- host: hostName,
+ host: host,
username: args.zipUsername,
privateKey: config.paths.privateKey()
}, command,