forked from reekoheek/xeekee
-
Notifications
You must be signed in to change notification settings - Fork 0
/
paxfile.js
120 lines (92 loc) · 3.18 KB
/
paxfile.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
var moment = require('moment'),
mustache = require('mustache'),
fs = require('fs'),
spawn = require('child_process').spawn;
module.exports = function() {
"use strict";
var mkdirp = this.require('mkdirp'),
Q = this.require('q');
this.task('init', function(logger) {
return this.exec(['php', 'composer', 'install'], logger);
});
this.task('serve', function(logger) {
if (!this.argv.t) {
this.argv.t = './www';
}
return this.exec(['php', 'serve'], logger);
});
this.task('migrate:generate', function() {
var logger = arguments[arguments.length - 1],
className = 'Migrate',
title = 'Migrate',
now = new Date();
for(var i = 0; i < arguments.length - 1; i++) {
var s = arguments[i].toLowerCase(),
w = s[0].toUpperCase() + s.substr(1);
className += w;
title += ' ' + w;
}
className += '_' + moment.utc(now).format('YYYYMMDDHHmmss');
mkdirp.sync('migrations');
var content = mustache.render(fs.readFileSync('pax_templates/Migrate.php').toString(), {
className: className,
title: title,
time: moment.utc(now).format()
});
fs.writeFile('migrations/' + className + '.php', content);
});
this.task('migrate', function() {
var logger = arguments[arguments.length - 1],
cmd = spawn('php', ['index.php', 'migrate', 'show'], {
cwd: 'www'
}),
deferred = Q.defer();
logger.head('Show migration...');
cmd.stdout.on('data', function(data) {
logger.log(data.toString().trim());
});
cmd.stderr.on('data', function(data) {
logger.error(data.toString().trim());
});
cmd.on('close', function() {
deferred.resolve();
});
return deferred.promise;
});
this.task('migrate:run', function() {
var logger = arguments[arguments.length - 1],
cmd = spawn('php', ['index.php', 'migrate', 'run'], {
cwd: 'www'
}),
deferred = Q.defer();
logger.head('Run migration...');
cmd.stdout.on('data', function(data) {
logger.log(data.toString().trim());
});
cmd.stderr.on('data', function(data) {
logger.error(data.toString().trim());
});
cmd.on('close', function() {
deferred.resolve();
});
return deferred.promise;
});
this.task('migrate:rollback', function() {
var logger = arguments[arguments.length - 1],
cmd = spawn('php', ['index.php', 'migrate', 'rollback'], {
cwd: 'www'
}),
deferred = Q.defer();
logger.head('Rollback migration...');
cmd.stdout.on('data', function(data) {
logger.log(data.toString().trim());
});
cmd.stderr.on('data', function(data) {
logger.error(data.toString().trim());
});
cmd.on('close', function() {
deferred.resolve();
});
return deferred.promise;
});
};