2012-08-10 01:34:00 +00:00
|
|
|
/*
|
|
|
|
* grunt-couchapp https://github.com/elf/grunt-couchapp
|
|
|
|
*
|
|
|
|
* Copyright (c) 2012 Ken "Elf" Mathieu Sternberg
|
|
|
|
* Licensed under the MIT license.
|
|
|
|
*/
|
|
|
|
|
2013-07-03 17:27:18 +00:00
|
|
|
var path, couchapp, nanolib, urls, async;
|
2012-08-10 01:34:00 +00:00
|
|
|
|
|
|
|
path = require('path');
|
|
|
|
couchapp = require('couchapp');
|
|
|
|
urls = require('url');
|
2013-07-03 17:27:18 +00:00
|
|
|
async = require('async');
|
2012-08-10 01:34:00 +00:00
|
|
|
|
2013-09-09 02:06:49 +00:00
|
|
|
var genDB = function(db) {
|
|
|
|
var parts, dbname, auth;
|
|
|
|
parts = urls.parse(db);
|
|
|
|
dbname = parts.pathname.replace(/^\//, '');
|
|
|
|
auth = parts.auth ? (parts.auth + '@') : '';
|
|
|
|
return {
|
|
|
|
name: dbname,
|
|
|
|
url: parts.protocol + '//' + auth + parts.host
|
|
|
|
};
|
|
|
|
};
|
2012-08-10 01:34:00 +00:00
|
|
|
|
2012-11-17 00:50:59 +00:00
|
|
|
var genDB = function(db) {
|
|
|
|
var parts, dbname, auth;
|
|
|
|
parts = urls.parse(db);
|
|
|
|
dbname = parts.pathname.replace(/^\//, '');
|
|
|
|
auth = parts.auth ? (parts.auth + '@') : '';
|
|
|
|
return {
|
|
|
|
name: dbname,
|
|
|
|
url: parts.protocol + '//' + auth + parts.host
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2012-08-10 01:34:00 +00:00
|
|
|
module.exports = function(grunt) {
|
|
|
|
|
|
|
|
// ==========================================================================
|
|
|
|
// TASKS
|
|
|
|
// ==========================================================================
|
|
|
|
|
|
|
|
grunt.registerMultiTask("couchapp", "Install Couchapp", function() {
|
2013-07-03 17:27:18 +00:00
|
|
|
var task = this;
|
|
|
|
var done = this.async();
|
2013-07-03 16:44:49 +00:00
|
|
|
|
|
|
|
async.each(this.files, function(file, cb) {
|
2013-07-03 17:27:18 +00:00
|
|
|
var appobj, apppath
|
|
|
|
apppath = path.join(process.cwd(), path.normalize(file.src[0]))
|
|
|
|
try {
|
|
|
|
appobj = require(apppath)
|
|
|
|
couchapp.createApp(appobj, task.data.db, function(app) {
|
|
|
|
app.push(cb);
|
|
|
|
});
|
|
|
|
} catch(ex) {
|
|
|
|
grunt.log.error(ex);
|
|
|
|
grunt.log.warn('Could not load couchapp from ' + apppath + '.');
|
|
|
|
cb();
|
|
|
|
}
|
|
|
|
}, done);
|
2012-08-10 01:34:00 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
grunt.registerMultiTask("rmcouchdb", "Delete a Couch Database", function() {
|
|
|
|
var done, parts, nano, dbname, _this;
|
|
|
|
_this = this;
|
|
|
|
done = this.async();
|
2012-11-17 00:50:59 +00:00
|
|
|
db = genDB(this.data.db);
|
2012-08-10 01:34:00 +00:00
|
|
|
try {
|
2012-11-17 00:50:59 +00:00
|
|
|
nano = require('nano')(db.url);
|
2013-09-09 02:11:23 +00:00
|
|
|
if (db.name) {
|
|
|
|
nano.db.destroy(db.name, function(err) {
|
2013-09-06 14:02:16 +00:00
|
|
|
if (err) {
|
|
|
|
if (err.status_code && err.status_code === 404) {
|
|
|
|
if (_this.data.options && _this.data.options.okay_if_missing) {
|
2013-09-09 02:11:23 +00:00
|
|
|
grunt.log.writeln("Database " + db.name + " not present... skipping.");
|
2013-09-06 14:02:16 +00:00
|
|
|
return done(null, null) ;
|
|
|
|
} else {
|
2013-09-09 02:11:23 +00:00
|
|
|
grunt.warn("Database " + db.name + " does not exist.");
|
2013-09-06 14:02:16 +00:00
|
|
|
}
|
2012-08-10 01:34:00 +00:00
|
|
|
} else {
|
2013-09-06 14:02:16 +00:00
|
|
|
grunt.warn(err);
|
2012-08-10 01:34:00 +00:00
|
|
|
}
|
|
|
|
}
|
2013-09-06 14:02:16 +00:00
|
|
|
return done(err, null);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
grunt.log.writeln("No database specified... skipping.");
|
|
|
|
return done(null, null);
|
|
|
|
}
|
2012-08-10 01:34:00 +00:00
|
|
|
} catch (e) {
|
|
|
|
grunt.warn(e);
|
|
|
|
done(e, null);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2013-08-22 03:49:53 +00:00
|
|
|
grunt.registerMultiTask("mkcouchdb", "Make a Couch Database", function() {
|
|
|
|
var done, parts, nano, dbname, _this;
|
2012-10-30 19:17:55 +00:00
|
|
|
_this = this;
|
2012-11-17 00:50:59 +00:00
|
|
|
|
2012-08-10 01:34:00 +00:00
|
|
|
done = this.async();
|
|
|
|
parts = urls.parse(this.data.db);
|
2012-11-17 00:50:59 +00:00
|
|
|
db = genDB(this.data.db);
|
2012-08-10 01:34:00 +00:00
|
|
|
try {
|
2013-09-09 02:11:23 +00:00
|
|
|
if (db.name) {
|
|
|
|
nano = require('nano')(db.url);
|
|
|
|
nano.db.create(db.name, function(err) {
|
2013-09-06 14:02:16 +00:00
|
|
|
if (_this.data.options && _this.data.options.okay_if_exists) {
|
|
|
|
if (err){
|
2013-09-09 02:11:23 +00:00
|
|
|
grunt.log.writeln("Database " + db.name + " exists, skipping");
|
2013-09-06 14:02:16 +00:00
|
|
|
}
|
|
|
|
return done(null, null);
|
|
|
|
} else {
|
|
|
|
if (err){
|
|
|
|
grunt.warn(err);
|
|
|
|
}
|
|
|
|
return done(err, null);
|
2012-10-30 19:17:55 +00:00
|
|
|
}
|
2013-09-06 14:02:16 +00:00
|
|
|
});
|
|
|
|
} else {
|
2013-09-06 14:04:20 +00:00
|
|
|
var err_msg = "No database specified to create!";
|
2013-09-06 14:02:16 +00:00
|
|
|
grunt.warn(err_msg);
|
|
|
|
return done(new Error(err_msg), null);
|
|
|
|
}
|
2012-08-10 01:34:00 +00:00
|
|
|
} catch (e) {
|
|
|
|
grunt.warn(e);
|
|
|
|
done(e, null);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
};
|