gipity 1.0.48

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.
Files changed (116) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +234 -0
  3. package/dist/__tests__/config.test.d.ts +1 -0
  4. package/dist/__tests__/config.test.js +31 -0
  5. package/dist/__tests__/config.test.js.map +1 -0
  6. package/dist/__tests__/sync.test.d.ts +1 -0
  7. package/dist/__tests__/sync.test.js +89 -0
  8. package/dist/__tests__/sync.test.js.map +1 -0
  9. package/dist/__tests__/utils.test.d.ts +1 -0
  10. package/dist/__tests__/utils.test.js +69 -0
  11. package/dist/__tests__/utils.test.js.map +1 -0
  12. package/dist/api.d.ts +13 -0
  13. package/dist/api.js +85 -0
  14. package/dist/api.js.map +1 -0
  15. package/dist/auth.d.ts +12 -0
  16. package/dist/auth.js +90 -0
  17. package/dist/auth.js.map +1 -0
  18. package/dist/coding-guidelines.d.ts +9 -0
  19. package/dist/coding-guidelines.js +52 -0
  20. package/dist/coding-guidelines.js.map +1 -0
  21. package/dist/commands/agent.d.ts +2 -0
  22. package/dist/commands/agent.js +164 -0
  23. package/dist/commands/agent.js.map +1 -0
  24. package/dist/commands/api.d.ts +2 -0
  25. package/dist/commands/api.js +137 -0
  26. package/dist/commands/api.js.map +1 -0
  27. package/dist/commands/audit.d.ts +2 -0
  28. package/dist/commands/audit.js +70 -0
  29. package/dist/commands/audit.js.map +1 -0
  30. package/dist/commands/browser.d.ts +2 -0
  31. package/dist/commands/browser.js +88 -0
  32. package/dist/commands/browser.js.map +1 -0
  33. package/dist/commands/chat.d.ts +2 -0
  34. package/dist/commands/chat.js +68 -0
  35. package/dist/commands/chat.js.map +1 -0
  36. package/dist/commands/checkpoint.d.ts +2 -0
  37. package/dist/commands/checkpoint.js +67 -0
  38. package/dist/commands/checkpoint.js.map +1 -0
  39. package/dist/commands/credits.d.ts +2 -0
  40. package/dist/commands/credits.js +57 -0
  41. package/dist/commands/credits.js.map +1 -0
  42. package/dist/commands/db.d.ts +2 -0
  43. package/dist/commands/db.js +102 -0
  44. package/dist/commands/db.js.map +1 -0
  45. package/dist/commands/deploy.d.ts +2 -0
  46. package/dist/commands/deploy.js +49 -0
  47. package/dist/commands/deploy.js.map +1 -0
  48. package/dist/commands/file.d.ts +2 -0
  49. package/dist/commands/file.js +85 -0
  50. package/dist/commands/file.js.map +1 -0
  51. package/dist/commands/fn.d.ts +2 -0
  52. package/dist/commands/fn.js +87 -0
  53. package/dist/commands/fn.js.map +1 -0
  54. package/dist/commands/init.d.ts +2 -0
  55. package/dist/commands/init.js +107 -0
  56. package/dist/commands/init.js.map +1 -0
  57. package/dist/commands/login.d.ts +2 -0
  58. package/dist/commands/login.js +62 -0
  59. package/dist/commands/login.js.map +1 -0
  60. package/dist/commands/logout.d.ts +2 -0
  61. package/dist/commands/logout.js +14 -0
  62. package/dist/commands/logout.js.map +1 -0
  63. package/dist/commands/logs.d.ts +2 -0
  64. package/dist/commands/logs.js +39 -0
  65. package/dist/commands/logs.js.map +1 -0
  66. package/dist/commands/memory.d.ts +2 -0
  67. package/dist/commands/memory.js +114 -0
  68. package/dist/commands/memory.js.map +1 -0
  69. package/dist/commands/project.d.ts +2 -0
  70. package/dist/commands/project.js +132 -0
  71. package/dist/commands/project.js.map +1 -0
  72. package/dist/commands/push.d.ts +2 -0
  73. package/dist/commands/push.js +34 -0
  74. package/dist/commands/push.js.map +1 -0
  75. package/dist/commands/rbac.d.ts +2 -0
  76. package/dist/commands/rbac.js +89 -0
  77. package/dist/commands/rbac.js.map +1 -0
  78. package/dist/commands/records.d.ts +2 -0
  79. package/dist/commands/records.js +131 -0
  80. package/dist/commands/records.js.map +1 -0
  81. package/dist/commands/sandbox.d.ts +2 -0
  82. package/dist/commands/sandbox.js +53 -0
  83. package/dist/commands/sandbox.js.map +1 -0
  84. package/dist/commands/scaffold.d.ts +2 -0
  85. package/dist/commands/scaffold.js +38 -0
  86. package/dist/commands/scaffold.js.map +1 -0
  87. package/dist/commands/start-cc.d.ts +2 -0
  88. package/dist/commands/start-cc.js +201 -0
  89. package/dist/commands/start-cc.js.map +1 -0
  90. package/dist/commands/status.d.ts +2 -0
  91. package/dist/commands/status.js +43 -0
  92. package/dist/commands/status.js.map +1 -0
  93. package/dist/commands/sync.d.ts +2 -0
  94. package/dist/commands/sync.js +42 -0
  95. package/dist/commands/sync.js.map +1 -0
  96. package/dist/commands/workflow.d.ts +2 -0
  97. package/dist/commands/workflow.js +163 -0
  98. package/dist/commands/workflow.js.map +1 -0
  99. package/dist/config.d.ts +15 -0
  100. package/dist/config.js +76 -0
  101. package/dist/config.js.map +1 -0
  102. package/dist/index.d.ts +2 -0
  103. package/dist/index.js +65 -0
  104. package/dist/index.js.map +1 -0
  105. package/dist/setup.d.ts +23 -0
  106. package/dist/setup.js +168 -0
  107. package/dist/setup.js.map +1 -0
  108. package/dist/sync.d.ts +34 -0
  109. package/dist/sync.js +234 -0
  110. package/dist/sync.js.map +1 -0
  111. package/dist/utils.d.ts +10 -0
  112. package/dist/utils.js +57 -0
  113. package/dist/utils.js.map +1 -0
  114. package/hooks/post-write.sh +17 -0
  115. package/hooks/pre-turn.sh +20 -0
  116. package/package.json +29 -0
@@ -0,0 +1,88 @@
1
+ import { Command } from 'commander';
2
+ import { post } from '../api.js';
3
+ import { requireConfig } from '../config.js';
4
+ import { formatSize } from '../utils.js';
5
+ function shortUrl(url) {
6
+ try {
7
+ const u = new URL(url);
8
+ return u.pathname + u.search;
9
+ }
10
+ catch {
11
+ return url.length > 60 ? url.slice(-60) : url;
12
+ }
13
+ }
14
+ export const browserCommand = new Command('browser')
15
+ .description('Inspect a URL: console errors, performance, failed resources')
16
+ .argument('<url>', 'URL to inspect')
17
+ .option('--wait <ms>', 'Wait before capture in ms', '3000')
18
+ .option('--json', 'Output as JSON')
19
+ .action(async (url, opts) => {
20
+ try {
21
+ const config = requireConfig();
22
+ const waitMs = parseInt(opts.wait, 10) || 3000;
23
+ const res = await post(`/projects/${config.projectGuid}/browser/inspect`, { url, waitMs });
24
+ const b = res.data;
25
+ if (opts.json) {
26
+ console.log(JSON.stringify(b));
27
+ return;
28
+ }
29
+ const timing = b.timing || { ttfb: 0, domReady: 0, load: 0 };
30
+ // ── Page Info ──
31
+ console.log(`\nInspecting ${b.url || url}`);
32
+ console.log(` Title: ${b.title || '(none)'}`);
33
+ console.log(` Elements: ${b.elementCount || 0}`);
34
+ console.log(` Page weight: ${formatSize(b.totalBytes || 0)}`);
35
+ // ── Timing ──
36
+ console.log(`\n Timing:`);
37
+ console.log(` TTFB: ${timing.ttfb}ms`);
38
+ console.log(` DOM ready: ${timing.domReady}ms`);
39
+ console.log(` Load: ${timing.load}ms`);
40
+ if (b.lcp) {
41
+ console.log(` LCP: ${b.lcp.time}ms (${b.lcp.element}${b.lcp.url ? ' ' + shortUrl(b.lcp.url) : ''})`);
42
+ }
43
+ // ── Console ──
44
+ if (b.console?.length > 0) {
45
+ console.log(`\n Console (${b.console.length}):`);
46
+ for (const line of b.console) {
47
+ console.log(` ${line}`);
48
+ }
49
+ }
50
+ else {
51
+ console.log('\n Console: (clean)');
52
+ }
53
+ // ── Failed Resources ──
54
+ if (b.failedResources?.length > 0) {
55
+ console.log(`\n Failed resources (${b.failedResources.length}):`);
56
+ for (const r of b.failedResources) {
57
+ console.log(` ${r}`);
58
+ }
59
+ }
60
+ // ── Render Blocking ──
61
+ if (b.renderBlocking?.length > 0) {
62
+ console.log(`\n Render-blocking (${b.renderBlocking.length}):`);
63
+ for (const r of b.renderBlocking) {
64
+ console.log(` ${shortUrl(r)}`);
65
+ }
66
+ }
67
+ // ── Large Resources ──
68
+ if (b.largeResources?.length > 0) {
69
+ console.log(`\n Large resources >100KB (${b.largeResources.length}):`);
70
+ for (const r of b.largeResources) {
71
+ console.log(` ${formatSize(r.size).padEnd(10)} ${r.type.padEnd(8)} ${shortUrl(r.url)}`);
72
+ }
73
+ }
74
+ // ── Oversized Images ──
75
+ if (b.oversizedImages?.length > 0) {
76
+ console.log(`\n Oversized images (${b.oversizedImages.length}):`);
77
+ for (const img of b.oversizedImages) {
78
+ console.log(` ${img.natural} served, ${img.displayed} displayed — ${shortUrl(img.src)}`);
79
+ }
80
+ }
81
+ console.log('');
82
+ }
83
+ catch (err) {
84
+ console.error(`Browser inspect failed: ${err.message}`);
85
+ process.exit(1);
86
+ }
87
+ });
88
+ //# sourceMappingURL=browser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"browser.js","sourceRoot":"","sources":["../../src/commands/browser.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { Command } from 'commander';
2
+ export declare const chatCommand: Command;
@@ -0,0 +1,68 @@
1
+ import { Command } from 'commander';
2
+ import { post } from '../api.js';
3
+ import { requireConfig, saveConfig } from '../config.js';
4
+ import { syncDown } from '../sync.js';
5
+ const FILE_TOOLS = new Set([
6
+ 'file_write', 'file_edit', 'file_delete', 'file_copy', 'file_move',
7
+ 'file_rename', 'dir_create', 'dir_delete',
8
+ ]);
9
+ export const chatCommand = new Command('chat')
10
+ .description('Send a message to the Gipity agent')
11
+ .argument('<message>', 'Message to send')
12
+ .option('--new', 'Start a new conversation')
13
+ .option('--json', 'Output as JSON')
14
+ .action(async (message, opts) => {
15
+ try {
16
+ const config = requireConfig();
17
+ const useExisting = config.conversationGuid && !opts.new;
18
+ const endpoint = useExisting
19
+ ? `/conversations/${config.conversationGuid}/messages`
20
+ : '/conversations';
21
+ const body = useExisting
22
+ ? { content: message }
23
+ : { agentGuid: config.agentGuid, content: message, projectGuid: config.projectGuid };
24
+ const res = await post(endpoint, body);
25
+ // Save conversation guid for continuity
26
+ if (res.data.conversationGuid !== config.conversationGuid) {
27
+ saveConfig({ ...config, conversationGuid: res.data.conversationGuid });
28
+ }
29
+ // Check if file tools were used — auto sync-down
30
+ const fileToolsUsed = res.data.toolsUsed?.filter(t => FILE_TOOLS.has(t.toolName)) || [];
31
+ let syncSummary = '';
32
+ if (fileToolsUsed.length > 0) {
33
+ const syncResult = await syncDown();
34
+ if (syncResult.pulled > 0) {
35
+ syncSummary = `\nPulled ${syncResult.pulled} file${syncResult.pulled > 1 ? 's' : ''}:\n${syncResult.summary}`;
36
+ }
37
+ }
38
+ if (opts.json) {
39
+ console.log(JSON.stringify({
40
+ content: res.data.content,
41
+ toolsUsed: res.data.toolsUsed?.map(t => t.toolName) || [],
42
+ model: res.data.model,
43
+ tokens: res.data.inputTokens + res.data.outputTokens,
44
+ cost: res.data.costUsd,
45
+ conversationGuid: res.data.conversationGuid,
46
+ filesSynced: fileToolsUsed.length > 0,
47
+ }));
48
+ }
49
+ else {
50
+ // Show agent response
51
+ console.log(res.data.content);
52
+ // Show tools used
53
+ if (res.data.toolsUsed && res.data.toolsUsed.length > 0) {
54
+ const toolNames = [...new Set(res.data.toolsUsed.map(t => t.toolName))];
55
+ console.log(`\nTools: ${toolNames.join(', ')}`);
56
+ }
57
+ // Show sync results
58
+ if (syncSummary) {
59
+ console.log(syncSummary);
60
+ }
61
+ }
62
+ }
63
+ catch (err) {
64
+ console.error(`Chat failed: ${err.message}`);
65
+ process.exit(1);
66
+ }
67
+ });
68
+ //# sourceMappingURL=chat.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chat.js","sourceRoot":"","sources":["../../src/commands/chat.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { Command } from 'commander';
2
+ export declare const checkpointCommand: Command;
@@ -0,0 +1,67 @@
1
+ import { Command } from 'commander';
2
+ import { get, post } from '../api.js';
3
+ import { requireConfig } from '../config.js';
4
+ import { syncDown } from '../sync.js';
5
+ import { formatAge } from '../utils.js';
6
+ export const checkpointCommand = new Command('checkpoint')
7
+ .description('Manage file checkpoints (snapshots for undo/restore)');
8
+ checkpointCommand
9
+ .command('list')
10
+ .description('List checkpoints')
11
+ .option('--limit <n>', 'Max results', '20')
12
+ .option('--json', 'Output as JSON')
13
+ .action(async (opts) => {
14
+ try {
15
+ const config = requireConfig();
16
+ const limit = parseInt(opts.limit, 10) || 20;
17
+ const res = await get(`/projects/${config.projectGuid}/checkpoints?limit=${limit}`);
18
+ if (opts.json) {
19
+ console.log(JSON.stringify(res.data));
20
+ }
21
+ else {
22
+ if (res.data.length === 0) {
23
+ console.log('No checkpoints.');
24
+ }
25
+ else {
26
+ for (const cp of res.data) {
27
+ const age = formatAge(cp.created_at);
28
+ const branch = cp.branched ? ' (branched)' : '';
29
+ console.log(` ${cp.guid} ${cp.label || '(auto)'} ${cp.fileCount} files ${age}${branch}`);
30
+ }
31
+ }
32
+ }
33
+ }
34
+ catch (err) {
35
+ console.error(`List failed: ${err.message}`);
36
+ process.exit(1);
37
+ }
38
+ });
39
+ checkpointCommand
40
+ .command('restore <guid>')
41
+ .description('Restore files to a checkpoint (creates a backup checkpoint first)')
42
+ .option('--json', 'Output as JSON')
43
+ .action(async (guid, opts) => {
44
+ try {
45
+ const config = requireConfig();
46
+ const res = await post(`/projects/${config.projectGuid}/checkpoints/restore`, {
47
+ checkpoint_guid: guid,
48
+ });
49
+ // Sync down restored files
50
+ const syncResult = await syncDown();
51
+ if (opts.json) {
52
+ console.log(JSON.stringify({ ...res.data, synced: syncResult.pulled }));
53
+ }
54
+ else {
55
+ console.log(`Restored to ${res.data.restoredTo}`);
56
+ console.log(`Backup created: ${res.data.backupCheckpoint}`);
57
+ if (syncResult.pulled > 0) {
58
+ console.log(`Pulled ${syncResult.pulled} files to local.`);
59
+ }
60
+ }
61
+ }
62
+ catch (err) {
63
+ console.error(`Restore failed: ${err.message}`);
64
+ process.exit(1);
65
+ }
66
+ });
67
+ //# sourceMappingURL=checkpoint.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"checkpoint.js","sourceRoot":"","sources":["../../src/commands/checkpoint.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { Command } from 'commander';
2
+ export declare const creditsCommand: Command;
@@ -0,0 +1,57 @@
1
+ import { Command } from 'commander';
2
+ import { get } from '../api.js';
3
+ export const creditsCommand = new Command('credits')
4
+ .description('View credits and usage')
5
+ .option('--json', 'Output as JSON')
6
+ .action(async (opts) => {
7
+ try {
8
+ const res = await get('/credits/balance');
9
+ if (opts.json) {
10
+ console.log(JSON.stringify(res.data));
11
+ }
12
+ else {
13
+ console.log(`Credits: ${res.data.totalCredits.toLocaleString()}`);
14
+ if (res.data.balances.length > 0) {
15
+ for (const b of res.data.balances) {
16
+ const exp = new Date(b.expiresAt).toLocaleDateString();
17
+ console.log(` ${b.source}: ${b.credits.toLocaleString()} expires ${exp}`);
18
+ }
19
+ }
20
+ }
21
+ }
22
+ catch (err) {
23
+ console.error(`Failed: ${err.message}`);
24
+ process.exit(1);
25
+ }
26
+ });
27
+ creditsCommand
28
+ .command('usage')
29
+ .description('Show recent credit usage')
30
+ .option('--limit <n>', 'Number of entries', '20')
31
+ .option('--json', 'Output as JSON')
32
+ .action(async (opts) => {
33
+ try {
34
+ const limit = parseInt(opts.limit, 10) || 20;
35
+ const res = await get(`/credits/usage?limit=${limit}`);
36
+ if (opts.json) {
37
+ console.log(JSON.stringify(res.data));
38
+ }
39
+ else {
40
+ if (res.data.length === 0) {
41
+ console.log('No usage history.');
42
+ }
43
+ else {
44
+ for (const u of res.data) {
45
+ const date = new Date(u.createdAt).toLocaleString();
46
+ const model = u.modelId ? ` [${u.modelId}]` : '';
47
+ console.log(`${u.operation} -${u.creditsDeducted}${model} ${date}`);
48
+ }
49
+ }
50
+ }
51
+ }
52
+ catch (err) {
53
+ console.error(`Usage failed: ${err.message}`);
54
+ process.exit(1);
55
+ }
56
+ });
57
+ //# sourceMappingURL=credits.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"credits.js","sourceRoot":"","sources":["../../src/commands/credits.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { Command } from 'commander';
2
+ export declare const dbCommand: Command;
@@ -0,0 +1,102 @@
1
+ import { Command } from 'commander';
2
+ import { get, post, sendMessage } from '../api.js';
3
+ import { requireConfig } from '../config.js';
4
+ export const dbCommand = new Command('db')
5
+ .description('Manage project databases');
6
+ dbCommand
7
+ .command('query <sql>')
8
+ .description('Execute SQL on project database')
9
+ .option('--database <name>', 'Database name')
10
+ .option('--json', 'Output as JSON')
11
+ .action(async (sql, opts) => {
12
+ try {
13
+ const config = requireConfig();
14
+ // If no database specified, find the first one
15
+ let dbName = opts.database;
16
+ if (!dbName) {
17
+ const listRes = await get(`/projects/${config.projectGuid}/databases`);
18
+ if (listRes.data.length === 0) {
19
+ console.error('No databases found. Create one first: gipity db create <name>');
20
+ process.exit(1);
21
+ }
22
+ dbName = listRes.data[0].friendlyName;
23
+ }
24
+ const res = await post(`/projects/${config.projectGuid}/db/query`, { sql, database: dbName });
25
+ if (opts.json) {
26
+ console.log(JSON.stringify(res.data));
27
+ }
28
+ else {
29
+ if (res.data.rows !== undefined) {
30
+ if (res.data.rows.length === 0) {
31
+ console.log('(no results)');
32
+ }
33
+ else {
34
+ // Simple table output
35
+ const columns = Object.keys(res.data.rows[0]);
36
+ console.log(columns.join('\t'));
37
+ for (const row of res.data.rows) {
38
+ console.log(columns.map(c => String(row[c] ?? 'NULL')).join('\t'));
39
+ }
40
+ }
41
+ }
42
+ else if (res.data.affectedRows !== undefined) {
43
+ console.log(`Affected rows: ${res.data.affectedRows}`);
44
+ }
45
+ else if (res.data.results) {
46
+ console.log(JSON.stringify(res.data.results, null, 2));
47
+ }
48
+ }
49
+ }
50
+ catch (err) {
51
+ console.error(`Query failed: ${err.message}`);
52
+ process.exit(1);
53
+ }
54
+ });
55
+ dbCommand
56
+ .command('list')
57
+ .description('List project databases')
58
+ .option('--json', 'Output as JSON')
59
+ .action(async (opts) => {
60
+ try {
61
+ const config = requireConfig();
62
+ const res = await get(`/projects/${config.projectGuid}/databases`);
63
+ if (opts.json) {
64
+ console.log(JSON.stringify(res.data));
65
+ }
66
+ else {
67
+ if (res.data.length === 0) {
68
+ console.log('No databases. Create one: gipity db create <name>');
69
+ }
70
+ else {
71
+ for (const db of res.data) {
72
+ console.log(db.friendlyName);
73
+ }
74
+ }
75
+ }
76
+ }
77
+ catch (err) {
78
+ console.error(`List failed: ${err.message}`);
79
+ process.exit(1);
80
+ }
81
+ });
82
+ dbCommand
83
+ .command('create <name>')
84
+ .description('Create a project database')
85
+ .option('--json', 'Output as JSON')
86
+ .action(async (name, opts) => {
87
+ try {
88
+ // DDL delegates to agent (needs confirmation flow)
89
+ const response = await sendMessage(`Create a new database called "${name}" for this project. Confirm when done, no explanation.`);
90
+ if (opts.json) {
91
+ console.log(JSON.stringify({ response }));
92
+ }
93
+ else {
94
+ console.log(response);
95
+ }
96
+ }
97
+ catch (err) {
98
+ console.error(`Create failed: ${err.message}`);
99
+ process.exit(1);
100
+ }
101
+ });
102
+ //# sourceMappingURL=db.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"db.js","sourceRoot":"","sources":["../../src/commands/db.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { Command } from 'commander';
2
+ export declare const deployCommand: Command;
@@ -0,0 +1,49 @@
1
+ import { Command } from 'commander';
2
+ import { post } from '../api.js';
3
+ import { requireConfig } from '../config.js';
4
+ import { syncUp } from '../sync.js';
5
+ export const deployCommand = new Command('deploy')
6
+ .description('Deploy project to dev or prod')
7
+ .argument('[target]', 'dev or prod', 'dev')
8
+ .option('--source-dir <dir>', 'Source directory to deploy from')
9
+ .option('--no-sync', 'Skip sync-up before deploy')
10
+ .option('--json', 'Output as JSON')
11
+ .action(async (target, opts) => {
12
+ try {
13
+ if (target !== 'dev' && target !== 'prod') {
14
+ console.error('Target must be "dev" or "prod"');
15
+ process.exit(1);
16
+ }
17
+ const config = requireConfig();
18
+ // Sync up first
19
+ if (opts.sync !== false) {
20
+ const syncResult = await syncUp();
21
+ if (syncResult.pushed > 0 && !opts.json) {
22
+ console.log(`Synced ${syncResult.pushed} file${syncResult.pushed > 1 ? 's' : ''}.`);
23
+ }
24
+ }
25
+ // Deploy
26
+ if (!opts.json)
27
+ console.log(`Deploying to ${target}...`);
28
+ const res = await post(`/projects/${config.projectGuid}/deploy`, {
29
+ target,
30
+ sourceDir: opts.sourceDir,
31
+ });
32
+ if (opts.json) {
33
+ console.log(JSON.stringify(res.data));
34
+ }
35
+ else {
36
+ if (res.data.warning) {
37
+ console.log(res.data.warning);
38
+ }
39
+ else {
40
+ console.log(`${res.data.url} (${res.data.fileCount} files)`);
41
+ }
42
+ }
43
+ }
44
+ catch (err) {
45
+ console.error(`Deploy failed: ${err.message}`);
46
+ process.exit(1);
47
+ }
48
+ });
49
+ //# sourceMappingURL=deploy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deploy.js","sourceRoot":"","sources":["../../src/commands/deploy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAEpC,MAAM,CAAC,MAAM,aAAa,GAAG,IAAI,OAAO,CAAC,QAAQ,CAAC;KAC/C,WAAW,CAAC,+BAA+B,CAAC;KAC5C,QAAQ,CAAC,UAAU,EAAE,aAAa,EAAE,KAAK,CAAC;KAC1C,MAAM,CAAC,oBAAoB,EAAE,iCAAiC,CAAC;KAC/D,MAAM,CAAC,WAAW,EAAE,4BAA4B,CAAC;KACjD,MAAM,CAAC,QAAQ,EAAE,gBAAgB,CAAC;KAClC,MAAM,CAAC,KAAK,EAAE,MAAc,EAAE,IAAI,EAAE,EAAE;IACrC,IAAI,CAAC;QACH,IAAI,MAAM,KAAK,KAAK,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;YAC1C,OAAO,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAC;YAChD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,CAAC;QAED,MAAM,MAAM,GAAG,aAAa,EAAE,CAAC;QAE/B,gBAAgB;QAChB,IAAI,IAAI,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;YACxB,MAAM,UAAU,GAAG,MAAM,MAAM,EAAE,CAAC;YAClC,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;gBACxC,OAAO,CAAC,GAAG,CAAC,UAAU,UAAU,CAAC,MAAM,QAAQ,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;YACtF,CAAC;QACH,CAAC;QAED,SAAS;QACT,IAAI,CAAC,IAAI,CAAC,IAAI;YAAE,OAAO,CAAC,GAAG,CAAC,gBAAgB,MAAM,KAAK,CAAC,CAAC;QAEzD,MAAM,GAAG,GAAG,MAAM,IAAI,CAEnB,aAAa,MAAM,CAAC,WAAW,SAAS,EAAE;YAC3C,MAAM;YACN,SAAS,EAAE,IAAI,CAAC,SAAS;SAC1B,CAAC,CAAC;QAEH,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;QACxC,CAAC;aAAM,CAAC;YACN,IAAI,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;gBACrB,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAChC,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,IAAI,CAAC,GAAG,MAAM,GAAG,CAAC,IAAI,CAAC,SAAS,SAAS,CAAC,CAAC;YAChE,CAAC;QACH,CAAC;IACH,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAClB,OAAO,CAAC,KAAK,CAAC,kBAAkB,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;QAC/C,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ import { Command } from 'commander';
2
+ export declare const fileCommand: Command;
@@ -0,0 +1,85 @@
1
+ import { Command } from 'commander';
2
+ import { get } from '../api.js';
3
+ import { requireConfig } from '../config.js';
4
+ import { formatSize } from '../utils.js';
5
+ export const fileCommand = new Command('file')
6
+ .description('Browse remote files (without sync)');
7
+ fileCommand
8
+ .command('ls [path]')
9
+ .description('List files in remote project')
10
+ .option('--json', 'Output as JSON')
11
+ .action(async (path, opts) => {
12
+ try {
13
+ const config = requireConfig();
14
+ const query = path ? `?path=${encodeURIComponent(path)}` : '';
15
+ const res = await get(`/projects/${config.projectGuid}/files${query}`);
16
+ if (opts.json) {
17
+ console.log(JSON.stringify(res.data));
18
+ }
19
+ else {
20
+ if (res.data.length === 0) {
21
+ console.log('(empty)');
22
+ }
23
+ else {
24
+ for (const f of res.data) {
25
+ const size = f.type === 'directory' ? '<DIR>' : formatSize(Number(f.size));
26
+ console.log(`${size.padStart(10)} ${f.name}${f.type === 'directory' ? '/' : ''}`);
27
+ }
28
+ }
29
+ }
30
+ }
31
+ catch (err) {
32
+ console.error(`List failed: ${err.message}`);
33
+ process.exit(1);
34
+ }
35
+ });
36
+ fileCommand
37
+ .command('cat <path>')
38
+ .description('Read a remote file')
39
+ .option('--json', 'Output as JSON')
40
+ .action(async (path, opts) => {
41
+ try {
42
+ const config = requireConfig();
43
+ const res = await get(`/projects/${config.projectGuid}/files/read?path=${encodeURIComponent(path)}`);
44
+ if (opts.json) {
45
+ console.log(JSON.stringify(res.data));
46
+ }
47
+ else {
48
+ process.stdout.write(res.data.content);
49
+ }
50
+ }
51
+ catch (err) {
52
+ console.error(`Read failed: ${err.message}`);
53
+ process.exit(1);
54
+ }
55
+ });
56
+ fileCommand
57
+ .command('tree [path]')
58
+ .description('Show full file tree')
59
+ .option('--json', 'Output as JSON')
60
+ .action(async (path, opts) => {
61
+ try {
62
+ const config = requireConfig();
63
+ const query = path ? `?path=${encodeURIComponent(path)}` : '';
64
+ const res = await get(`/projects/${config.projectGuid}/files/tree${query}`);
65
+ if (opts.json) {
66
+ console.log(JSON.stringify(res.data));
67
+ }
68
+ else {
69
+ if (res.data.length === 0) {
70
+ console.log('(empty)');
71
+ }
72
+ else {
73
+ for (const f of res.data) {
74
+ const size = f.type === 'dir' ? '' : ` (${formatSize(Number(f.size))})`;
75
+ console.log(`${f.path}${size}`);
76
+ }
77
+ }
78
+ }
79
+ }
80
+ catch (err) {
81
+ console.error(`Tree failed: ${err.message}`);
82
+ process.exit(1);
83
+ }
84
+ });
85
+ //# sourceMappingURL=file.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file.js","sourceRoot":"","sources":["../../src/commands/file.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { Command } from 'commander';
2
+ export declare const fnCommand: Command;