mirror of https://github.com/GOSTSec/gostexplr
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
52 lines
1.7 KiB
52 lines
1.7 KiB
7 years ago
|
#!/usr/bin/env node
|
||
|
var exec = require('child_process').exec;
|
||
|
var models = require('../models');
|
||
|
var env = process.env.NODE_ENV || 'development';
|
||
|
var config = require(__dirname + '/../config/config.json')[env];
|
||
|
|
||
|
if (process.argv.length < 4) {
|
||
|
console.log('Provide root user name and password for mysql');
|
||
|
process.exit(0);
|
||
|
}
|
||
|
|
||
|
const dropUserDB = `mysql -u${process.argv[2]} -p${process.argv[3]} -e "drop database ${config.database};drop user ${config.username}"`
|
||
|
const createdb = `mysql -u${process.argv[2]} -p${process.argv[3]} -e "create database ${config.database}"`;
|
||
|
const createUser = `mysql -u${process.argv[2]} -p${process.argv[3]} -e "create user ${config.username} identified by '${config.password}'"`;
|
||
|
const grantAccess = `mysql -u${process.argv[2]} -p${process.argv[3]} -e "grant all on ${config.database}.* to ${config.username}"`;
|
||
|
|
||
|
exec(dropUserDB, function(err,stdout,stderr) {
|
||
|
console.log(stdout);
|
||
|
exec(createdb, function(err,stdout,stderr) {
|
||
|
if (err) {
|
||
|
console.log(err);
|
||
|
process.exit(0);
|
||
|
} else {
|
||
|
console.log(stdout);
|
||
|
exec(createUser, function(err, stdout, stderr) {
|
||
|
if (err) {
|
||
|
console.log(err);
|
||
|
process.exit(0);
|
||
|
} else {
|
||
|
console.log(stdout);
|
||
|
exec(grantAccess, function(err, stdout, stderr) {
|
||
|
if (err) {
|
||
|
console.log(err);
|
||
|
} else {
|
||
|
console.log(stdout);
|
||
|
models.sequelize.sync({force: true})
|
||
|
.then(() => {
|
||
|
console.log(`\nUSER (${config.username}) AND DATABASE (${config.database}) CREATED SUCCESSFULLY`);
|
||
|
process.exit(0);
|
||
|
})
|
||
|
.catch((err) => {
|
||
|
console.log(err);
|
||
|
process.exit(0);
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
});
|