strapi/bin/strapi-update.js

87 lines
3.0 KiB
JavaScript
Raw Normal View History

2015-10-05 14:06:11 +02:00
#!/usr/bin/env node
2015-10-01 00:30:16 +02:00
'use strict';
/**
* Module dependencies
*/
// Node.js core.
const fs = require('fs');
const path = require('path');
const exec = require('child_process').exec;
// Public node modules.
const _ = require('lodash');
const winston = require('winston');
// Logger.
const logger = new (winston.Logger)({
transports: [
new (winston.transports.Console)({
level: 'debug',
colorize: 'level'
})
]
});
/**
* `$ strapi update`
*
* Pull latest update from custom generators
* readed from the RC file at $HOME.
*/
module.exports = function () {
const HOME = process.env[process.platform === 'win32' ? 'USERPROFILE' : 'HOME'];
fs.access(path.resolve(HOME, '.strapirc'), fs.F_OK | fs.R_OK | fs.W_OK, function (err) {
if (err) {
if (err.code === 'ENOENT') {
2015-10-08 09:12:55 +02:00
logger.error('No `.strapirc` file detected at `' + HOME + '`.');
logger.error('Execute `$ strapi config` to create one.');
2015-10-01 00:30:16 +02:00
} else if (err.code === 'EACCES') {
2015-10-08 09:12:55 +02:00
logger.error('Impossible to access the `.strapirc` file at `' + HOME + '`.');
logger.error('Please check read/write permissions before execute `$ strapi update`.');
2015-10-01 00:30:16 +02:00
}
process.exit(1);
} else {
const config = JSON.parse(fs.readFileSync(path.resolve(HOME, '.strapirc')));
2015-10-08 09:12:55 +02:00
_.forEach(config.generators, function (info, name) {
2015-10-01 00:30:16 +02:00
try {
2015-10-08 09:12:55 +02:00
process.chdir(path.resolve(__dirname, '..', 'node_modules', 'strapi-generate-' + name));
logger.debug('Pulling the latest updates of `strapi-generate-' + name + '`.');
2015-10-01 00:30:16 +02:00
exec('git pull ' + info.remote + ' ' + info.branch, function (err) {
if (err) {
2015-10-08 09:12:55 +02:00
logger.error('Impossible to update `strapi-generate-' + name + '`.');
2015-10-01 00:30:16 +02:00
} else {
2015-10-08 09:12:55 +02:00
logger.info('Successfully updated `strapi-generate-' + name + '`.');
2015-10-01 00:30:16 +02:00
}
});
} catch (err) {
process.chdir(path.resolve(__dirname, '..', 'node_modules'));
2015-10-08 09:12:55 +02:00
logger.debug('Cloning the `strapi-generate-' + name + '` repository for the first time...');
exec('git clone ' + info.repository + ' strapi-generate-' + name, function (err) {
2015-10-01 00:30:16 +02:00
if (err) {
2015-10-08 09:12:55 +02:00
logger.error('Impossible to clone the `strapi-generate-' + name + '` repository.');
2015-10-01 00:30:16 +02:00
console.log(err);
} else {
2015-10-08 09:12:55 +02:00
logger.info('Successfully cloned the `strapi-generate-' + name + '` repository.');
process.chdir(path.resolve(__dirname, '..', 'node_modules', 'strapi-generate-' + name));
logger.debug('Installing dependencies for `strapi-generate-' + name + '`...');
2015-10-01 00:30:16 +02:00
exec('npm install', function (err) {
if (err) {
2015-10-08 09:12:55 +02:00
logger.error('Impossible to install dependencies for `strapi-generate-' + name + '`.');
2015-10-01 00:30:16 +02:00
console.log(err);
} else {
2015-10-08 09:12:55 +02:00
logger.info('Successfully installed dependencies for `strapi-generate-' + name + '`.');
2015-10-01 00:30:16 +02:00
}
});
}
});
}
});
}
});
};