dockup-cli 1.0.2 → 1.2.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.
@@ -1,240 +1,230 @@
1
1
  "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- var __importDefault = (this && this.__importDefault) || function (mod) {
36
- return (mod && mod.__esModule) ? mod : { "default": mod };
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
37
11
  };
38
- Object.defineProperty(exports, "__esModule", { value: true });
39
- exports.workspaceList = workspaceList;
40
- exports.workspaceCreate = workspaceCreate;
41
- exports.workspaceSelect = workspaceSelect;
42
- exports.workspaceRename = workspaceRename;
43
- exports.workspaceDelete = workspaceDelete;
44
- exports.workspaceCurrent = workspaceCurrent;
45
- const chalk_1 = __importDefault(require("chalk"));
46
- const ora_1 = __importDefault(require("ora"));
47
- const readline = __importStar(require("readline"));
48
- const config_1 = require("../lib/config");
49
- const api_1 = require("../lib/api");
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var workspace_exports = {};
30
+ __export(workspace_exports, {
31
+ workspaceCreate: () => workspaceCreate,
32
+ workspaceCurrent: () => workspaceCurrent,
33
+ workspaceDelete: () => workspaceDelete,
34
+ workspaceList: () => workspaceList,
35
+ workspaceRename: () => workspaceRename,
36
+ workspaceSelect: () => workspaceSelect
37
+ });
38
+ module.exports = __toCommonJS(workspace_exports);
39
+ var import_chalk = __toESM(require("chalk"));
40
+ var import_ora = __toESM(require("ora"));
41
+ var readline = __toESM(require("readline"));
42
+ var import_config = require("../lib/config");
43
+ var import_api = require("../lib/api");
50
44
  function question(prompt) {
51
- const rl = readline.createInterface({
52
- input: process.stdin,
53
- output: process.stdout
54
- });
55
- return new Promise((resolve) => {
56
- rl.question(prompt, (answer) => {
57
- rl.close();
58
- resolve(answer);
59
- });
45
+ const rl = readline.createInterface({
46
+ input: process.stdin,
47
+ output: process.stdout
48
+ });
49
+ return new Promise((resolve) => {
50
+ rl.question(prompt, (answer) => {
51
+ rl.close();
52
+ resolve(answer);
60
53
  });
54
+ });
61
55
  }
62
56
  function requireAuth() {
63
- if (!(0, config_1.isLoggedIn)()) {
64
- console.log(chalk_1.default.red('Not logged in. Run `dockup login` first.'));
65
- return false;
66
- }
67
- return true;
57
+ if (!(0, import_config.isLoggedIn)()) {
58
+ console.log(import_chalk.default.red("Not logged in. Run `dockup login` first."));
59
+ return false;
60
+ }
61
+ return true;
68
62
  }
69
63
  async function workspaceList() {
70
- if (!requireAuth())
71
- return;
72
- const spinner = (0, ora_1.default)('Fetching workspaces...').start();
73
- try {
74
- const workspaces = await api_1.api.getWorkspaces();
75
- spinner.stop();
76
- if (workspaces.length === 0) {
77
- console.log(chalk_1.default.yellow('\nNo workspaces found. Create one with `dockup workspace create`'));
78
- return;
79
- }
80
- const currentWs = (0, config_1.getCurrentWorkspace)();
81
- console.log(chalk_1.default.cyan('\n Your Workspaces:\n'));
82
- workspaces.forEach((ws) => {
83
- const isCurrent = currentWs?.id === ws.id;
84
- const marker = isCurrent ? chalk_1.default.green('● ') : ' ';
85
- const name = isCurrent ? chalk_1.default.green(ws.name) : ws.name;
86
- const slug = chalk_1.default.dim(`(${ws.slug})`);
87
- const dbCount = chalk_1.default.dim(`${ws._count?.databases || 0} databases`);
88
- console.log(`${marker}${name} ${slug} - ${dbCount}`);
89
- });
90
- console.log();
91
- if (currentWs) {
92
- console.log(chalk_1.default.dim(`Current workspace: ${currentWs.name}`));
93
- }
94
- else {
95
- console.log(chalk_1.default.dim('No workspace selected. Run `dockup workspace select` to choose one.'));
96
- }
97
- console.log();
98
- }
99
- catch (error) {
100
- spinner.fail(`Failed to fetch workspaces: ${error.message}`);
64
+ if (!requireAuth()) return;
65
+ const spinner = (0, import_ora.default)("Fetching workspaces...").start();
66
+ try {
67
+ const workspaces = await import_api.api.getWorkspaces();
68
+ spinner.stop();
69
+ if (workspaces.length === 0) {
70
+ console.log(import_chalk.default.yellow("\nNo workspaces found. Create one with `dockup workspace create`"));
71
+ return;
72
+ }
73
+ const currentWs = (0, import_config.getCurrentWorkspace)();
74
+ console.log(import_chalk.default.cyan("\n Your Workspaces:\n"));
75
+ workspaces.forEach((ws) => {
76
+ const isCurrent = currentWs?.id === ws.id;
77
+ const marker = isCurrent ? import_chalk.default.green("\u25CF ") : " ";
78
+ const name = isCurrent ? import_chalk.default.green(ws.name) : ws.name;
79
+ const slug = import_chalk.default.dim(`(${ws.slug})`);
80
+ const dbCount = import_chalk.default.dim(`${ws._count?.databases || 0} databases`);
81
+ console.log(`${marker}${name} ${slug} - ${dbCount}`);
82
+ });
83
+ console.log();
84
+ if (currentWs) {
85
+ console.log(import_chalk.default.dim(`Current workspace: ${currentWs.name}`));
86
+ } else {
87
+ console.log(import_chalk.default.dim("No workspace selected. Run `dockup workspace select` to choose one."));
101
88
  }
89
+ console.log();
90
+ } catch (error) {
91
+ spinner.fail(`Failed to fetch workspaces: ${error.message}`);
92
+ }
102
93
  }
103
94
  async function workspaceCreate(options) {
104
- if (!requireAuth())
105
- return;
106
- let name = options.name;
107
- if (!name) {
108
- name = await question('Workspace name: ');
109
- if (!name || name.trim() === '') {
110
- console.log(chalk_1.default.red('Name is required'));
111
- return;
112
- }
113
- name = name.trim();
114
- }
115
- const spinner = (0, ora_1.default)('Creating workspace...').start();
116
- try {
117
- const workspace = await api_1.api.createWorkspace(name);
118
- spinner.succeed(`Workspace "${chalk_1.default.green(workspace.name)}" created successfully`);
119
- // Auto-select the new workspace
120
- (0, config_1.setCurrentWorkspace)({
121
- id: workspace.id,
122
- name: workspace.name,
123
- slug: workspace.slug
124
- });
125
- console.log(chalk_1.default.dim(`Workspace selected: ${workspace.name}`));
126
- }
127
- catch (error) {
128
- spinner.fail(`Failed to create workspace: ${error.message}`);
129
- }
95
+ if (!requireAuth()) return;
96
+ let name = options.name;
97
+ if (!name) {
98
+ name = await question("Workspace name: ");
99
+ if (!name || name.trim() === "") {
100
+ console.log(import_chalk.default.red("Name is required"));
101
+ return;
102
+ }
103
+ name = name.trim();
104
+ }
105
+ const spinner = (0, import_ora.default)("Creating workspace...").start();
106
+ try {
107
+ const workspace = await import_api.api.createWorkspace(name);
108
+ spinner.succeed(`Workspace "${import_chalk.default.green(workspace.name)}" created successfully`);
109
+ (0, import_config.setCurrentWorkspace)({
110
+ id: workspace.id,
111
+ name: workspace.name,
112
+ slug: workspace.slug
113
+ });
114
+ console.log(import_chalk.default.dim(`Workspace selected: ${workspace.name}`));
115
+ } catch (error) {
116
+ spinner.fail(`Failed to create workspace: ${error.message}`);
117
+ }
130
118
  }
131
119
  async function workspaceSelect() {
132
- if (!requireAuth())
133
- return;
134
- const spinner = (0, ora_1.default)('Fetching workspaces...').start();
135
- try {
136
- const workspaces = await api_1.api.getWorkspaces();
137
- spinner.stop();
138
- if (workspaces.length === 0) {
139
- console.log(chalk_1.default.yellow('\nNo workspaces found. Create one with `dockup workspace create`'));
140
- return;
141
- }
142
- const currentWs = (0, config_1.getCurrentWorkspace)();
143
- console.log(chalk_1.default.cyan('\n Select a workspace:\n'));
144
- workspaces.forEach((ws, index) => {
145
- const isCurrent = currentWs?.id === ws.id;
146
- const marker = isCurrent ? chalk_1.default.green('●') : ' ';
147
- console.log(` ${marker} ${index + 1}. ${ws.name} ${chalk_1.default.dim(`(${ws.slug})`)}`);
148
- });
149
- console.log();
150
- const answer = await question('Enter number: ');
151
- const index = parseInt(answer) - 1;
152
- if (isNaN(index) || index < 0 || index >= workspaces.length) {
153
- console.log(chalk_1.default.red('Invalid selection'));
154
- return;
155
- }
156
- const selected = workspaces[index];
157
- (0, config_1.setCurrentWorkspace)({
158
- id: selected.id,
159
- name: selected.name,
160
- slug: selected.slug
161
- });
162
- console.log(chalk_1.default.green(`✓ Workspace "${selected.name}" selected`));
163
- }
164
- catch (error) {
165
- spinner.fail(`Failed to select workspace: ${error.message}`);
166
- }
120
+ if (!requireAuth()) return;
121
+ const spinner = (0, import_ora.default)("Fetching workspaces...").start();
122
+ try {
123
+ const workspaces = await import_api.api.getWorkspaces();
124
+ spinner.stop();
125
+ if (workspaces.length === 0) {
126
+ console.log(import_chalk.default.yellow("\nNo workspaces found. Create one with `dockup workspace create`"));
127
+ return;
128
+ }
129
+ const currentWs = (0, import_config.getCurrentWorkspace)();
130
+ console.log(import_chalk.default.cyan("\n Select a workspace:\n"));
131
+ workspaces.forEach((ws, index2) => {
132
+ const isCurrent = currentWs?.id === ws.id;
133
+ const marker = isCurrent ? import_chalk.default.green("\u25CF") : " ";
134
+ console.log(` ${marker} ${index2 + 1}. ${ws.name} ${import_chalk.default.dim(`(${ws.slug})`)}`);
135
+ });
136
+ console.log();
137
+ const answer = await question("Enter number: ");
138
+ const index = parseInt(answer) - 1;
139
+ if (isNaN(index) || index < 0 || index >= workspaces.length) {
140
+ console.log(import_chalk.default.red("Invalid selection"));
141
+ return;
142
+ }
143
+ const selected = workspaces[index];
144
+ (0, import_config.setCurrentWorkspace)({
145
+ id: selected.id,
146
+ name: selected.name,
147
+ slug: selected.slug
148
+ });
149
+ console.log(import_chalk.default.green(`\u2713 Workspace "${selected.name}" selected`));
150
+ } catch (error) {
151
+ spinner.fail(`Failed to select workspace: ${error.message}`);
152
+ }
167
153
  }
168
154
  async function workspaceRename(options) {
169
- if (!requireAuth())
170
- return;
171
- const currentWs = (0, config_1.getCurrentWorkspace)();
172
- if (!currentWs) {
173
- console.log(chalk_1.default.yellow('No workspace selected. Run `dockup workspace select` first.'));
174
- return;
175
- }
176
- let newName = options.name;
177
- if (!newName) {
178
- newName = await question(`New name for "${currentWs.name}" (enter to keep): `);
179
- if (!newName || newName.trim() === '') {
180
- newName = currentWs.name;
181
- }
182
- else {
183
- newName = newName.trim();
184
- }
185
- }
186
- const spinner = (0, ora_1.default)('Renaming workspace...').start();
187
- try {
188
- const workspace = await api_1.api.renameWorkspace(currentWs.id, newName);
189
- spinner.succeed(`Workspace renamed to "${chalk_1.default.green(workspace.name)}"`);
190
- // Update local config
191
- (0, config_1.setCurrentWorkspace)({
192
- id: workspace.id,
193
- name: workspace.name,
194
- slug: workspace.slug
195
- });
196
- }
197
- catch (error) {
198
- spinner.fail(`Failed to rename workspace: ${error.message}`);
199
- }
155
+ if (!requireAuth()) return;
156
+ const currentWs = (0, import_config.getCurrentWorkspace)();
157
+ if (!currentWs) {
158
+ console.log(import_chalk.default.yellow("No workspace selected. Run `dockup workspace select` first."));
159
+ return;
160
+ }
161
+ let newName = options.name;
162
+ if (!newName) {
163
+ newName = await question(`New name for "${currentWs.name}" (enter to keep): `);
164
+ if (!newName || newName.trim() === "") {
165
+ newName = currentWs.name;
166
+ } else {
167
+ newName = newName.trim();
168
+ }
169
+ }
170
+ const spinner = (0, import_ora.default)("Renaming workspace...").start();
171
+ try {
172
+ const workspace = await import_api.api.renameWorkspace(currentWs.id, newName);
173
+ spinner.succeed(`Workspace renamed to "${import_chalk.default.green(workspace.name)}"`);
174
+ (0, import_config.setCurrentWorkspace)({
175
+ id: workspace.id,
176
+ name: workspace.name,
177
+ slug: workspace.slug
178
+ });
179
+ } catch (error) {
180
+ spinner.fail(`Failed to rename workspace: ${error.message}`);
181
+ }
200
182
  }
201
183
  async function workspaceDelete() {
202
- if (!requireAuth())
203
- return;
204
- const currentWs = (0, config_1.getCurrentWorkspace)();
205
- if (!currentWs) {
206
- console.log(chalk_1.default.yellow('No workspace selected. Run `dockup workspace select` first.'));
207
- return;
208
- }
209
- console.log(chalk_1.default.red(`\n WARNING: This will delete "${currentWs.name}" and all its databases!\n`));
210
- const answer = await question('Type workspace name to confirm: ');
211
- if (answer !== currentWs.name) {
212
- console.log(chalk_1.default.dim('Cancelled'));
213
- return;
214
- }
215
- const spinner = (0, ora_1.default)('Deleting workspace...').start();
216
- try {
217
- await api_1.api.deleteWorkspace(currentWs.id);
218
- spinner.succeed(`Workspace "${currentWs.name}" deleted`);
219
- (0, config_1.clearCurrentWorkspace)();
220
- console.log(chalk_1.default.dim('Run `dockup workspace select` to select another workspace.'));
221
- }
222
- catch (error) {
223
- spinner.fail(`Failed to delete workspace: ${error.message}`);
224
- }
184
+ if (!requireAuth()) return;
185
+ const currentWs = (0, import_config.getCurrentWorkspace)();
186
+ if (!currentWs) {
187
+ console.log(import_chalk.default.yellow("No workspace selected. Run `dockup workspace select` first."));
188
+ return;
189
+ }
190
+ console.log(import_chalk.default.red(`
191
+ WARNING: This will delete "${currentWs.name}" and all its databases!
192
+ `));
193
+ const answer = await question("Type workspace name to confirm: ");
194
+ if (answer !== currentWs.name) {
195
+ console.log(import_chalk.default.dim("Cancelled"));
196
+ return;
197
+ }
198
+ const spinner = (0, import_ora.default)("Deleting workspace...").start();
199
+ try {
200
+ await import_api.api.deleteWorkspace(currentWs.id);
201
+ spinner.succeed(`Workspace "${currentWs.name}" deleted`);
202
+ (0, import_config.clearCurrentWorkspace)();
203
+ console.log(import_chalk.default.dim("Run `dockup workspace select` to select another workspace."));
204
+ } catch (error) {
205
+ spinner.fail(`Failed to delete workspace: ${error.message}`);
206
+ }
225
207
  }
226
208
  async function workspaceCurrent() {
227
- if (!requireAuth())
228
- return;
229
- const currentWs = (0, config_1.getCurrentWorkspace)();
230
- if (!currentWs) {
231
- console.log(chalk_1.default.yellow('No workspace selected.'));
232
- console.log(chalk_1.default.dim('Run `dockup workspace select` to choose one.'));
233
- return;
234
- }
235
- console.log(chalk_1.default.cyan('\n Current Workspace:\n'));
236
- console.log(` ${chalk_1.default.dim('Name:')} ${currentWs.name}`);
237
- console.log(` ${chalk_1.default.dim('Slug:')} ${currentWs.slug}`);
238
- console.log(` ${chalk_1.default.dim('ID:')} ${currentWs.id}`);
239
- console.log();
209
+ if (!requireAuth()) return;
210
+ const currentWs = (0, import_config.getCurrentWorkspace)();
211
+ if (!currentWs) {
212
+ console.log(import_chalk.default.yellow("No workspace selected."));
213
+ console.log(import_chalk.default.dim("Run `dockup workspace select` to choose one."));
214
+ return;
215
+ }
216
+ console.log(import_chalk.default.cyan("\n Current Workspace:\n"));
217
+ console.log(` ${import_chalk.default.dim("Name:")} ${currentWs.name}`);
218
+ console.log(` ${import_chalk.default.dim("Slug:")} ${currentWs.slug}`);
219
+ console.log(` ${import_chalk.default.dim("ID:")} ${currentWs.id}`);
220
+ console.log();
240
221
  }
222
+ // Annotate the CommonJS export names for ESM import in node:
223
+ 0 && (module.exports = {
224
+ workspaceCreate,
225
+ workspaceCurrent,
226
+ workspaceDelete,
227
+ workspaceList,
228
+ workspaceRename,
229
+ workspaceSelect
230
+ });