@brainfish-ai/devdoc 0.1.30 → 0.1.31
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/ai-agents/CLAUDE.md +1 -1
- package/dist/cli/commands/deploy.js +65 -1
- package/dist/cli/commands/domain.d.ts +21 -0
- package/dist/cli/commands/domain.js +386 -0
- package/dist/cli/index.js +30 -1
- package/package.json +1 -1
- package/renderer/app/api/domains/add/route.ts +132 -0
- package/renderer/app/api/domains/lookup/route.ts +43 -0
- package/renderer/app/api/domains/remove/route.ts +100 -0
- package/renderer/app/api/domains/status/route.ts +158 -0
- package/renderer/app/api/domains/verify/route.ts +181 -0
- package/renderer/app/api/local-assets/[...path]/route.ts +122 -0
- package/renderer/app/globals.css +9 -0
- package/renderer/app/layout.tsx +8 -1
- package/renderer/components/docs/mdx/cards.tsx +35 -7
- package/renderer/components/docs/navigation/sidebar.tsx +5 -5
- package/renderer/components/docs-header.tsx +9 -5
- package/renderer/components/docs-viewer/sidebar/right-sidebar.tsx +5 -5
- package/renderer/lib/docs/config/domain-schema.ts +260 -0
- package/renderer/lib/docs/config/index.ts +14 -0
- package/renderer/lib/storage/blob.ts +242 -4
- package/renderer/public/file.svg +0 -1
- package/renderer/public/globe.svg +0 -1
- package/renderer/public/logo.svg +0 -9
- package/renderer/public/window.svg +0 -1
|
@@ -0,0 +1,386 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.domainAdd = domainAdd;
|
|
7
|
+
exports.domainStatus = domainStatus;
|
|
8
|
+
exports.domainVerify = domainVerify;
|
|
9
|
+
exports.domainRemove = domainRemove;
|
|
10
|
+
const path_1 = __importDefault(require("path"));
|
|
11
|
+
const fs_extra_1 = __importDefault(require("fs-extra"));
|
|
12
|
+
const logger_1 = require("../../utils/logger");
|
|
13
|
+
const constants_1 = require("../../constants");
|
|
14
|
+
/**
|
|
15
|
+
* Load .devdoc.json and get API key
|
|
16
|
+
*/
|
|
17
|
+
function loadDevDocConfig(projectRoot) {
|
|
18
|
+
const configPath = path_1.default.join(projectRoot, '.devdoc.json');
|
|
19
|
+
if (!fs_extra_1.default.existsSync(configPath)) {
|
|
20
|
+
return null;
|
|
21
|
+
}
|
|
22
|
+
try {
|
|
23
|
+
return fs_extra_1.default.readJsonSync(configPath);
|
|
24
|
+
}
|
|
25
|
+
catch {
|
|
26
|
+
return null;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Get API key from options, env, or config
|
|
31
|
+
*/
|
|
32
|
+
function getApiKey(options, config) {
|
|
33
|
+
return options.apiKey || process.env.DEVDOC_API_KEY || config?.apiKey || null;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Validate domain format
|
|
37
|
+
*/
|
|
38
|
+
function isValidDomainFormat(domain) {
|
|
39
|
+
if (!domain) {
|
|
40
|
+
return { valid: false, error: 'Domain is required' };
|
|
41
|
+
}
|
|
42
|
+
if (domain.length < 4) {
|
|
43
|
+
return { valid: false, error: 'Domain must be at least 4 characters' };
|
|
44
|
+
}
|
|
45
|
+
// Basic domain format check
|
|
46
|
+
const domainRegex = /^(?!-)[a-zA-Z0-9-]+(?:\.[a-zA-Z0-9-]+)*\.[a-zA-Z]{2,}$/;
|
|
47
|
+
if (!domainRegex.test(domain)) {
|
|
48
|
+
return { valid: false, error: 'Invalid domain format. Example: docs.example.com' };
|
|
49
|
+
}
|
|
50
|
+
// Check for reserved domains
|
|
51
|
+
const reserved = ['devdoc.sh', 'devdoc.io', 'devdoc.com'];
|
|
52
|
+
if (reserved.some(r => domain === r || domain.endsWith(`.${r}`))) {
|
|
53
|
+
return { valid: false, error: 'Cannot use a reserved DevDoc domain' };
|
|
54
|
+
}
|
|
55
|
+
return { valid: true };
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Normalize domain (lowercase, remove protocol/path)
|
|
59
|
+
*/
|
|
60
|
+
function normalizeDomain(domain) {
|
|
61
|
+
let normalized = domain.toLowerCase().trim();
|
|
62
|
+
normalized = normalized.replace(/^https?:\/\//, '');
|
|
63
|
+
normalized = normalized.split('/')[0];
|
|
64
|
+
normalized = normalized.split(':')[0];
|
|
65
|
+
return normalized;
|
|
66
|
+
}
|
|
67
|
+
// =============================================================================
|
|
68
|
+
// Domain Add Command
|
|
69
|
+
// =============================================================================
|
|
70
|
+
/**
|
|
71
|
+
* Add a custom domain to the project
|
|
72
|
+
*/
|
|
73
|
+
async function domainAdd(customDomain, options) {
|
|
74
|
+
const projectRoot = process.cwd();
|
|
75
|
+
const apiUrl = options.url || process.env.DEVDOC_API_URL || constants_1.DEFAULT_API_URL;
|
|
76
|
+
logger_1.logger.info('Adding custom domain...\n');
|
|
77
|
+
// Load config
|
|
78
|
+
const config = loadDevDocConfig(projectRoot);
|
|
79
|
+
if (!config) {
|
|
80
|
+
logger_1.logger.error('.devdoc.json not found. Deploy your project first with "devdoc deploy"');
|
|
81
|
+
process.exit(1);
|
|
82
|
+
}
|
|
83
|
+
// Get API key
|
|
84
|
+
const apiKey = getApiKey(options, config);
|
|
85
|
+
if (!apiKey) {
|
|
86
|
+
logger_1.logger.error('API key not found. Deploy your project first or provide via --api-key');
|
|
87
|
+
process.exit(1);
|
|
88
|
+
}
|
|
89
|
+
// Normalize and validate domain
|
|
90
|
+
const domain = normalizeDomain(customDomain);
|
|
91
|
+
const validation = isValidDomainFormat(domain);
|
|
92
|
+
if (!validation.valid) {
|
|
93
|
+
logger_1.logger.error(validation.error);
|
|
94
|
+
process.exit(1);
|
|
95
|
+
}
|
|
96
|
+
logger_1.logger.info(`Domain: ${domain}`);
|
|
97
|
+
console.log('');
|
|
98
|
+
try {
|
|
99
|
+
const response = await fetch(`${apiUrl}/api/domains/add`, {
|
|
100
|
+
method: 'POST',
|
|
101
|
+
headers: {
|
|
102
|
+
'Content-Type': 'application/json',
|
|
103
|
+
'Authorization': `Bearer ${apiKey}`,
|
|
104
|
+
},
|
|
105
|
+
body: JSON.stringify({ customDomain: domain }),
|
|
106
|
+
});
|
|
107
|
+
const result = await response.json();
|
|
108
|
+
if (!response.ok || !result.success) {
|
|
109
|
+
logger_1.logger.error(result.error || 'Failed to add domain');
|
|
110
|
+
process.exit(1);
|
|
111
|
+
}
|
|
112
|
+
logger_1.logger.success(`✓ Domain ${domain} added!`);
|
|
113
|
+
console.log('');
|
|
114
|
+
console.log(' Next, add these DNS records to your domain provider:');
|
|
115
|
+
console.log('');
|
|
116
|
+
console.log(' 1. CNAME Record:');
|
|
117
|
+
console.log(` Name: ${result.verification.cname.name}`);
|
|
118
|
+
console.log(` Value: ${result.verification.cname.value}`);
|
|
119
|
+
console.log('');
|
|
120
|
+
console.log(' 2. TXT Record (for verification):');
|
|
121
|
+
console.log(` Name: ${result.verification.txt.name}`);
|
|
122
|
+
console.log(` Value: ${result.verification.txt.value}`);
|
|
123
|
+
console.log('');
|
|
124
|
+
logger_1.logger.info('After adding DNS records, run:');
|
|
125
|
+
console.log(' devdoc domain verify');
|
|
126
|
+
console.log('');
|
|
127
|
+
}
|
|
128
|
+
catch (error) {
|
|
129
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
130
|
+
logger_1.logger.error(`Failed to add domain: ${message}`);
|
|
131
|
+
process.exit(1);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
// =============================================================================
|
|
135
|
+
// Domain Status Command
|
|
136
|
+
// =============================================================================
|
|
137
|
+
/**
|
|
138
|
+
* Check status of custom domain
|
|
139
|
+
*/
|
|
140
|
+
async function domainStatus(options) {
|
|
141
|
+
const projectRoot = process.cwd();
|
|
142
|
+
const apiUrl = options.url || process.env.DEVDOC_API_URL || constants_1.DEFAULT_API_URL;
|
|
143
|
+
// Load config
|
|
144
|
+
const config = loadDevDocConfig(projectRoot);
|
|
145
|
+
if (!config) {
|
|
146
|
+
logger_1.logger.error('.devdoc.json not found. Deploy your project first with "devdoc deploy"');
|
|
147
|
+
process.exit(1);
|
|
148
|
+
}
|
|
149
|
+
// Get API key
|
|
150
|
+
const apiKey = getApiKey(options, config);
|
|
151
|
+
if (!apiKey) {
|
|
152
|
+
logger_1.logger.error('API key not found. Deploy your project first or provide via --api-key');
|
|
153
|
+
process.exit(1);
|
|
154
|
+
}
|
|
155
|
+
try {
|
|
156
|
+
const response = await fetch(`${apiUrl}/api/domains/status`, {
|
|
157
|
+
method: 'GET',
|
|
158
|
+
headers: {
|
|
159
|
+
'Authorization': `Bearer ${apiKey}`,
|
|
160
|
+
},
|
|
161
|
+
});
|
|
162
|
+
const result = await response.json();
|
|
163
|
+
if (!response.ok) {
|
|
164
|
+
logger_1.logger.error(result.error || 'Failed to get domain status');
|
|
165
|
+
process.exit(1);
|
|
166
|
+
}
|
|
167
|
+
console.log('');
|
|
168
|
+
console.log(' Custom Domain Status');
|
|
169
|
+
console.log(' --------------------');
|
|
170
|
+
if (!result.hasCustomDomain) {
|
|
171
|
+
console.log('');
|
|
172
|
+
console.log(' No custom domain configured.');
|
|
173
|
+
console.log('');
|
|
174
|
+
console.log(' Your docs are available at:');
|
|
175
|
+
console.log(` ${logger_1.logger.cyan(result.projectUrl)}`);
|
|
176
|
+
console.log('');
|
|
177
|
+
logger_1.logger.info('To add a custom domain, run:');
|
|
178
|
+
console.log(' devdoc domain add docs.yourdomain.com');
|
|
179
|
+
console.log('');
|
|
180
|
+
return;
|
|
181
|
+
}
|
|
182
|
+
console.log('');
|
|
183
|
+
console.log(` Domain: ${result.domain}`);
|
|
184
|
+
console.log(` Status: ${getStatusDisplay(result.status || 'unknown')}`);
|
|
185
|
+
console.log('');
|
|
186
|
+
if (result.status === 'active') {
|
|
187
|
+
console.log(' Your docs are available at:');
|
|
188
|
+
console.log(` ${logger_1.logger.cyan(result.customUrl || `https://${result.domain}`)}`);
|
|
189
|
+
console.log('');
|
|
190
|
+
console.log(' Also accessible at:');
|
|
191
|
+
console.log(` ${result.projectUrl}`);
|
|
192
|
+
}
|
|
193
|
+
else if (result.status === 'pending' && result.dnsRecords) {
|
|
194
|
+
console.log(' Add these DNS records to your domain:');
|
|
195
|
+
console.log('');
|
|
196
|
+
console.log(' CNAME Record:');
|
|
197
|
+
console.log(` Name: ${result.dnsRecords.cname.name}`);
|
|
198
|
+
console.log(` Value: ${result.dnsRecords.cname.value}`);
|
|
199
|
+
console.log('');
|
|
200
|
+
console.log(' TXT Record:');
|
|
201
|
+
console.log(` Name: ${result.dnsRecords.txt.name}`);
|
|
202
|
+
console.log(` Value: ${result.dnsRecords.txt.value}`);
|
|
203
|
+
console.log('');
|
|
204
|
+
logger_1.logger.info('After adding DNS records, run: devdoc domain verify');
|
|
205
|
+
}
|
|
206
|
+
else if (result.message) {
|
|
207
|
+
console.log(` ${result.message}`);
|
|
208
|
+
}
|
|
209
|
+
if (result.nextStep) {
|
|
210
|
+
console.log('');
|
|
211
|
+
logger_1.logger.info(`Next: ${result.nextStep}`);
|
|
212
|
+
}
|
|
213
|
+
console.log('');
|
|
214
|
+
}
|
|
215
|
+
catch (error) {
|
|
216
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
217
|
+
logger_1.logger.error(`Failed to get domain status: ${message}`);
|
|
218
|
+
process.exit(1);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
/**
|
|
222
|
+
* Get display string for status
|
|
223
|
+
*/
|
|
224
|
+
function getStatusDisplay(status) {
|
|
225
|
+
switch (status) {
|
|
226
|
+
case 'pending':
|
|
227
|
+
return logger_1.logger.yellow('⏳ Pending DNS configuration');
|
|
228
|
+
case 'dns_verified':
|
|
229
|
+
return logger_1.logger.cyan('✓ DNS verified, SSL provisioning...');
|
|
230
|
+
case 'ssl_provisioning':
|
|
231
|
+
return logger_1.logger.cyan('🔒 SSL certificate provisioning...');
|
|
232
|
+
case 'active':
|
|
233
|
+
return logger_1.logger.green('✓ Active');
|
|
234
|
+
case 'error':
|
|
235
|
+
return logger_1.logger.red('✗ Error');
|
|
236
|
+
default:
|
|
237
|
+
return status;
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
// =============================================================================
|
|
241
|
+
// Domain Verify Command
|
|
242
|
+
// =============================================================================
|
|
243
|
+
/**
|
|
244
|
+
* Verify DNS configuration for custom domain
|
|
245
|
+
*/
|
|
246
|
+
async function domainVerify(options) {
|
|
247
|
+
const projectRoot = process.cwd();
|
|
248
|
+
const apiUrl = options.url || process.env.DEVDOC_API_URL || constants_1.DEFAULT_API_URL;
|
|
249
|
+
logger_1.logger.info('Verifying DNS configuration...\n');
|
|
250
|
+
// Load config
|
|
251
|
+
const config = loadDevDocConfig(projectRoot);
|
|
252
|
+
if (!config) {
|
|
253
|
+
logger_1.logger.error('.devdoc.json not found. Deploy your project first with "devdoc deploy"');
|
|
254
|
+
process.exit(1);
|
|
255
|
+
}
|
|
256
|
+
// Get API key
|
|
257
|
+
const apiKey = getApiKey(options, config);
|
|
258
|
+
if (!apiKey) {
|
|
259
|
+
logger_1.logger.error('API key not found. Deploy your project first or provide via --api-key');
|
|
260
|
+
process.exit(1);
|
|
261
|
+
}
|
|
262
|
+
try {
|
|
263
|
+
const response = await fetch(`${apiUrl}/api/domains/verify`, {
|
|
264
|
+
method: 'POST',
|
|
265
|
+
headers: {
|
|
266
|
+
'Content-Type': 'application/json',
|
|
267
|
+
'Authorization': `Bearer ${apiKey}`,
|
|
268
|
+
},
|
|
269
|
+
body: JSON.stringify({}),
|
|
270
|
+
});
|
|
271
|
+
const result = await response.json();
|
|
272
|
+
if (!response.ok) {
|
|
273
|
+
logger_1.logger.error(result.error || 'Failed to verify domain');
|
|
274
|
+
process.exit(1);
|
|
275
|
+
}
|
|
276
|
+
console.log('');
|
|
277
|
+
console.log(' DNS Verification Results');
|
|
278
|
+
console.log(' ------------------------');
|
|
279
|
+
console.log('');
|
|
280
|
+
console.log(` Domain: ${result.domain}`);
|
|
281
|
+
console.log('');
|
|
282
|
+
// CNAME check
|
|
283
|
+
console.log(' CNAME Record:');
|
|
284
|
+
if (result.checks.cname.valid) {
|
|
285
|
+
console.log(` ${logger_1.logger.green('✓')} Found: ${result.checks.cname.value}`);
|
|
286
|
+
}
|
|
287
|
+
else if (result.checks.cname.found) {
|
|
288
|
+
console.log(` ${logger_1.logger.yellow('!')} Found but incorrect: ${result.checks.cname.value}`);
|
|
289
|
+
console.log(` Expected: ${result.checks.cname.expected}`);
|
|
290
|
+
}
|
|
291
|
+
else {
|
|
292
|
+
console.log(` ${logger_1.logger.red('✗')} Not found`);
|
|
293
|
+
console.log(` Expected: ${result.checks.cname.expected}`);
|
|
294
|
+
}
|
|
295
|
+
// TXT check
|
|
296
|
+
console.log('');
|
|
297
|
+
console.log(' TXT Verification Record:');
|
|
298
|
+
if (result.checks.txt.verified) {
|
|
299
|
+
console.log(` ${logger_1.logger.green('✓')} Verified`);
|
|
300
|
+
}
|
|
301
|
+
else if (result.checks.txt.found) {
|
|
302
|
+
console.log(` ${logger_1.logger.yellow('!')} Found but value doesn't match`);
|
|
303
|
+
}
|
|
304
|
+
else {
|
|
305
|
+
console.log(` ${logger_1.logger.red('✗')} Not found`);
|
|
306
|
+
console.log(` Expected: ${result.checks.txt.expected}`);
|
|
307
|
+
}
|
|
308
|
+
console.log('');
|
|
309
|
+
if (result.success) {
|
|
310
|
+
logger_1.logger.success('DNS verified!');
|
|
311
|
+
console.log('');
|
|
312
|
+
console.log(` ${result.message}`);
|
|
313
|
+
console.log('');
|
|
314
|
+
logger_1.logger.info('Run "devdoc domain status" to check SSL provisioning progress.');
|
|
315
|
+
}
|
|
316
|
+
else {
|
|
317
|
+
logger_1.logger.warn('DNS verification incomplete');
|
|
318
|
+
console.log('');
|
|
319
|
+
console.log(` ${result.message}`);
|
|
320
|
+
console.log('');
|
|
321
|
+
logger_1.logger.info('DNS changes can take 1-24 hours to propagate.');
|
|
322
|
+
logger_1.logger.info('Run "devdoc domain verify" again later.');
|
|
323
|
+
}
|
|
324
|
+
console.log('');
|
|
325
|
+
}
|
|
326
|
+
catch (error) {
|
|
327
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
328
|
+
logger_1.logger.error(`Failed to verify domain: ${message}`);
|
|
329
|
+
process.exit(1);
|
|
330
|
+
}
|
|
331
|
+
}
|
|
332
|
+
// =============================================================================
|
|
333
|
+
// Domain Remove Command
|
|
334
|
+
// =============================================================================
|
|
335
|
+
/**
|
|
336
|
+
* Remove custom domain from project
|
|
337
|
+
*/
|
|
338
|
+
async function domainRemove(customDomain, options) {
|
|
339
|
+
const projectRoot = process.cwd();
|
|
340
|
+
const apiUrl = options.url || process.env.DEVDOC_API_URL || constants_1.DEFAULT_API_URL;
|
|
341
|
+
logger_1.logger.info('Removing custom domain...\n');
|
|
342
|
+
// Load config
|
|
343
|
+
const config = loadDevDocConfig(projectRoot);
|
|
344
|
+
if (!config) {
|
|
345
|
+
logger_1.logger.error('.devdoc.json not found. Deploy your project first with "devdoc deploy"');
|
|
346
|
+
process.exit(1);
|
|
347
|
+
}
|
|
348
|
+
// Get API key
|
|
349
|
+
const apiKey = getApiKey(options, config);
|
|
350
|
+
if (!apiKey) {
|
|
351
|
+
logger_1.logger.error('API key not found. Deploy your project first or provide via --api-key');
|
|
352
|
+
process.exit(1);
|
|
353
|
+
}
|
|
354
|
+
try {
|
|
355
|
+
const body = {};
|
|
356
|
+
if (customDomain) {
|
|
357
|
+
body.customDomain = normalizeDomain(customDomain);
|
|
358
|
+
}
|
|
359
|
+
const response = await fetch(`${apiUrl}/api/domains/remove`, {
|
|
360
|
+
method: 'DELETE',
|
|
361
|
+
headers: {
|
|
362
|
+
'Content-Type': 'application/json',
|
|
363
|
+
'Authorization': `Bearer ${apiKey}`,
|
|
364
|
+
},
|
|
365
|
+
body: JSON.stringify(body),
|
|
366
|
+
});
|
|
367
|
+
const result = await response.json();
|
|
368
|
+
if (!response.ok || !result.success) {
|
|
369
|
+
logger_1.logger.error(result.error || 'Failed to remove domain');
|
|
370
|
+
process.exit(1);
|
|
371
|
+
}
|
|
372
|
+
logger_1.logger.success(`✓ Domain ${result.domain} removed`);
|
|
373
|
+
console.log('');
|
|
374
|
+
console.log(' Your docs remain accessible at the default subdomain.');
|
|
375
|
+
console.log('');
|
|
376
|
+
logger_1.logger.info('You can add a new custom domain anytime with:');
|
|
377
|
+
console.log(' devdoc domain add docs.yourdomain.com');
|
|
378
|
+
console.log('');
|
|
379
|
+
}
|
|
380
|
+
catch (error) {
|
|
381
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
382
|
+
logger_1.logger.error(`Failed to remove domain: ${message}`);
|
|
383
|
+
process.exit(1);
|
|
384
|
+
}
|
|
385
|
+
}
|
|
386
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"domain.js","sourceRoot":"","sources":["../../../src/cli/commands/domain.ts"],"names":[],"mappings":"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","sourcesContent":["import path from 'path'\nimport fs from 'fs-extra'\nimport { logger } from '../../utils/logger'\nimport { DEFAULT_API_URL } from '../../constants'\n\ninterface DomainOptions {\n  url?: string\n  apiKey?: string\n}\n\ninterface DevDocConfig {\n  projectId?: string\n  name?: string\n  slug?: string\n  subdomain?: string\n  apiKey?: string\n  url?: string\n  lastDeployed?: string\n  createdAt?: string\n}\n\ninterface DomainAddResponse {\n  success: boolean\n  domain: string\n  projectSlug: string\n  status: string\n  verification: {\n    cname: { name: string; value: string }\n    txt: { name: string; value: string }\n  }\n  instructions: string[]\n  error?: string\n}\n\ninterface DomainStatusResponse {\n  hasCustomDomain: boolean\n  domain?: string\n  status?: string\n  projectSlug: string\n  projectUrl: string\n  customUrl?: string\n  message?: string\n  dnsRecords?: {\n    cname: { name: string; value: string }\n    txt: { name: string; value: string }\n  }\n  nextStep?: string\n  error?: string\n}\n\ninterface DomainVerifyResponse {\n  success: boolean\n  domain: string\n  status: string\n  message: string\n  checks: {\n    cname: { found: boolean; value: string | null; valid: boolean; expected: string }\n    txt: { found: boolean; verified: boolean; expected: string }\n  }\n  error?: string\n}\n\ninterface DomainRemoveResponse {\n  success: boolean\n  message: string\n  domain: string\n  error?: string\n}\n\n/**\n * Load .devdoc.json and get API key\n */\nfunction loadDevDocConfig(projectRoot: string): DevDocConfig | null {\n  const configPath = path.join(projectRoot, '.devdoc.json')\n  if (!fs.existsSync(configPath)) {\n    return null\n  }\n  try {\n    return fs.readJsonSync(configPath) as DevDocConfig\n  } catch {\n    return null\n  }\n}\n\n/**\n * Get API key from options, env, or config\n */\nfunction getApiKey(options: DomainOptions, config: DevDocConfig | null): string | null {\n  return options.apiKey || process.env.DEVDOC_API_KEY || config?.apiKey || null\n}\n\n/**\n * Validate domain format\n */\nfunction isValidDomainFormat(domain: string): { valid: boolean; error?: string } {\n  if (!domain) {\n    return { valid: false, error: 'Domain is required' }\n  }\n  \n  if (domain.length < 4) {\n    return { valid: false, error: 'Domain must be at least 4 characters' }\n  }\n  \n  // Basic domain format check\n  const domainRegex = /^(?!-)[a-zA-Z0-9-]+(?:\\.[a-zA-Z0-9-]+)*\\.[a-zA-Z]{2,}$/\n  if (!domainRegex.test(domain)) {\n    return { valid: false, error: 'Invalid domain format. Example: docs.example.com' }\n  }\n  \n  // Check for reserved domains\n  const reserved = ['devdoc.sh', 'devdoc.io', 'devdoc.com']\n  if (reserved.some(r => domain === r || domain.endsWith(`.${r}`))) {\n    return { valid: false, error: 'Cannot use a reserved DevDoc domain' }\n  }\n  \n  return { valid: true }\n}\n\n/**\n * Normalize domain (lowercase, remove protocol/path)\n */\nfunction normalizeDomain(domain: string): string {\n  let normalized = domain.toLowerCase().trim()\n  normalized = normalized.replace(/^https?:\\/\\//, '')\n  normalized = normalized.split('/')[0]\n  normalized = normalized.split(':')[0]\n  return normalized\n}\n\n// =============================================================================\n// Domain Add Command\n// =============================================================================\n\n/**\n * Add a custom domain to the project\n */\nexport async function domainAdd(customDomain: string, options: DomainOptions): Promise<void> {\n  const projectRoot = process.cwd()\n  const apiUrl = options.url || process.env.DEVDOC_API_URL || DEFAULT_API_URL\n  \n  logger.info('Adding custom domain...\\n')\n  \n  // Load config\n  const config = loadDevDocConfig(projectRoot)\n  if (!config) {\n    logger.error('.devdoc.json not found. Deploy your project first with \"devdoc deploy\"')\n    process.exit(1)\n  }\n  \n  // Get API key\n  const apiKey = getApiKey(options, config)\n  if (!apiKey) {\n    logger.error('API key not found. Deploy your project first or provide via --api-key')\n    process.exit(1)\n  }\n  \n  // Normalize and validate domain\n  const domain = normalizeDomain(customDomain)\n  const validation = isValidDomainFormat(domain)\n  if (!validation.valid) {\n    logger.error(validation.error!)\n    process.exit(1)\n  }\n  \n  logger.info(`Domain: ${domain}`)\n  console.log('')\n  \n  try {\n    const response = await fetch(`${apiUrl}/api/domains/add`, {\n      method: 'POST',\n      headers: {\n        'Content-Type': 'application/json',\n        'Authorization': `Bearer ${apiKey}`,\n      },\n      body: JSON.stringify({ customDomain: domain }),\n    })\n    \n    const result = await response.json() as DomainAddResponse\n    \n    if (!response.ok || !result.success) {\n      logger.error(result.error || 'Failed to add domain')\n      process.exit(1)\n    }\n    \n    logger.success(`✓ Domain ${domain} added!`)\n    console.log('')\n    console.log('  Next, add these DNS records to your domain provider:')\n    console.log('')\n    console.log('  1. CNAME Record:')\n    console.log(`     Name:  ${result.verification.cname.name}`)\n    console.log(`     Value: ${result.verification.cname.value}`)\n    console.log('')\n    console.log('  2. TXT Record (for verification):')\n    console.log(`     Name:  ${result.verification.txt.name}`)\n    console.log(`     Value: ${result.verification.txt.value}`)\n    console.log('')\n    logger.info('After adding DNS records, run:')\n    console.log('  devdoc domain verify')\n    console.log('')\n    \n  } catch (error) {\n    const message = error instanceof Error ? error.message : String(error)\n    logger.error(`Failed to add domain: ${message}`)\n    process.exit(1)\n  }\n}\n\n// =============================================================================\n// Domain Status Command\n// =============================================================================\n\n/**\n * Check status of custom domain\n */\nexport async function domainStatus(options: DomainOptions): Promise<void> {\n  const projectRoot = process.cwd()\n  const apiUrl = options.url || process.env.DEVDOC_API_URL || DEFAULT_API_URL\n  \n  // Load config\n  const config = loadDevDocConfig(projectRoot)\n  if (!config) {\n    logger.error('.devdoc.json not found. Deploy your project first with \"devdoc deploy\"')\n    process.exit(1)\n  }\n  \n  // Get API key\n  const apiKey = getApiKey(options, config)\n  if (!apiKey) {\n    logger.error('API key not found. Deploy your project first or provide via --api-key')\n    process.exit(1)\n  }\n  \n  try {\n    const response = await fetch(`${apiUrl}/api/domains/status`, {\n      method: 'GET',\n      headers: {\n        'Authorization': `Bearer ${apiKey}`,\n      },\n    })\n    \n    const result = await response.json() as DomainStatusResponse\n    \n    if (!response.ok) {\n      logger.error(result.error || 'Failed to get domain status')\n      process.exit(1)\n    }\n    \n    console.log('')\n    console.log('  Custom Domain Status')\n    console.log('  --------------------')\n    \n    if (!result.hasCustomDomain) {\n      console.log('')\n      console.log('  No custom domain configured.')\n      console.log('')\n      console.log('  Your docs are available at:')\n      console.log(`  ${logger.cyan(result.projectUrl)}`)\n      console.log('')\n      logger.info('To add a custom domain, run:')\n      console.log('  devdoc domain add docs.yourdomain.com')\n      console.log('')\n      return\n    }\n    \n    console.log('')\n    console.log(`  Domain:  ${result.domain}`)\n    console.log(`  Status:  ${getStatusDisplay(result.status || 'unknown')}`)\n    console.log('')\n    \n    if (result.status === 'active') {\n      console.log('  Your docs are available at:')\n      console.log(`  ${logger.cyan(result.customUrl || `https://${result.domain}`)}`)\n      console.log('')\n      console.log('  Also accessible at:')\n      console.log(`  ${result.projectUrl}`)\n    } else if (result.status === 'pending' && result.dnsRecords) {\n      console.log('  Add these DNS records to your domain:')\n      console.log('')\n      console.log('  CNAME Record:')\n      console.log(`    Name:  ${result.dnsRecords.cname.name}`)\n      console.log(`    Value: ${result.dnsRecords.cname.value}`)\n      console.log('')\n      console.log('  TXT Record:')\n      console.log(`    Name:  ${result.dnsRecords.txt.name}`)\n      console.log(`    Value: ${result.dnsRecords.txt.value}`)\n      console.log('')\n      logger.info('After adding DNS records, run: devdoc domain verify')\n    } else if (result.message) {\n      console.log(`  ${result.message}`)\n    }\n    \n    if (result.nextStep) {\n      console.log('')\n      logger.info(`Next: ${result.nextStep}`)\n    }\n    \n    console.log('')\n    \n  } catch (error) {\n    const message = error instanceof Error ? error.message : String(error)\n    logger.error(`Failed to get domain status: ${message}`)\n    process.exit(1)\n  }\n}\n\n/**\n * Get display string for status\n */\nfunction getStatusDisplay(status: string): string {\n  switch (status) {\n    case 'pending':\n      return logger.yellow('⏳ Pending DNS configuration')\n    case 'dns_verified':\n      return logger.cyan('✓ DNS verified, SSL provisioning...')\n    case 'ssl_provisioning':\n      return logger.cyan('🔒 SSL certificate provisioning...')\n    case 'active':\n      return logger.green('✓ Active')\n    case 'error':\n      return logger.red('✗ Error')\n    default:\n      return status\n  }\n}\n\n// =============================================================================\n// Domain Verify Command\n// =============================================================================\n\n/**\n * Verify DNS configuration for custom domain\n */\nexport async function domainVerify(options: DomainOptions): Promise<void> {\n  const projectRoot = process.cwd()\n  const apiUrl = options.url || process.env.DEVDOC_API_URL || DEFAULT_API_URL\n  \n  logger.info('Verifying DNS configuration...\\n')\n  \n  // Load config\n  const config = loadDevDocConfig(projectRoot)\n  if (!config) {\n    logger.error('.devdoc.json not found. Deploy your project first with \"devdoc deploy\"')\n    process.exit(1)\n  }\n  \n  // Get API key\n  const apiKey = getApiKey(options, config)\n  if (!apiKey) {\n    logger.error('API key not found. Deploy your project first or provide via --api-key')\n    process.exit(1)\n  }\n  \n  try {\n    const response = await fetch(`${apiUrl}/api/domains/verify`, {\n      method: 'POST',\n      headers: {\n        'Content-Type': 'application/json',\n        'Authorization': `Bearer ${apiKey}`,\n      },\n      body: JSON.stringify({}),\n    })\n    \n    const result = await response.json() as DomainVerifyResponse\n    \n    if (!response.ok) {\n      logger.error(result.error || 'Failed to verify domain')\n      process.exit(1)\n    }\n    \n    console.log('')\n    console.log('  DNS Verification Results')\n    console.log('  ------------------------')\n    console.log('')\n    console.log(`  Domain: ${result.domain}`)\n    console.log('')\n    \n    // CNAME check\n    console.log('  CNAME Record:')\n    if (result.checks.cname.valid) {\n      console.log(`    ${logger.green('✓')} Found: ${result.checks.cname.value}`)\n    } else if (result.checks.cname.found) {\n      console.log(`    ${logger.yellow('!')} Found but incorrect: ${result.checks.cname.value}`)\n      console.log(`      Expected: ${result.checks.cname.expected}`)\n    } else {\n      console.log(`    ${logger.red('✗')} Not found`)\n      console.log(`      Expected: ${result.checks.cname.expected}`)\n    }\n    \n    // TXT check\n    console.log('')\n    console.log('  TXT Verification Record:')\n    if (result.checks.txt.verified) {\n      console.log(`    ${logger.green('✓')} Verified`)\n    } else if (result.checks.txt.found) {\n      console.log(`    ${logger.yellow('!')} Found but value doesn't match`)\n    } else {\n      console.log(`    ${logger.red('✗')} Not found`)\n      console.log(`      Expected: ${result.checks.txt.expected}`)\n    }\n    \n    console.log('')\n    \n    if (result.success) {\n      logger.success('DNS verified!')\n      console.log('')\n      console.log(`  ${result.message}`)\n      console.log('')\n      logger.info('Run \"devdoc domain status\" to check SSL provisioning progress.')\n    } else {\n      logger.warn('DNS verification incomplete')\n      console.log('')\n      console.log(`  ${result.message}`)\n      console.log('')\n      logger.info('DNS changes can take 1-24 hours to propagate.')\n      logger.info('Run \"devdoc domain verify\" again later.')\n    }\n    \n    console.log('')\n    \n  } catch (error) {\n    const message = error instanceof Error ? error.message : String(error)\n    logger.error(`Failed to verify domain: ${message}`)\n    process.exit(1)\n  }\n}\n\n// =============================================================================\n// Domain Remove Command\n// =============================================================================\n\n/**\n * Remove custom domain from project\n */\nexport async function domainRemove(customDomain: string | undefined, options: DomainOptions): Promise<void> {\n  const projectRoot = process.cwd()\n  const apiUrl = options.url || process.env.DEVDOC_API_URL || DEFAULT_API_URL\n  \n  logger.info('Removing custom domain...\\n')\n  \n  // Load config\n  const config = loadDevDocConfig(projectRoot)\n  if (!config) {\n    logger.error('.devdoc.json not found. Deploy your project first with \"devdoc deploy\"')\n    process.exit(1)\n  }\n  \n  // Get API key\n  const apiKey = getApiKey(options, config)\n  if (!apiKey) {\n    logger.error('API key not found. Deploy your project first or provide via --api-key')\n    process.exit(1)\n  }\n  \n  try {\n    const body: Record<string, string> = {}\n    if (customDomain) {\n      body.customDomain = normalizeDomain(customDomain)\n    }\n    \n    const response = await fetch(`${apiUrl}/api/domains/remove`, {\n      method: 'DELETE',\n      headers: {\n        'Content-Type': 'application/json',\n        'Authorization': `Bearer ${apiKey}`,\n      },\n      body: JSON.stringify(body),\n    })\n    \n    const result = await response.json() as DomainRemoveResponse\n    \n    if (!response.ok || !result.success) {\n      logger.error(result.error || 'Failed to remove domain')\n      process.exit(1)\n    }\n    \n    logger.success(`✓ Domain ${result.domain} removed`)\n    console.log('')\n    console.log('  Your docs remain accessible at the default subdomain.')\n    console.log('')\n    logger.info('You can add a new custom domain anytime with:')\n    console.log('  devdoc domain add docs.yourdomain.com')\n    console.log('')\n    \n  } catch (error) {\n    const message = error instanceof Error ? error.message : String(error)\n    logger.error(`Failed to remove domain: ${message}`)\n    process.exit(1)\n  }\n}\n"]}
|
package/dist/cli/index.js
CHANGED
|
@@ -12,6 +12,7 @@ const keys_1 = require("./commands/keys");
|
|
|
12
12
|
const whoami_1 = require("./commands/whoami");
|
|
13
13
|
const upload_1 = require("./commands/upload");
|
|
14
14
|
const ai_1 = require("./commands/ai");
|
|
15
|
+
const domain_1 = require("./commands/domain");
|
|
15
16
|
const packageJson = require('../../package.json');
|
|
16
17
|
const program = new commander_1.Command();
|
|
17
18
|
program
|
|
@@ -112,5 +113,33 @@ program
|
|
|
112
113
|
.option('-u, --url <url>', 'API URL')
|
|
113
114
|
.option('-k, --api-key <key>', 'API key for authentication')
|
|
114
115
|
.action(upload_1.upload);
|
|
116
|
+
// Domain management - custom domains (one per project, free)
|
|
117
|
+
const domainCmd = program
|
|
118
|
+
.command('domain')
|
|
119
|
+
.description('Manage custom domain for your documentation');
|
|
120
|
+
domainCmd
|
|
121
|
+
.command('add <custom-domain>')
|
|
122
|
+
.description('Add a custom domain (e.g., docs.example.com)')
|
|
123
|
+
.option('-u, --url <url>', 'API URL')
|
|
124
|
+
.option('-k, --api-key <key>', 'API key for authentication')
|
|
125
|
+
.action(domain_1.domainAdd);
|
|
126
|
+
domainCmd
|
|
127
|
+
.command('status')
|
|
128
|
+
.description('Check custom domain status and DNS configuration')
|
|
129
|
+
.option('-u, --url <url>', 'API URL')
|
|
130
|
+
.option('-k, --api-key <key>', 'API key for authentication')
|
|
131
|
+
.action(domain_1.domainStatus);
|
|
132
|
+
domainCmd
|
|
133
|
+
.command('verify')
|
|
134
|
+
.description('Verify DNS configuration for your custom domain')
|
|
135
|
+
.option('-u, --url <url>', 'API URL')
|
|
136
|
+
.option('-k, --api-key <key>', 'API key for authentication')
|
|
137
|
+
.action(domain_1.domainVerify);
|
|
138
|
+
domainCmd
|
|
139
|
+
.command('remove [custom-domain]')
|
|
140
|
+
.description('Remove custom domain from project')
|
|
141
|
+
.option('-u, --url <url>', 'API URL')
|
|
142
|
+
.option('-k, --api-key <key>', 'API key for authentication')
|
|
143
|
+
.action(domain_1.domainRemove);
|
|
115
144
|
program.parse(process.argv);
|
|
116
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command } from 'commander';\nimport { create } from './commands/create';\nimport { init } from './commands/init';\nimport { dev } from './commands/dev';\nimport { build } from './commands/build';\nimport { start } from './commands/start';\nimport { check } from './commands/check';\nimport { deploy } from './commands/deploy';\nimport { listKeys, regenerateKey } from './commands/keys';\nimport { whoami } from './commands/whoami';\nimport { upload, listAssets } from './commands/upload';\nimport { ai } from './commands/ai';\n\nconst packageJson = require('../../package.json');\n\nconst program = new Command();\n\nprogram\n  .name('devdoc')\n  .description('Documentation framework for developers')\n  .version(packageJson.version);\n\nprogram\n  .command('create [project-directory]')\n  .description('Create a new DevDoc documentation site')\n  .option('-t, --template <type>', 'Template to use (basic, openapi, graphql)')\n  .option('-s, --subdomain <subdomain>', 'Subdomain for your docs (e.g., my-docs.devdoc.sh)')\n  .option('--no-git', 'Skip git initialization')\n  .option('--no-install', 'Skip installing dependencies')\n  .option('--ai [tool]', 'Set up AI agents (claude, cursor, both, or just --ai to choose)')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .action(create);\n\nprogram\n  .command('init')\n  .description('Initialize/register project with Brainfish')\n  .option('-s, --slug <slug>', 'Project slug')\n  .option('--subdomain <subdomain>', 'Subdomain for your docs (e.g., my-docs.devdoc.sh)')\n  .option('-f, --force', 'Overwrite existing .devdoc.json')\n  .option('--ai [tool]', 'Set up AI agents (claude, cursor, both, or just --ai to choose)')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .action(init);\n\nprogram\n  .command('dev')\n  .description('Start development server with hot reload')\n  .option('-p, --port <port>', 'Port to run the server on', '3333')\n  .option('-H, --host <host>', 'Host to bind the server to', 'localhost')\n  .option('-o, --open', 'Open browser automatically', true)\n  .option('--no-open', 'Do not open browser automatically')\n  .action(dev);\n\nprogram\n  .command('build')\n  .description('Build documentation for production')\n  .option('-o, --output <dir>', 'Output directory', 'dist')\n  .action(build);\n\nprogram\n  .command('start')\n  .description('Start production server')\n  .option('-p, --port <port>', 'Port to run the server on', '3000')\n  .action(start);\n\nprogram\n  .command('check')\n  .description('Validate docs.json and MDX files')\n  .action(check);\n\nprogram\n  .command('ai')\n  .description('Set up AI agent configuration (Claude Code skills, Cursor rules)')\n  .option('-t, --tool <tool>', 'AI tool to configure (claude, cursor, both)')\n  .action(ai);\n\nprogram\n  .command('deploy')\n  .description('Deploy documentation to DevDoc platform')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(deploy);\n\n// Keys management\nconst keysCmd = program\n  .command('keys')\n  .description('Manage API keys for your project');\n\nkeysCmd\n  .command('list')\n  .description('Show current API key info')\n  .option('-u, --url <url>', 'API URL')\n  .action(listKeys);\n\nkeysCmd\n  .command('regenerate')\n  .description('Generate a new API key (invalidates the old one)')\n  .option('-u, --url <url>', 'API URL')\n  .action(regenerateKey);\n\nprogram\n  .command('whoami')\n  .description('Show current project information')\n  .option('-u, --url <url>', 'API URL')\n  .action(whoami);\n\n// Assets management\nconst assetsCmd = program\n  .command('assets')\n  .description('Manage project assets (images, files)');\n\nassetsCmd\n  .command('upload <files...>')\n  .description('Upload assets to storage (max 25MB per file)')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(upload);\n\nassetsCmd\n  .command('list')\n  .description('List uploaded assets')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(listAssets);\n\n// Shortcut for upload\nprogram\n  .command('upload <files...>')\n  .description('Upload assets to storage (shortcut for \"devdoc assets upload\")')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(upload);\n\nprogram.parse(process.argv);\n"]}
|
|
145
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command } from 'commander';\nimport { create } from './commands/create';\nimport { init } from './commands/init';\nimport { dev } from './commands/dev';\nimport { build } from './commands/build';\nimport { start } from './commands/start';\nimport { check } from './commands/check';\nimport { deploy } from './commands/deploy';\nimport { listKeys, regenerateKey } from './commands/keys';\nimport { whoami } from './commands/whoami';\nimport { upload, listAssets } from './commands/upload';\nimport { ai } from './commands/ai';\nimport { domainAdd, domainStatus, domainVerify, domainRemove } from './commands/domain';\n\nconst packageJson = require('../../package.json');\n\nconst program = new Command();\n\nprogram\n  .name('devdoc')\n  .description('Documentation framework for developers')\n  .version(packageJson.version);\n\nprogram\n  .command('create [project-directory]')\n  .description('Create a new DevDoc documentation site')\n  .option('-t, --template <type>', 'Template to use (basic, openapi, graphql)')\n  .option('-s, --subdomain <subdomain>', 'Subdomain for your docs (e.g., my-docs.devdoc.sh)')\n  .option('--no-git', 'Skip git initialization')\n  .option('--no-install', 'Skip installing dependencies')\n  .option('--ai [tool]', 'Set up AI agents (claude, cursor, both, or just --ai to choose)')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .action(create);\n\nprogram\n  .command('init')\n  .description('Initialize/register project with Brainfish')\n  .option('-s, --slug <slug>', 'Project slug')\n  .option('--subdomain <subdomain>', 'Subdomain for your docs (e.g., my-docs.devdoc.sh)')\n  .option('-f, --force', 'Overwrite existing .devdoc.json')\n  .option('--ai [tool]', 'Set up AI agents (claude, cursor, both, or just --ai to choose)')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .action(init);\n\nprogram\n  .command('dev')\n  .description('Start development server with hot reload')\n  .option('-p, --port <port>', 'Port to run the server on', '3333')\n  .option('-H, --host <host>', 'Host to bind the server to', 'localhost')\n  .option('-o, --open', 'Open browser automatically', true)\n  .option('--no-open', 'Do not open browser automatically')\n  .action(dev);\n\nprogram\n  .command('build')\n  .description('Build documentation for production')\n  .option('-o, --output <dir>', 'Output directory', 'dist')\n  .action(build);\n\nprogram\n  .command('start')\n  .description('Start production server')\n  .option('-p, --port <port>', 'Port to run the server on', '3000')\n  .action(start);\n\nprogram\n  .command('check')\n  .description('Validate docs.json and MDX files')\n  .action(check);\n\nprogram\n  .command('ai')\n  .description('Set up AI agent configuration (Claude Code skills, Cursor rules)')\n  .option('-t, --tool <tool>', 'AI tool to configure (claude, cursor, both)')\n  .action(ai);\n\nprogram\n  .command('deploy')\n  .description('Deploy documentation to DevDoc platform')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(deploy);\n\n// Keys management\nconst keysCmd = program\n  .command('keys')\n  .description('Manage API keys for your project');\n\nkeysCmd\n  .command('list')\n  .description('Show current API key info')\n  .option('-u, --url <url>', 'API URL')\n  .action(listKeys);\n\nkeysCmd\n  .command('regenerate')\n  .description('Generate a new API key (invalidates the old one)')\n  .option('-u, --url <url>', 'API URL')\n  .action(regenerateKey);\n\nprogram\n  .command('whoami')\n  .description('Show current project information')\n  .option('-u, --url <url>', 'API URL')\n  .action(whoami);\n\n// Assets management\nconst assetsCmd = program\n  .command('assets')\n  .description('Manage project assets (images, files)');\n\nassetsCmd\n  .command('upload <files...>')\n  .description('Upload assets to storage (max 25MB per file)')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(upload);\n\nassetsCmd\n  .command('list')\n  .description('List uploaded assets')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(listAssets);\n\n// Shortcut for upload\nprogram\n  .command('upload <files...>')\n  .description('Upload assets to storage (shortcut for \"devdoc assets upload\")')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(upload);\n\n// Domain management - custom domains (one per project, free)\nconst domainCmd = program\n  .command('domain')\n  .description('Manage custom domain for your documentation');\n\ndomainCmd\n  .command('add <custom-domain>')\n  .description('Add a custom domain (e.g., docs.example.com)')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainAdd);\n\ndomainCmd\n  .command('status')\n  .description('Check custom domain status and DNS configuration')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainStatus);\n\ndomainCmd\n  .command('verify')\n  .description('Verify DNS configuration for your custom domain')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainVerify);\n\ndomainCmd\n  .command('remove [custom-domain]')\n  .description('Remove custom domain from project')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainRemove);\n\nprogram.parse(process.argv);\n"]}
|
package/package.json
CHANGED