git-push-deploy-cli 0.2.2 → 0.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +466 -108
- package/dist/commands/config.d.ts +10 -0
- package/dist/commands/config.d.ts.map +1 -0
- package/dist/commands/config.js +295 -0
- package/dist/commands/config.js.map +1 -0
- package/dist/commands/daemon.d.ts +10 -0
- package/dist/commands/daemon.d.ts.map +1 -0
- package/dist/commands/daemon.js +67 -0
- package/dist/commands/daemon.js.map +1 -0
- package/dist/commands/deploy.d.ts +2 -1
- package/dist/commands/deploy.d.ts.map +1 -1
- package/dist/commands/deploy.js +23 -5
- package/dist/commands/deploy.js.map +1 -1
- package/dist/commands/init.d.ts.map +1 -1
- package/dist/commands/init.js +36 -19
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/install.d.ts.map +1 -1
- package/dist/commands/install.js +98 -3
- package/dist/commands/install.js.map +1 -1
- package/dist/commands/logs.d.ts +1 -0
- package/dist/commands/logs.d.ts.map +1 -1
- package/dist/commands/logs.js +4 -1
- package/dist/commands/logs.js.map +1 -1
- package/dist/commands/release.d.ts +5 -1
- package/dist/commands/release.d.ts.map +1 -1
- package/dist/commands/release.js +204 -6
- package/dist/commands/release.js.map +1 -1
- package/dist/commands/rollback.d.ts +17 -0
- package/dist/commands/rollback.d.ts.map +1 -0
- package/dist/commands/rollback.js +169 -0
- package/dist/commands/rollback.js.map +1 -0
- package/dist/commands/stage.d.ts +4 -0
- package/dist/commands/stage.d.ts.map +1 -1
- package/dist/commands/stage.js +52 -4
- package/dist/commands/stage.js.map +1 -1
- package/dist/commands/status.d.ts.map +1 -1
- package/dist/commands/status.js +15 -2
- package/dist/commands/status.js.map +1 -1
- package/dist/config/loader.d.ts +1 -0
- package/dist/config/loader.d.ts.map +1 -1
- package/dist/config/loader.js +1 -1
- package/dist/config/loader.js.map +1 -1
- package/dist/config/types.d.ts +112 -14
- package/dist/config/types.d.ts.map +1 -1
- package/dist/config/types.js +20 -0
- package/dist/config/types.js.map +1 -1
- package/dist/index.js +31 -2
- package/dist/index.js.map +1 -1
- package/dist/utils/git.d.ts +43 -0
- package/dist/utils/git.d.ts.map +1 -1
- package/dist/utils/git.js +98 -0
- package/dist/utils/git.js.map +1 -1
- package/dist/utils/notifications.d.ts +6 -0
- package/dist/utils/notifications.d.ts.map +1 -0
- package/dist/utils/notifications.js +188 -0
- package/dist/utils/notifications.js.map +1 -0
- package/dist/utils/shell.d.ts +4 -0
- package/dist/utils/shell.d.ts.map +1 -1
- package/dist/utils/shell.js +18 -0
- package/dist/utils/shell.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
import chalk from 'chalk';
|
|
2
|
+
import * as readline from 'readline';
|
|
3
|
+
import { getServiceConfig, getWorkspaceRoot, getDeployRepoPath } from '../config/loader.js';
|
|
4
|
+
import { getCommitLogDetailed, getCurrentCommit, getCommitByRef, gitResetHard, gitPushForce, getCurrentBranch } from '../utils/git.js';
|
|
5
|
+
import { exists, joinPath } from '../utils/files.js';
|
|
6
|
+
/**
|
|
7
|
+
* Prompt user for confirmation
|
|
8
|
+
*/
|
|
9
|
+
async function confirm(question) {
|
|
10
|
+
const rl = readline.createInterface({
|
|
11
|
+
input: process.stdin,
|
|
12
|
+
output: process.stdout
|
|
13
|
+
});
|
|
14
|
+
return new Promise((resolve) => {
|
|
15
|
+
rl.question(`${question} (y/n): `, (answer) => {
|
|
16
|
+
rl.close();
|
|
17
|
+
resolve(answer.toLowerCase() === 'y' || answer.toLowerCase() === 'yes');
|
|
18
|
+
});
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Prompt user to select a number
|
|
23
|
+
*/
|
|
24
|
+
async function promptNumber(prompt, max) {
|
|
25
|
+
const rl = readline.createInterface({
|
|
26
|
+
input: process.stdin,
|
|
27
|
+
output: process.stdout
|
|
28
|
+
});
|
|
29
|
+
return new Promise((resolve) => {
|
|
30
|
+
rl.question(prompt, (answer) => {
|
|
31
|
+
rl.close();
|
|
32
|
+
if (answer.toLowerCase() === 'q' || answer.toLowerCase() === 'quit') {
|
|
33
|
+
resolve(-1);
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
const num = parseInt(answer, 10);
|
|
37
|
+
if (num >= 1 && num <= max) {
|
|
38
|
+
resolve(num - 1);
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
resolve(-1);
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Rollback command - revert to a previous deployment
|
|
48
|
+
*
|
|
49
|
+
* Usage:
|
|
50
|
+
* gpd rollback <service> - Interactive selection from recent commits
|
|
51
|
+
* gpd rollback <service> --steps 2 - Go back 2 commits
|
|
52
|
+
* gpd rollback <service> --list - Show available versions without rollback
|
|
53
|
+
* gpd rollback <service> abc123 - Rollback to specific commit
|
|
54
|
+
*/
|
|
55
|
+
export async function rollbackCommand(serviceName, target, options = {}) {
|
|
56
|
+
const config = getServiceConfig(serviceName);
|
|
57
|
+
const workspaceRoot = getWorkspaceRoot();
|
|
58
|
+
const deployRepoPath = getDeployRepoPath(config, workspaceRoot);
|
|
59
|
+
// Check if deploy repo exists
|
|
60
|
+
if (!exists(joinPath(deployRepoPath, '.git'))) {
|
|
61
|
+
throw new Error(`Deploy repo not found at ${deployRepoPath}. Have you deployed before?`);
|
|
62
|
+
}
|
|
63
|
+
const currentCommit = getCurrentCommit(deployRepoPath);
|
|
64
|
+
const branch = getCurrentBranch(deployRepoPath);
|
|
65
|
+
// List mode - just show versions
|
|
66
|
+
if (options.list) {
|
|
67
|
+
console.log(chalk.blue(`Deployment history for ${serviceName}:`));
|
|
68
|
+
console.log('');
|
|
69
|
+
const commits = getCommitLogDetailed(deployRepoPath, 15);
|
|
70
|
+
commits.forEach((commit, index) => {
|
|
71
|
+
const tagInfo = commit.tags.length > 0 ? chalk.cyan(` [${commit.tags.join(', ')}]`) : '';
|
|
72
|
+
const current = index === 0 ? chalk.green(' (current)') : '';
|
|
73
|
+
console.log(chalk.yellow(commit.shortHash) +
|
|
74
|
+
chalk.gray(` ${commit.date} `) +
|
|
75
|
+
commit.message +
|
|
76
|
+
tagInfo +
|
|
77
|
+
current);
|
|
78
|
+
});
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
console.log(chalk.blue(`Rollback ${serviceName}...`));
|
|
82
|
+
console.log(chalk.gray(` Current: ${currentCommit.substring(0, 7)}`));
|
|
83
|
+
console.log(chalk.gray(` Branch: ${branch}`));
|
|
84
|
+
console.log('');
|
|
85
|
+
let targetCommit;
|
|
86
|
+
if (target) {
|
|
87
|
+
// Specific commit/ref provided
|
|
88
|
+
try {
|
|
89
|
+
targetCommit = getCommitByRef(deployRepoPath, target);
|
|
90
|
+
console.log(chalk.gray(` Target: ${targetCommit.substring(0, 7)} (from ${target})`));
|
|
91
|
+
}
|
|
92
|
+
catch {
|
|
93
|
+
throw new Error(`Invalid commit reference: ${target}`);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
else if (options.steps) {
|
|
97
|
+
// Go back N steps
|
|
98
|
+
try {
|
|
99
|
+
targetCommit = getCommitByRef(deployRepoPath, `HEAD~${options.steps}`);
|
|
100
|
+
const commits = getCommitLogDetailed(deployRepoPath, options.steps + 1);
|
|
101
|
+
const targetInfo = commits[options.steps];
|
|
102
|
+
if (targetInfo) {
|
|
103
|
+
const tagInfo = targetInfo.tags.length > 0 ? chalk.cyan(` [${targetInfo.tags.join(', ')}]`) : '';
|
|
104
|
+
console.log(chalk.gray(` Target: ${targetInfo.shortHash} ${targetInfo.message}${tagInfo}`));
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
catch {
|
|
108
|
+
throw new Error(`Cannot go back ${options.steps} commits`);
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
// Interactive selection - show detailed commit list
|
|
113
|
+
const commits = getCommitLogDetailed(deployRepoPath, 10);
|
|
114
|
+
if (commits.length <= 1) {
|
|
115
|
+
throw new Error('No previous commits to rollback to');
|
|
116
|
+
}
|
|
117
|
+
// Skip first commit (current) and display the rest
|
|
118
|
+
const previousCommits = commits.slice(1);
|
|
119
|
+
console.log(chalk.blue('Available versions to rollback to:'));
|
|
120
|
+
console.log('');
|
|
121
|
+
previousCommits.forEach((commit, index) => {
|
|
122
|
+
const tagInfo = commit.tags.length > 0 ? chalk.cyan(` [${commit.tags.join(', ')}]`) : '';
|
|
123
|
+
console.log(chalk.white(` ${index + 1}) `) + chalk.yellow(commit.shortHash) + chalk.gray(` ${commit.date} `) + commit.message + tagInfo);
|
|
124
|
+
});
|
|
125
|
+
console.log('');
|
|
126
|
+
const selection = await promptNumber(`Select version (1-${previousCommits.length}, q to quit): `, previousCommits.length);
|
|
127
|
+
if (selection < 0) {
|
|
128
|
+
console.log(chalk.yellow('Cancelled'));
|
|
129
|
+
return;
|
|
130
|
+
}
|
|
131
|
+
targetCommit = previousCommits[selection].hash;
|
|
132
|
+
const selected = previousCommits[selection];
|
|
133
|
+
const tagInfo = selected.tags.length > 0 ? ` [${selected.tags.join(', ')}]` : '';
|
|
134
|
+
console.log(chalk.gray(` Selected: ${selected.shortHash} ${selected.message}${tagInfo}`));
|
|
135
|
+
}
|
|
136
|
+
// Check if we're already at target
|
|
137
|
+
if (targetCommit === currentCommit) {
|
|
138
|
+
console.log(chalk.yellow('Already at target commit'));
|
|
139
|
+
return;
|
|
140
|
+
}
|
|
141
|
+
// Confirm unless --force
|
|
142
|
+
if (!options.force) {
|
|
143
|
+
console.log('');
|
|
144
|
+
console.log(chalk.yellow.bold('⚠ Warning: This will:'));
|
|
145
|
+
console.log(chalk.yellow(` 1. Reset deploy repo to ${targetCommit.substring(0, 7)}`));
|
|
146
|
+
console.log(chalk.yellow(` 2. Force push to server`));
|
|
147
|
+
console.log(chalk.yellow(` 3. Server will checkout and restart with old version`));
|
|
148
|
+
console.log('');
|
|
149
|
+
const shouldContinue = await confirm('Continue with rollback?');
|
|
150
|
+
if (!shouldContinue) {
|
|
151
|
+
console.log(chalk.yellow('Cancelled'));
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
// Perform rollback
|
|
156
|
+
console.log('');
|
|
157
|
+
console.log(chalk.blue('Performing rollback...'));
|
|
158
|
+
// 1. Reset local deploy repo
|
|
159
|
+
console.log(chalk.gray(` Resetting to ${targetCommit.substring(0, 7)}...`));
|
|
160
|
+
gitResetHard(deployRepoPath, targetCommit);
|
|
161
|
+
// 2. Force push to server
|
|
162
|
+
console.log(chalk.gray(` Force pushing to origin/${branch}...`));
|
|
163
|
+
gitPushForce(deployRepoPath, 'origin', branch);
|
|
164
|
+
console.log('');
|
|
165
|
+
console.log(chalk.green.bold(`✓ Rolled back ${serviceName} to ${targetCommit.substring(0, 7)}`));
|
|
166
|
+
console.log(chalk.gray(' The server hook will handle: git checkout, npm install, pm2 restart'));
|
|
167
|
+
console.log(chalk.gray(` Check logs: gpd logs ${serviceName}`));
|
|
168
|
+
}
|
|
169
|
+
//# sourceMappingURL=rollback.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rollback.js","sourceRoot":"","sources":["../../src/commands/rollback.ts"],"names":[],"mappings":"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"}
|
package/dist/commands/stage.d.ts
CHANGED
|
@@ -7,4 +7,8 @@
|
|
|
7
7
|
* - artifacts: copied from sourceDir to deployRepo
|
|
8
8
|
*/
|
|
9
9
|
export declare function stageCommand(serviceName: string): Promise<void>;
|
|
10
|
+
/**
|
|
11
|
+
* Dry run version of stage command - shows what would be copied without copying
|
|
12
|
+
*/
|
|
13
|
+
export declare function stageCommandDryRun(serviceName: string): Promise<void>;
|
|
10
14
|
//# sourceMappingURL=stage.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stage.d.ts","sourceRoot":"","sources":["../../src/commands/stage.ts"],"names":[],"mappings":"AAmCA;;;;;;;GAOG;AACH,wBAAsB,YAAY,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,
|
|
1
|
+
{"version":3,"file":"stage.d.ts","sourceRoot":"","sources":["../../src/commands/stage.ts"],"names":[],"mappings":"AAmCA;;;;;;;GAOG;AACH,wBAAsB,YAAY,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAuDrE;AAED;;GAEG;AACH,wBAAsB,kBAAkB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAwC3E"}
|
package/dist/commands/stage.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import chalk from 'chalk';
|
|
2
2
|
import { execSync } from 'child_process';
|
|
3
|
-
import { getServiceConfig, getWorkspaceRoot, getSourceDir, getDeployRepoPath } from '../config/loader.js';
|
|
4
|
-
import { DEFAULT_ARTIFACTS, parseSshPort, buildSshUrl } from '../config/types.js';
|
|
3
|
+
import { getServiceConfig, getWorkspaceRoot, getSourceDir, getDeployRepoPath, CONFIG_FILENAME } from '../config/loader.js';
|
|
4
|
+
import { DEFAULT_ARTIFACTS, parseSshPort, buildSshUrl, getPrimaryServer } from '../config/types.js';
|
|
5
5
|
import { ensureDir, removeDir, copy, exists, joinPath } from '../utils/files.js';
|
|
6
6
|
/**
|
|
7
7
|
* Initialize deploy repo if it doesn't exist (lazy init)
|
|
@@ -43,8 +43,9 @@ export async function stageCommand(serviceName) {
|
|
|
43
43
|
}
|
|
44
44
|
console.log(chalk.gray(` Source: ${config.sourceDir}`));
|
|
45
45
|
console.log(chalk.gray(` Deploy: ${config.sourceDir}/${config.deployRepo}`));
|
|
46
|
-
// Lazy init deploy repo
|
|
47
|
-
const
|
|
46
|
+
// Lazy init deploy repo (use primary server for remote)
|
|
47
|
+
const primaryServer = getPrimaryServer(config);
|
|
48
|
+
const { host, bareRepo, sshOptions } = primaryServer;
|
|
48
49
|
const wasInitialized = initDeployRepoIfNeeded(deployRepoPath, host, bareRepo, sshOptions);
|
|
49
50
|
if (wasInitialized) {
|
|
50
51
|
console.log(chalk.green(' ✓ Deploy repo initialized'));
|
|
@@ -68,6 +69,53 @@ export async function stageCommand(serviceName) {
|
|
|
68
69
|
if (copiedCount === 0) {
|
|
69
70
|
throw new Error('No artifacts were copied. Check your artifacts config and build output.');
|
|
70
71
|
}
|
|
72
|
+
// Copy .git-deploy.json to deploy repo (needed by server-side install)
|
|
73
|
+
const configSrc = joinPath(workspaceRoot, CONFIG_FILENAME);
|
|
74
|
+
const configDest = joinPath(deployRepoPath, CONFIG_FILENAME);
|
|
75
|
+
if (exists(configSrc)) {
|
|
76
|
+
copy(configSrc, configDest);
|
|
77
|
+
console.log(chalk.gray(` ${CONFIG_FILENAME}`));
|
|
78
|
+
}
|
|
71
79
|
console.log(chalk.green(`✓ Staged ${copiedCount} artifact(s) to ${config.sourceDir}/${config.deployRepo}`));
|
|
72
80
|
}
|
|
81
|
+
/**
|
|
82
|
+
* Dry run version of stage command - shows what would be copied without copying
|
|
83
|
+
*/
|
|
84
|
+
export async function stageCommandDryRun(serviceName) {
|
|
85
|
+
console.log(chalk.blue(`[DRY RUN] Stage preview for ${serviceName}...`));
|
|
86
|
+
const config = getServiceConfig(serviceName);
|
|
87
|
+
const workspaceRoot = getWorkspaceRoot();
|
|
88
|
+
const sourceDir = getSourceDir(config, workspaceRoot);
|
|
89
|
+
const deployRepoPath = getDeployRepoPath(config, workspaceRoot);
|
|
90
|
+
const artifacts = config.artifacts || DEFAULT_ARTIFACTS;
|
|
91
|
+
// Validate source directory exists
|
|
92
|
+
if (!exists(sourceDir)) {
|
|
93
|
+
throw new Error(`Source directory not found: ${sourceDir}`);
|
|
94
|
+
}
|
|
95
|
+
console.log(chalk.gray(` Source: ${config.sourceDir}`));
|
|
96
|
+
console.log(chalk.gray(` Deploy: ${config.sourceDir}/${config.deployRepo}`));
|
|
97
|
+
// Check if deploy repo needs init
|
|
98
|
+
if (!exists(joinPath(deployRepoPath, '.git'))) {
|
|
99
|
+
console.log(chalk.yellow(` Would initialize deploy repo at ${config.deployRepo}`));
|
|
100
|
+
}
|
|
101
|
+
// Show what would be copied
|
|
102
|
+
console.log(chalk.gray(' Would copy:'));
|
|
103
|
+
let wouldCopy = 0;
|
|
104
|
+
for (const artifact of artifacts) {
|
|
105
|
+
const srcPath = joinPath(sourceDir, artifact);
|
|
106
|
+
if (exists(srcPath)) {
|
|
107
|
+
console.log(chalk.gray(` ✓ ${artifact}`));
|
|
108
|
+
wouldCopy++;
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
console.log(chalk.yellow(` ✗ ${artifact} (not found)`));
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
if (wouldCopy === 0) {
|
|
115
|
+
console.log(chalk.red(' No artifacts would be copied!'));
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
console.log(chalk.gray(` Total: ${wouldCopy} artifact(s) would be staged`));
|
|
119
|
+
}
|
|
120
|
+
}
|
|
73
121
|
//# sourceMappingURL=stage.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stage.js","sourceRoot":"","sources":["../../src/commands/stage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"stage.js","sourceRoot":"","sources":["../../src/commands/stage.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"status.d.ts","sourceRoot":"","sources":["../../src/commands/status.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"status.d.ts","sourceRoot":"","sources":["../../src/commands/status.ts"],"names":[],"mappings":"AAIA;;GAEG;AACH,wBAAsB,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC,CAsCnD"}
|
package/dist/commands/status.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import chalk from 'chalk';
|
|
2
2
|
import { loadConfig, listServices } from '../config/loader.js';
|
|
3
|
+
import { getServers } from '../config/types.js';
|
|
3
4
|
/**
|
|
4
5
|
* Status command - show all configured services
|
|
5
6
|
*/
|
|
@@ -13,12 +14,24 @@ export async function statusCommand() {
|
|
|
13
14
|
console.log(chalk.white('Configured Services:'));
|
|
14
15
|
for (const name of services) {
|
|
15
16
|
const svc = config.services[name];
|
|
17
|
+
const servers = getServers(svc);
|
|
16
18
|
console.log(chalk.gray(` ${name}`));
|
|
17
|
-
|
|
19
|
+
if (servers.length === 1) {
|
|
20
|
+
console.log(chalk.gray(` Host: ${servers[0].host}`));
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
console.log(chalk.gray(` Servers: ${servers.length}`));
|
|
24
|
+
for (const server of servers) {
|
|
25
|
+
const label = server.name || server.host;
|
|
26
|
+
console.log(chalk.gray(` - ${label}`));
|
|
27
|
+
}
|
|
28
|
+
}
|
|
18
29
|
console.log(chalk.gray(` Process: ${svc.processName}`));
|
|
19
30
|
console.log(chalk.gray(` Source: ${svc.sourceDir}`));
|
|
20
31
|
console.log(chalk.gray(` Deploy: ${svc.sourceDir}/${svc.deployRepo}`));
|
|
21
|
-
|
|
32
|
+
if (servers.length === 1) {
|
|
33
|
+
console.log(chalk.gray(` Target: ${servers[0].targetDir}`));
|
|
34
|
+
}
|
|
22
35
|
if (svc.environment) {
|
|
23
36
|
console.log(chalk.gray(` Environment: ${svc.environment}`));
|
|
24
37
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"status.js","sourceRoot":"","sources":["../../src/commands/status.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"status.js","sourceRoot":"","sources":["../../src/commands/status.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAEhD;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,aAAa;IACjC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC;IAC1C,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAEhB,2BAA2B;IAC3B,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,YAAY,EAAE,CAAC;QAChC,MAAM,MAAM,GAAG,UAAU,EAAE,CAAC;QAE5B,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC,CAAC;QACjD,KAAK,MAAM,IAAI,IAAI,QAAQ,EAAE,CAAC;YAC5B,MAAM,GAAG,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAClC,MAAM,OAAO,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC;YAChC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,CAAC;YACrC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACzB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,aAAa,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YAC1D,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,gBAAgB,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;gBAC1D,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;oBAC7B,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC;oBACzC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,KAAK,EAAE,CAAC,CAAC,CAAC;gBAC9C,CAAC;YACH,CAAC;YACD,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,gBAAgB,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;YAC3D,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,GAAG,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;YACxD,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,GAAG,CAAC,SAAS,IAAI,GAAG,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;YAC1E,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACzB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;YACjE,CAAC;YACD,IAAI,GAAG,CAAC,WAAW,EAAE,CAAC;gBACpB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,oBAAoB,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;YACjE,CAAC;QACH,CAAC;QACD,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAClB,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,sDAAsD,CAAC,CAAC,CAAC;QAClF,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAClB,CAAC;AACH,CAAC"}
|
package/dist/config/loader.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"loader.d.ts","sourceRoot":"","sources":["../../src/config/loader.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"loader.d.ts","sourceRoot":"","sources":["../../src/config/loader.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAE9D,eAAO,MAAM,eAAe,qBAAqB,CAAC;AAElD;;GAEG;AACH,wBAAgB,cAAc,CAAC,QAAQ,GAAE,MAAsB,GAAG,MAAM,GAAG,IAAI,CAY9E;AAED;;GAEG;AACH,wBAAgB,UAAU,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,YAAY,CAgB5D;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,WAAW,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,aAAa,CAUxF;AAED;;GAEG;AACH,wBAAgB,gBAAgB,IAAI,MAAM,CAMzC;AAED;;;;;GAKG;AACH,wBAAgB,YAAY,CAAC,MAAM,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,GAAG,MAAM,CAEjF;AAED;;;;;GAKG;AACH,wBAAgB,iBAAiB,CAAC,MAAM,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,GAAG,MAAM,CAEtF;AAED;;GAEG;AACH,wBAAgB,YAAY,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAG1D"}
|
package/dist/config/loader.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"loader.js","sourceRoot":"","sources":["../../src/config/loader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,IAAI,CAAC;AAC9C,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAGrC,MAAM,eAAe,GAAG,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"loader.js","sourceRoot":"","sources":["../../src/config/loader.ts"],"names":[],"mappings":"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"}
|
package/dist/config/types.d.ts
CHANGED
|
@@ -1,11 +1,101 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Process manager type
|
|
3
3
|
*/
|
|
4
|
-
export type ProcessManagerType = 'pm2' | 'systemd';
|
|
4
|
+
export type ProcessManagerType = 'pm2' | 'systemd' | 'gpdd';
|
|
5
5
|
/**
|
|
6
6
|
* Environment type for deployment
|
|
7
7
|
*/
|
|
8
8
|
export type EnvironmentType = 'production' | 'staging' | 'development';
|
|
9
|
+
/**
|
|
10
|
+
* Hooks configuration for pre/post deployment scripts
|
|
11
|
+
*/
|
|
12
|
+
export interface HooksConfig {
|
|
13
|
+
/** Commands to run locally before deployment (before git push) */
|
|
14
|
+
preDeploy?: string[];
|
|
15
|
+
/** Commands to run on server after deployment (after npm install) */
|
|
16
|
+
postDeploy?: string[];
|
|
17
|
+
/** Commands to run locally after successful deployment */
|
|
18
|
+
postDeployLocal?: string[];
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Slack notification configuration
|
|
22
|
+
*/
|
|
23
|
+
export interface SlackNotificationConfig {
|
|
24
|
+
/** Slack webhook URL */
|
|
25
|
+
webhookUrl: string;
|
|
26
|
+
/** Channel override (optional, uses webhook default) */
|
|
27
|
+
channel?: string;
|
|
28
|
+
/** Username override */
|
|
29
|
+
username?: string;
|
|
30
|
+
/** Only notify on failure */
|
|
31
|
+
onlyOnFailure?: boolean;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Discord notification configuration
|
|
35
|
+
*/
|
|
36
|
+
export interface DiscordNotificationConfig {
|
|
37
|
+
/** Discord webhook URL */
|
|
38
|
+
webhookUrl: string;
|
|
39
|
+
/** Username override */
|
|
40
|
+
username?: string;
|
|
41
|
+
/** Only notify on failure */
|
|
42
|
+
onlyOnFailure?: boolean;
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Generic webhook notification configuration
|
|
46
|
+
*/
|
|
47
|
+
export interface WebhookNotificationConfig {
|
|
48
|
+
/** Webhook URL */
|
|
49
|
+
url: string;
|
|
50
|
+
/** HTTP method (default: POST) */
|
|
51
|
+
method?: 'POST' | 'PUT';
|
|
52
|
+
/** Additional headers */
|
|
53
|
+
headers?: Record<string, string>;
|
|
54
|
+
/** Only notify on failure */
|
|
55
|
+
onlyOnFailure?: boolean;
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Notification configuration
|
|
59
|
+
*/
|
|
60
|
+
export interface NotificationsConfig {
|
|
61
|
+
/** Slack notifications */
|
|
62
|
+
slack?: SlackNotificationConfig;
|
|
63
|
+
/** Discord notifications */
|
|
64
|
+
discord?: DiscordNotificationConfig;
|
|
65
|
+
/** Generic webhook */
|
|
66
|
+
webhook?: WebhookNotificationConfig;
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* Deployment result for notifications
|
|
70
|
+
*/
|
|
71
|
+
export interface DeploymentResult {
|
|
72
|
+
service: string;
|
|
73
|
+
environment?: string;
|
|
74
|
+
servers: string[];
|
|
75
|
+
success: boolean;
|
|
76
|
+
message?: string;
|
|
77
|
+
timestamp: string;
|
|
78
|
+
duration?: number;
|
|
79
|
+
commitHash?: string;
|
|
80
|
+
commitMessage?: string;
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Server configuration for deployment target
|
|
84
|
+
*/
|
|
85
|
+
export interface ServerConfig {
|
|
86
|
+
/** SSH host (user@hostname) */
|
|
87
|
+
host: string;
|
|
88
|
+
/** Additional SSH options (e.g., "-p 6771 -4") */
|
|
89
|
+
sshOptions?: string;
|
|
90
|
+
/** Where to install on server (target directory) */
|
|
91
|
+
targetDir: string;
|
|
92
|
+
/** Path to bare git repo on server */
|
|
93
|
+
bareRepo: string;
|
|
94
|
+
/** Unix group for shared access (created if not exists) */
|
|
95
|
+
group?: string;
|
|
96
|
+
/** Server-specific name/label (optional, for display) */
|
|
97
|
+
name?: string;
|
|
98
|
+
}
|
|
9
99
|
/**
|
|
10
100
|
* Service configuration for git-deploy
|
|
11
101
|
*
|
|
@@ -30,23 +120,22 @@ export interface ServiceConfig {
|
|
|
30
120
|
pm2Home?: string;
|
|
31
121
|
/** User to run PM2 commands as (via sudo -u) */
|
|
32
122
|
pm2User?: string;
|
|
123
|
+
/** GPDD: Number of workers (default: CPU count) */
|
|
124
|
+
gpddWorkers?: number;
|
|
125
|
+
/** GPDD: App entry point (default: dist/index.js) */
|
|
126
|
+
gpddEntryPoint?: string;
|
|
33
127
|
/** Environment type (production, staging, development) */
|
|
34
128
|
environment?: EnvironmentType;
|
|
35
129
|
/** Environment variables to write to .env file on server */
|
|
36
130
|
env?: Record<string, string | number | boolean>;
|
|
37
|
-
/**
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
/** Path to bare git repo on server */
|
|
46
|
-
bareRepo: string;
|
|
47
|
-
/** Unix group for shared access (created if not exists) */
|
|
48
|
-
group?: string;
|
|
49
|
-
};
|
|
131
|
+
/** Deployment hooks (pre-deploy, post-deploy scripts) */
|
|
132
|
+
hooks?: HooksConfig;
|
|
133
|
+
/** Notification settings */
|
|
134
|
+
notifications?: NotificationsConfig;
|
|
135
|
+
/** Server-side configuration (single server) */
|
|
136
|
+
server?: ServerConfig;
|
|
137
|
+
/** Multiple servers for parallel deployment */
|
|
138
|
+
servers?: ServerConfig[];
|
|
50
139
|
/** @deprecated Use sourceDir instead */
|
|
51
140
|
packages?: string[];
|
|
52
141
|
/** @deprecated Use sourceDir instead */
|
|
@@ -64,6 +153,15 @@ export interface DeployConfig {
|
|
|
64
153
|
* Default artifacts to copy if not specified
|
|
65
154
|
*/
|
|
66
155
|
export declare const DEFAULT_ARTIFACTS: string[];
|
|
156
|
+
/**
|
|
157
|
+
* Get all servers from a service config
|
|
158
|
+
* Handles both single 'server' and multiple 'servers' config
|
|
159
|
+
*/
|
|
160
|
+
export declare function getServers(config: ServiceConfig): ServerConfig[];
|
|
161
|
+
/**
|
|
162
|
+
* Get the primary server (first one) from config
|
|
163
|
+
*/
|
|
164
|
+
export declare function getPrimaryServer(config: ServiceConfig): ServerConfig;
|
|
67
165
|
/**
|
|
68
166
|
* Parse SSH options to extract port
|
|
69
167
|
* @param sshOptions e.g. "-p 6771 -4"
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/config/types.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,MAAM,kBAAkB,GAAG,KAAK,GAAG,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/config/types.ts"],"names":[],"mappings":"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"}
|
package/dist/config/types.js
CHANGED
|
@@ -6,6 +6,26 @@ export const DEFAULT_ARTIFACTS = [
|
|
|
6
6
|
'package.json',
|
|
7
7
|
'ecosystem.config.cjs'
|
|
8
8
|
];
|
|
9
|
+
/**
|
|
10
|
+
* Get all servers from a service config
|
|
11
|
+
* Handles both single 'server' and multiple 'servers' config
|
|
12
|
+
*/
|
|
13
|
+
export function getServers(config) {
|
|
14
|
+
if (config.servers && config.servers.length > 0) {
|
|
15
|
+
return config.servers;
|
|
16
|
+
}
|
|
17
|
+
if (config.server) {
|
|
18
|
+
return [config.server];
|
|
19
|
+
}
|
|
20
|
+
throw new Error('No server configuration found. Specify either "server" or "servers" in config.');
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Get the primary server (first one) from config
|
|
24
|
+
*/
|
|
25
|
+
export function getPrimaryServer(config) {
|
|
26
|
+
const servers = getServers(config);
|
|
27
|
+
return servers[0];
|
|
28
|
+
}
|
|
9
29
|
/**
|
|
10
30
|
* Parse SSH options to extract port
|
|
11
31
|
* @param sshOptions e.g. "-p 6771 -4"
|
package/dist/config/types.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/config/types.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/config/types.ts"],"names":[],"mappings":"AA0LA;;GAEG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAAG;IAC/B,MAAM;IACN,cAAc;IACd,sBAAsB;CACvB,CAAC;AAEF;;;GAGG;AACH,MAAM,UAAU,UAAU,CAAC,MAAqB;IAC9C,IAAI,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAChD,OAAO,MAAM,CAAC,OAAO,CAAC;IACxB,CAAC;IACD,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;QAClB,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IACzB,CAAC;IACD,MAAM,IAAI,KAAK,CAAC,gFAAgF,CAAC,CAAC;AACpG,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,gBAAgB,CAAC,MAAqB;IACpD,MAAM,OAAO,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC;IACnC,OAAO,OAAO,CAAC,CAAC,CAAC,CAAC;AACpB,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,YAAY,CAAC,UAAmB;IAC9C,IAAI,CAAC,UAAU;QAAE,OAAO,SAAS,CAAC;IAClC,MAAM,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;IAC7C,OAAO,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;AACpD,CAAC;AAED;;;;;;GAMG;AACH,MAAM,UAAU,WAAW,CAAC,IAAY,EAAE,QAAgB,EAAE,IAAa;IACvE,IAAI,IAAI,EAAE,CAAC;QACT,OAAO,SAAS,IAAI,IAAI,IAAI,GAAG,QAAQ,EAAE,CAAC;IAC5C,CAAC;IACD,OAAO,SAAS,IAAI,GAAG,QAAQ,EAAE,CAAC;AACpC,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -7,11 +7,14 @@ import { initCommand } from './commands/init.js';
|
|
|
7
7
|
import { statusCommand } from './commands/status.js';
|
|
8
8
|
import { logsCommand } from './commands/logs.js';
|
|
9
9
|
import { installCommand } from './commands/install.js';
|
|
10
|
+
import { rollbackCommand } from './commands/rollback.js';
|
|
11
|
+
import { configCommand } from './commands/config.js';
|
|
12
|
+
import { daemonCommand } from './commands/daemon.js';
|
|
10
13
|
const program = new Command();
|
|
11
14
|
program
|
|
12
15
|
.name('gpd')
|
|
13
16
|
.description('Git Push Deploy - CLI for git-based deployments with PM2 support')
|
|
14
|
-
.version('0.
|
|
17
|
+
.version('0.4.0');
|
|
15
18
|
// Development commands (run on dev machine)
|
|
16
19
|
program
|
|
17
20
|
.command('stage <service>')
|
|
@@ -27,7 +30,23 @@ program
|
|
|
27
30
|
.description('Stage and push to server (hook handles install)')
|
|
28
31
|
.option('-m, --message <message>', 'Commit message')
|
|
29
32
|
.option('--skip-push', 'Only stage, do not push')
|
|
30
|
-
.
|
|
33
|
+
.option('--dry-run', 'Preview what would happen without making changes')
|
|
34
|
+
.action((service, options) => deployCommand(service, {
|
|
35
|
+
message: options.message,
|
|
36
|
+
skipPush: options.skipPush,
|
|
37
|
+
dryRun: options.dryRun
|
|
38
|
+
}));
|
|
39
|
+
program
|
|
40
|
+
.command('rollback <service> [target]')
|
|
41
|
+
.description('Rollback to a previous deployment version')
|
|
42
|
+
.option('-s, --steps <n>', 'Go back N commits', parseInt)
|
|
43
|
+
.option('-l, --list', 'List available versions without rollback')
|
|
44
|
+
.option('-f, --force', 'Skip confirmation prompt')
|
|
45
|
+
.action((service, target, options) => rollbackCommand(service, target, {
|
|
46
|
+
steps: options.steps,
|
|
47
|
+
list: options.list,
|
|
48
|
+
force: options.force
|
|
49
|
+
}));
|
|
31
50
|
// Server setup command
|
|
32
51
|
program
|
|
33
52
|
.command('init <service>')
|
|
@@ -50,5 +69,15 @@ program
|
|
|
50
69
|
.option('-n, --lines <lines>', 'Number of lines to show', '50')
|
|
51
70
|
.option('-f, --follow', 'Follow log output')
|
|
52
71
|
.action(logsCommand);
|
|
72
|
+
program
|
|
73
|
+
.command('config')
|
|
74
|
+
.description('Interactive configuration wizard for .git-deploy.json')
|
|
75
|
+
.option('-e, --edit <service>', 'Edit existing service')
|
|
76
|
+
.option('-l, --list', 'List configured services')
|
|
77
|
+
.action((options) => configCommand({ edit: options.edit, list: options.list }));
|
|
78
|
+
program
|
|
79
|
+
.command('daemon <service> <action>')
|
|
80
|
+
.description('Control gpdd daemon on server (status|reload|stop|start)')
|
|
81
|
+
.action((service, action) => daemonCommand(service, action));
|
|
53
82
|
program.parse();
|
|
54
83
|
//# sourceMappingURL=index.js.map
|