@local-labs-jpollock/local-cli 0.0.1

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 (86) hide show
  1. package/addon-dist/bin/mcp-stdio.js +2808 -0
  2. package/addon-dist/lib/common/constants.d.ts +22 -0
  3. package/addon-dist/lib/common/constants.js +26 -0
  4. package/addon-dist/lib/common/theme.d.ts +68 -0
  5. package/addon-dist/lib/common/theme.js +126 -0
  6. package/addon-dist/lib/common/types.d.ts +298 -0
  7. package/addon-dist/lib/common/types.js +6 -0
  8. package/addon-dist/lib/main/config/ConnectionInfo.d.ts +25 -0
  9. package/addon-dist/lib/main/config/ConnectionInfo.js +82 -0
  10. package/addon-dist/lib/main/index.d.ts +12 -0
  11. package/addon-dist/lib/main/index.js +3322 -0
  12. package/addon-dist/lib/main/mcp/McpAuth.d.ts +37 -0
  13. package/addon-dist/lib/main/mcp/McpAuth.js +87 -0
  14. package/addon-dist/lib/main/mcp/McpServer.d.ts +67 -0
  15. package/addon-dist/lib/main/mcp/McpServer.js +343 -0
  16. package/addon-dist/lib/main/mcp/tools/changePhpVersion.d.ts +7 -0
  17. package/addon-dist/lib/main/mcp/tools/changePhpVersion.js +81 -0
  18. package/addon-dist/lib/main/mcp/tools/cloneSite.d.ts +7 -0
  19. package/addon-dist/lib/main/mcp/tools/cloneSite.js +66 -0
  20. package/addon-dist/lib/main/mcp/tools/createSite.d.ts +7 -0
  21. package/addon-dist/lib/main/mcp/tools/createSite.js +137 -0
  22. package/addon-dist/lib/main/mcp/tools/deleteSite.d.ts +7 -0
  23. package/addon-dist/lib/main/mcp/tools/deleteSite.js +72 -0
  24. package/addon-dist/lib/main/mcp/tools/exportDatabase.d.ts +7 -0
  25. package/addon-dist/lib/main/mcp/tools/exportDatabase.js +72 -0
  26. package/addon-dist/lib/main/mcp/tools/exportSite.d.ts +7 -0
  27. package/addon-dist/lib/main/mcp/tools/exportSite.js +103 -0
  28. package/addon-dist/lib/main/mcp/tools/getLocalInfo.d.ts +7 -0
  29. package/addon-dist/lib/main/mcp/tools/getLocalInfo.js +72 -0
  30. package/addon-dist/lib/main/mcp/tools/getSite.d.ts +7 -0
  31. package/addon-dist/lib/main/mcp/tools/getSite.js +68 -0
  32. package/addon-dist/lib/main/mcp/tools/getSiteLogs.d.ts +7 -0
  33. package/addon-dist/lib/main/mcp/tools/getSiteLogs.js +149 -0
  34. package/addon-dist/lib/main/mcp/tools/helpers.d.ts +59 -0
  35. package/addon-dist/lib/main/mcp/tools/helpers.js +179 -0
  36. package/addon-dist/lib/main/mcp/tools/importDatabase.d.ts +7 -0
  37. package/addon-dist/lib/main/mcp/tools/importDatabase.js +109 -0
  38. package/addon-dist/lib/main/mcp/tools/importSite.d.ts +7 -0
  39. package/addon-dist/lib/main/mcp/tools/importSite.js +149 -0
  40. package/addon-dist/lib/main/mcp/tools/index.d.ts +26 -0
  41. package/addon-dist/lib/main/mcp/tools/index.js +117 -0
  42. package/addon-dist/lib/main/mcp/tools/listBlueprints.d.ts +7 -0
  43. package/addon-dist/lib/main/mcp/tools/listBlueprints.js +54 -0
  44. package/addon-dist/lib/main/mcp/tools/listServices.d.ts +7 -0
  45. package/addon-dist/lib/main/mcp/tools/listServices.js +112 -0
  46. package/addon-dist/lib/main/mcp/tools/listSites.d.ts +7 -0
  47. package/addon-dist/lib/main/mcp/tools/listSites.js +62 -0
  48. package/addon-dist/lib/main/mcp/tools/openAdminer.d.ts +7 -0
  49. package/addon-dist/lib/main/mcp/tools/openAdminer.js +59 -0
  50. package/addon-dist/lib/main/mcp/tools/openSite.d.ts +7 -0
  51. package/addon-dist/lib/main/mcp/tools/openSite.js +62 -0
  52. package/addon-dist/lib/main/mcp/tools/renameSite.d.ts +7 -0
  53. package/addon-dist/lib/main/mcp/tools/renameSite.js +70 -0
  54. package/addon-dist/lib/main/mcp/tools/restartSite.d.ts +7 -0
  55. package/addon-dist/lib/main/mcp/tools/restartSite.js +56 -0
  56. package/addon-dist/lib/main/mcp/tools/saveBlueprint.d.ts +7 -0
  57. package/addon-dist/lib/main/mcp/tools/saveBlueprint.js +89 -0
  58. package/addon-dist/lib/main/mcp/tools/startSite.d.ts +7 -0
  59. package/addon-dist/lib/main/mcp/tools/startSite.js +54 -0
  60. package/addon-dist/lib/main/mcp/tools/stopSite.d.ts +7 -0
  61. package/addon-dist/lib/main/mcp/tools/stopSite.js +54 -0
  62. package/addon-dist/lib/main/mcp/tools/toggleXdebug.d.ts +7 -0
  63. package/addon-dist/lib/main/mcp/tools/toggleXdebug.js +69 -0
  64. package/addon-dist/lib/main/mcp/tools/trustSsl.d.ts +7 -0
  65. package/addon-dist/lib/main/mcp/tools/trustSsl.js +59 -0
  66. package/addon-dist/lib/main/mcp/tools/wpCli.d.ts +7 -0
  67. package/addon-dist/lib/main/mcp/tools/wpCli.js +110 -0
  68. package/addon-dist/lib/main.d.ts +1 -0
  69. package/addon-dist/lib/main.js +10 -0
  70. package/addon-dist/lib/renderer/index.d.ts +7 -0
  71. package/addon-dist/lib/renderer/index.js +479 -0
  72. package/addon-dist/package.json +73 -0
  73. package/bin/lwp.js +10 -0
  74. package/lib/bootstrap/index.d.ts +98 -0
  75. package/lib/bootstrap/index.js +493 -0
  76. package/lib/bootstrap/paths.d.ts +28 -0
  77. package/lib/bootstrap/paths.js +96 -0
  78. package/lib/client/GraphQLClient.d.ts +38 -0
  79. package/lib/client/GraphQLClient.js +71 -0
  80. package/lib/client/index.d.ts +4 -0
  81. package/lib/client/index.js +10 -0
  82. package/lib/formatters/index.d.ts +75 -0
  83. package/lib/formatters/index.js +139 -0
  84. package/lib/index.d.ts +8 -0
  85. package/lib/index.js +1173 -0
  86. package/package.json +72 -0
@@ -0,0 +1,22 @@
1
+ /**
2
+ * MCP Server Constants
3
+ */
4
+ export declare const MCP_SERVER: {
5
+ readonly NAME: "Local MCP Server";
6
+ readonly VERSION: "1.0.0";
7
+ readonly DEFAULT_PORT: 10789;
8
+ readonly PORT_RANGE: {
9
+ readonly MIN: 10789;
10
+ readonly MAX: 10889;
11
+ };
12
+ };
13
+ export declare const MCP_ENDPOINTS: {
14
+ readonly SSE: "/mcp/sse";
15
+ readonly MESSAGES: "/mcp/messages";
16
+ readonly HEALTH: "/health";
17
+ readonly GRAPHQL: "/graphql";
18
+ };
19
+ export declare const CONNECTION_INFO_FILENAME = "mcp-connection-info.json";
20
+ export declare const TRUSTED_IPS: readonly ["127.0.0.1", "::1", "::ffff:127.0.0.1"];
21
+ export declare const AUTH_TOKEN_LENGTH = 128;
22
+ export declare const REQUEST_TIMEOUT_MS = 30000;
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ /**
3
+ * MCP Server Constants
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.REQUEST_TIMEOUT_MS = exports.AUTH_TOKEN_LENGTH = exports.TRUSTED_IPS = exports.CONNECTION_INFO_FILENAME = exports.MCP_ENDPOINTS = exports.MCP_SERVER = void 0;
7
+ exports.MCP_SERVER = {
8
+ NAME: 'Local MCP Server',
9
+ VERSION: '1.0.0',
10
+ DEFAULT_PORT: 10789,
11
+ PORT_RANGE: {
12
+ MIN: 10789,
13
+ MAX: 10889,
14
+ },
15
+ };
16
+ exports.MCP_ENDPOINTS = {
17
+ SSE: '/mcp/sse',
18
+ MESSAGES: '/mcp/messages',
19
+ HEALTH: '/health',
20
+ GRAPHQL: '/graphql',
21
+ };
22
+ exports.CONNECTION_INFO_FILENAME = 'mcp-connection-info.json';
23
+ exports.TRUSTED_IPS = ['127.0.0.1', '::1', '::ffff:127.0.0.1'];
24
+ exports.AUTH_TOKEN_LENGTH = 128;
25
+ exports.REQUEST_TIMEOUT_MS = 30000;
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbW1vbi9jb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOztHQUVHOzs7QUFFVSxRQUFBLFVBQVUsR0FBRztJQUN4QixJQUFJLEVBQUUsa0JBQWtCO0lBQ3hCLE9BQU8sRUFBRSxPQUFPO0lBQ2hCLFlBQVksRUFBRSxLQUFLO0lBQ25CLFVBQVUsRUFBRTtRQUNWLEdBQUcsRUFBRSxLQUFLO1FBQ1YsR0FBRyxFQUFFLEtBQUs7S0FDWDtDQUNPLENBQUM7QUFFRSxRQUFBLGFBQWEsR0FBRztJQUMzQixHQUFHLEVBQUUsVUFBVTtJQUNmLFFBQVEsRUFBRSxlQUFlO0lBQ3pCLE1BQU0sRUFBRSxTQUFTO0lBQ2pCLE9BQU8sRUFBRSxVQUFVO0NBQ1gsQ0FBQztBQUVFLFFBQUEsd0JBQXdCLEdBQUcsMEJBQTBCLENBQUM7QUFFdEQsUUFBQSxXQUFXLEdBQUcsQ0FBQyxXQUFXLEVBQUUsS0FBSyxFQUFFLGtCQUFrQixDQUFVLENBQUM7QUFFaEUsUUFBQSxpQkFBaUIsR0FBRyxHQUFHLENBQUM7QUFFeEIsUUFBQSxrQkFBa0IsR0FBRyxLQUFLLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIE1DUCBTZXJ2ZXIgQ29uc3RhbnRzXG4gKi9cblxuZXhwb3J0IGNvbnN0IE1DUF9TRVJWRVIgPSB7XG4gIE5BTUU6ICdMb2NhbCBNQ1AgU2VydmVyJyxcbiAgVkVSU0lPTjogJzEuMC4wJyxcbiAgREVGQVVMVF9QT1JUOiAxMDc4OSxcbiAgUE9SVF9SQU5HRToge1xuICAgIE1JTjogMTA3ODksXG4gICAgTUFYOiAxMDg4OSxcbiAgfSxcbn0gYXMgY29uc3Q7XG5cbmV4cG9ydCBjb25zdCBNQ1BfRU5EUE9JTlRTID0ge1xuICBTU0U6ICcvbWNwL3NzZScsXG4gIE1FU1NBR0VTOiAnL21jcC9tZXNzYWdlcycsXG4gIEhFQUxUSDogJy9oZWFsdGgnLFxuICBHUkFQSFFMOiAnL2dyYXBocWwnLFxufSBhcyBjb25zdDtcblxuZXhwb3J0IGNvbnN0IENPTk5FQ1RJT05fSU5GT19GSUxFTkFNRSA9ICdtY3AtY29ubmVjdGlvbi1pbmZvLmpzb24nO1xuXG5leHBvcnQgY29uc3QgVFJVU1RFRF9JUFMgPSBbJzEyNy4wLjAuMScsICc6OjEnLCAnOjpmZmZmOjEyNy4wLjAuMSddIGFzIGNvbnN0O1xuXG5leHBvcnQgY29uc3QgQVVUSF9UT0tFTl9MRU5HVEggPSAxMjg7XG5cbmV4cG9ydCBjb25zdCBSRVFVRVNUX1RJTUVPVVRfTVMgPSAzMDAwMDtcbiJdfQ==
@@ -0,0 +1,68 @@
1
+ /**
2
+ * Theme Utilities for MCP Server Addon
3
+ *
4
+ * Provides theme detection and color management to match Local's theme preference.
5
+ * Local uses CSS classes on document.documentElement: .Theme__Dark or .Theme__Light
6
+ */
7
+ /**
8
+ * Theme color palette for consistent styling across components.
9
+ */
10
+ export interface ThemeColors {
11
+ panelBg: string;
12
+ panelBgSecondary: string;
13
+ panelBgCode: string;
14
+ textPrimary: string;
15
+ textSecondary: string;
16
+ textMuted: string;
17
+ border: string;
18
+ borderLight: string;
19
+ successBg: string;
20
+ successText: string;
21
+ errorBg: string;
22
+ errorText: string;
23
+ infoBg: string;
24
+ infoBorder: string;
25
+ infoText: string;
26
+ inputBg: string;
27
+ inputBorder: string;
28
+ primary: string;
29
+ primaryHover: string;
30
+ }
31
+ /**
32
+ * Light theme color palette.
33
+ */
34
+ declare const LIGHT_COLORS: ThemeColors;
35
+ /**
36
+ * Dark theme color palette.
37
+ */
38
+ declare const DARK_COLORS: ThemeColors;
39
+ /**
40
+ * Check if Local is currently in dark mode.
41
+ *
42
+ * Local sets CSS classes on document.documentElement:
43
+ * - .Theme__Dark for dark mode
44
+ * - .Theme__Light for light mode
45
+ *
46
+ * @returns true if dark mode is active, false otherwise
47
+ */
48
+ export declare function isDarkMode(): boolean;
49
+ /**
50
+ * Get theme-appropriate colors based on current Local theme.
51
+ *
52
+ * @returns ThemeColors object with colors for the current theme
53
+ */
54
+ export declare function getThemeColors(): ThemeColors;
55
+ /**
56
+ * Subscribe to theme changes via MutationObserver.
57
+ *
58
+ * Local toggles CSS classes on document.documentElement when theme changes.
59
+ * This function watches for those changes and calls the callback.
60
+ *
61
+ * @param callback Function called when theme changes
62
+ * @returns Cleanup function to stop observing
63
+ */
64
+ export declare function onThemeChange(callback: () => void): () => void;
65
+ /**
66
+ * Export color constants for direct access if needed.
67
+ */
68
+ export { LIGHT_COLORS, DARK_COLORS };
@@ -0,0 +1,126 @@
1
+ "use strict";
2
+ /**
3
+ * Theme Utilities for MCP Server Addon
4
+ *
5
+ * Provides theme detection and color management to match Local's theme preference.
6
+ * Local uses CSS classes on document.documentElement: .Theme__Dark or .Theme__Light
7
+ */
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.DARK_COLORS = exports.LIGHT_COLORS = void 0;
10
+ exports.isDarkMode = isDarkMode;
11
+ exports.getThemeColors = getThemeColors;
12
+ exports.onThemeChange = onThemeChange;
13
+ /**
14
+ * Light theme color palette.
15
+ */
16
+ const LIGHT_COLORS = {
17
+ // Backgrounds
18
+ panelBg: '#ffffff',
19
+ panelBgSecondary: '#f5f5f5',
20
+ panelBgCode: '#2d2d2d',
21
+ // Text
22
+ textPrimary: '#1a1a1a',
23
+ textSecondary: '#666666',
24
+ textMuted: '#999999',
25
+ // Borders
26
+ border: '#dddddd',
27
+ borderLight: '#eeeeee',
28
+ // Status colors
29
+ successBg: '#d4edda',
30
+ successText: '#28a745',
31
+ errorBg: '#f8d7da',
32
+ errorText: '#dc3545',
33
+ infoBg: '#e7f3ff',
34
+ infoBorder: '#b3d9ff',
35
+ infoText: '#333333',
36
+ // Interactive elements
37
+ inputBg: '#ffffff',
38
+ inputBorder: '#cccccc',
39
+ // Brand/accent colors
40
+ primary: '#007bff',
41
+ primaryHover: '#0056b3',
42
+ };
43
+ exports.LIGHT_COLORS = LIGHT_COLORS;
44
+ /**
45
+ * Dark theme color palette.
46
+ */
47
+ const DARK_COLORS = {
48
+ // Backgrounds
49
+ panelBg: '#2d2d2d',
50
+ panelBgSecondary: '#3d3d3d',
51
+ panelBgCode: '#1a1a1a',
52
+ // Text
53
+ textPrimary: '#e0e0e0',
54
+ textSecondary: '#a0a0a0',
55
+ textMuted: '#808080',
56
+ // Borders
57
+ border: '#4a4a4a',
58
+ borderLight: '#3d3d3d',
59
+ // Status colors
60
+ successBg: '#1a4d2e',
61
+ successText: '#68d391',
62
+ errorBg: '#4d1a1a',
63
+ errorText: '#fc8181',
64
+ infoBg: '#1a3a4d',
65
+ infoBorder: '#2d5a7b',
66
+ infoText: '#e0e0e0',
67
+ // Interactive elements
68
+ inputBg: '#3d3d3d',
69
+ inputBorder: '#5a5a5a',
70
+ // Brand/accent colors
71
+ primary: '#4da3ff',
72
+ primaryHover: '#2d8aff',
73
+ };
74
+ exports.DARK_COLORS = DARK_COLORS;
75
+ /**
76
+ * Check if Local is currently in dark mode.
77
+ *
78
+ * Local sets CSS classes on document.documentElement:
79
+ * - .Theme__Dark for dark mode
80
+ * - .Theme__Light for light mode
81
+ *
82
+ * @returns true if dark mode is active, false otherwise
83
+ */
84
+ function isDarkMode() {
85
+ // Guard for SSR/Node environment
86
+ if (typeof document === 'undefined') {
87
+ return false;
88
+ }
89
+ return document.documentElement.classList.contains('Theme__Dark');
90
+ }
91
+ /**
92
+ * Get theme-appropriate colors based on current Local theme.
93
+ *
94
+ * @returns ThemeColors object with colors for the current theme
95
+ */
96
+ function getThemeColors() {
97
+ return isDarkMode() ? DARK_COLORS : LIGHT_COLORS;
98
+ }
99
+ /**
100
+ * Subscribe to theme changes via MutationObserver.
101
+ *
102
+ * Local toggles CSS classes on document.documentElement when theme changes.
103
+ * This function watches for those changes and calls the callback.
104
+ *
105
+ * @param callback Function called when theme changes
106
+ * @returns Cleanup function to stop observing
107
+ */
108
+ function onThemeChange(callback) {
109
+ // Guard for SSR/Node environment
110
+ if (typeof document === 'undefined') {
111
+ return () => { };
112
+ }
113
+ const observer = new MutationObserver((mutations) => {
114
+ for (const mutation of mutations) {
115
+ if (mutation.attributeName === 'class') {
116
+ callback();
117
+ }
118
+ }
119
+ });
120
+ observer.observe(document.documentElement, {
121
+ attributes: true,
122
+ attributeFilter: ['class'],
123
+ });
124
+ return () => observer.disconnect();
125
+ }
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"theme.js","sourceRoot":"","sources":["../../src/common/theme.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;;AAuHH,gCAOC;AAOD,wCAEC;AAWD,sCAoBC;AAhID;;GAEG;AACH,MAAM,YAAY,GAAgB;IAChC,cAAc;IACd,OAAO,EAAE,SAAS;IAClB,gBAAgB,EAAE,SAAS;IAC3B,WAAW,EAAE,SAAS;IAEtB,OAAO;IACP,WAAW,EAAE,SAAS;IACtB,aAAa,EAAE,SAAS;IACxB,SAAS,EAAE,SAAS;IAEpB,UAAU;IACV,MAAM,EAAE,SAAS;IACjB,WAAW,EAAE,SAAS;IAEtB,gBAAgB;IAChB,SAAS,EAAE,SAAS;IACpB,WAAW,EAAE,SAAS;IACtB,OAAO,EAAE,SAAS;IAClB,SAAS,EAAE,SAAS;IACpB,MAAM,EAAE,SAAS;IACjB,UAAU,EAAE,SAAS;IACrB,QAAQ,EAAE,SAAS;IAEnB,uBAAuB;IACvB,OAAO,EAAE,SAAS;IAClB,WAAW,EAAE,SAAS;IAEtB,sBAAsB;IACtB,OAAO,EAAE,SAAS;IAClB,YAAY,EAAE,SAAS;CACxB,CAAC;AAmGO,oCAAY;AAjGrB;;GAEG;AACH,MAAM,WAAW,GAAgB;IAC/B,cAAc;IACd,OAAO,EAAE,SAAS;IAClB,gBAAgB,EAAE,SAAS;IAC3B,WAAW,EAAE,SAAS;IAEtB,OAAO;IACP,WAAW,EAAE,SAAS;IACtB,aAAa,EAAE,SAAS;IACxB,SAAS,EAAE,SAAS;IAEpB,UAAU;IACV,MAAM,EAAE,SAAS;IACjB,WAAW,EAAE,SAAS;IAEtB,gBAAgB;IAChB,SAAS,EAAE,SAAS;IACpB,WAAW,EAAE,SAAS;IACtB,OAAO,EAAE,SAAS;IAClB,SAAS,EAAE,SAAS;IACpB,MAAM,EAAE,SAAS;IACjB,UAAU,EAAE,SAAS;IACrB,QAAQ,EAAE,SAAS;IAEnB,uBAAuB;IACvB,OAAO,EAAE,SAAS;IAClB,WAAW,EAAE,SAAS;IAEtB,sBAAsB;IACtB,OAAO,EAAE,SAAS;IAClB,YAAY,EAAE,SAAS;CACxB,CAAC;AA+DqB,kCAAW;AA7DlC;;;;;;;;GAQG;AACH,SAAgB,UAAU;IACxB,iCAAiC;IACjC,IAAI,OAAO,QAAQ,KAAK,WAAW,EAAE,CAAC;QACpC,OAAO,KAAK,CAAC;IACf,CAAC;IAED,OAAO,QAAQ,CAAC,eAAe,CAAC,SAAS,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;AACpE,CAAC;AAED;;;;GAIG;AACH,SAAgB,cAAc;IAC5B,OAAO,UAAU,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,YAAY,CAAC;AACnD,CAAC;AAED;;;;;;;;GAQG;AACH,SAAgB,aAAa,CAAC,QAAoB;IAChD,iCAAiC;IACjC,IAAI,OAAO,QAAQ,KAAK,WAAW,EAAE,CAAC;QACpC,OAAO,GAAG,EAAE,GAAE,CAAC,CAAC;IAClB,CAAC;IAED,MAAM,QAAQ,GAAG,IAAI,gBAAgB,CAAC,CAAC,SAAS,EAAE,EAAE;QAClD,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE,CAAC;YACjC,IAAI,QAAQ,CAAC,aAAa,KAAK,OAAO,EAAE,CAAC;gBACvC,QAAQ,EAAE,CAAC;YACb,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,eAAe,EAAE;QACzC,UAAU,EAAE,IAAI;QAChB,eAAe,EAAE,CAAC,OAAO,CAAC;KAC3B,CAAC,CAAC;IAEH,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAC;AACrC,CAAC","sourcesContent":["/**\n * Theme Utilities for MCP Server Addon\n *\n * Provides theme detection and color management to match Local's theme preference.\n * Local uses CSS classes on document.documentElement: .Theme__Dark or .Theme__Light\n */\n\n/**\n * Theme color palette for consistent styling across components.\n */\nexport interface ThemeColors {\n  // Backgrounds\n  panelBg: string;\n  panelBgSecondary: string;\n  panelBgCode: string;\n\n  // Text\n  textPrimary: string;\n  textSecondary: string;\n  textMuted: string;\n\n  // Borders\n  border: string;\n  borderLight: string;\n\n  // Status colors\n  successBg: string;\n  successText: string;\n  errorBg: string;\n  errorText: string;\n  infoBg: string;\n  infoBorder: string;\n  infoText: string;\n\n  // Interactive elements\n  inputBg: string;\n  inputBorder: string;\n\n  // Brand/accent colors\n  primary: string;\n  primaryHover: string;\n}\n\n/**\n * Light theme color palette.\n */\nconst LIGHT_COLORS: ThemeColors = {\n  // Backgrounds\n  panelBg: '#ffffff',\n  panelBgSecondary: '#f5f5f5',\n  panelBgCode: '#2d2d2d',\n\n  // Text\n  textPrimary: '#1a1a1a',\n  textSecondary: '#666666',\n  textMuted: '#999999',\n\n  // Borders\n  border: '#dddddd',\n  borderLight: '#eeeeee',\n\n  // Status colors\n  successBg: '#d4edda',\n  successText: '#28a745',\n  errorBg: '#f8d7da',\n  errorText: '#dc3545',\n  infoBg: '#e7f3ff',\n  infoBorder: '#b3d9ff',\n  infoText: '#333333',\n\n  // Interactive elements\n  inputBg: '#ffffff',\n  inputBorder: '#cccccc',\n\n  // Brand/accent colors\n  primary: '#007bff',\n  primaryHover: '#0056b3',\n};\n\n/**\n * Dark theme color palette.\n */\nconst DARK_COLORS: ThemeColors = {\n  // Backgrounds\n  panelBg: '#2d2d2d',\n  panelBgSecondary: '#3d3d3d',\n  panelBgCode: '#1a1a1a',\n\n  // Text\n  textPrimary: '#e0e0e0',\n  textSecondary: '#a0a0a0',\n  textMuted: '#808080',\n\n  // Borders\n  border: '#4a4a4a',\n  borderLight: '#3d3d3d',\n\n  // Status colors\n  successBg: '#1a4d2e',\n  successText: '#68d391',\n  errorBg: '#4d1a1a',\n  errorText: '#fc8181',\n  infoBg: '#1a3a4d',\n  infoBorder: '#2d5a7b',\n  infoText: '#e0e0e0',\n\n  // Interactive elements\n  inputBg: '#3d3d3d',\n  inputBorder: '#5a5a5a',\n\n  // Brand/accent colors\n  primary: '#4da3ff',\n  primaryHover: '#2d8aff',\n};\n\n/**\n * Check if Local is currently in dark mode.\n *\n * Local sets CSS classes on document.documentElement:\n * - .Theme__Dark for dark mode\n * - .Theme__Light for light mode\n *\n * @returns true if dark mode is active, false otherwise\n */\nexport function isDarkMode(): boolean {\n  // Guard for SSR/Node environment\n  if (typeof document === 'undefined') {\n    return false;\n  }\n\n  return document.documentElement.classList.contains('Theme__Dark');\n}\n\n/**\n * Get theme-appropriate colors based on current Local theme.\n *\n * @returns ThemeColors object with colors for the current theme\n */\nexport function getThemeColors(): ThemeColors {\n  return isDarkMode() ? DARK_COLORS : LIGHT_COLORS;\n}\n\n/**\n * Subscribe to theme changes via MutationObserver.\n *\n * Local toggles CSS classes on document.documentElement when theme changes.\n * This function watches for those changes and calls the callback.\n *\n * @param callback Function called when theme changes\n * @returns Cleanup function to stop observing\n */\nexport function onThemeChange(callback: () => void): () => void {\n  // Guard for SSR/Node environment\n  if (typeof document === 'undefined') {\n    return () => {};\n  }\n\n  const observer = new MutationObserver((mutations) => {\n    for (const mutation of mutations) {\n      if (mutation.attributeName === 'class') {\n        callback();\n      }\n    }\n  });\n\n  observer.observe(document.documentElement, {\n    attributes: true,\n    attributeFilter: ['class'],\n  });\n\n  return () => observer.disconnect();\n}\n\n/**\n * Export color constants for direct access if needed.\n */\nexport { LIGHT_COLORS, DARK_COLORS };\n"]}
@@ -0,0 +1,298 @@
1
+ /**
2
+ * MCP Server Types
3
+ */
4
+ export interface McpConnectionInfo {
5
+ url: string;
6
+ authToken: string;
7
+ port: number;
8
+ version: string;
9
+ tools: string[];
10
+ }
11
+ export interface McpServerConfig {
12
+ port: number;
13
+ authToken?: string;
14
+ }
15
+ export interface McpServerStatus {
16
+ running: boolean;
17
+ port: number;
18
+ uptime: number;
19
+ error?: string;
20
+ }
21
+ export interface McpToolDefinition {
22
+ name: string;
23
+ description: string;
24
+ inputSchema: {
25
+ type: 'object';
26
+ properties: Record<string, unknown>;
27
+ required?: string[];
28
+ };
29
+ }
30
+ export interface McpToolResult {
31
+ content: Array<{
32
+ type: 'text';
33
+ text: string;
34
+ }>;
35
+ isError?: boolean;
36
+ }
37
+ export interface McpRequest {
38
+ jsonrpc: '2.0';
39
+ id: number | string;
40
+ method: string;
41
+ params?: {
42
+ name?: string;
43
+ arguments?: Record<string, unknown>;
44
+ };
45
+ }
46
+ export interface McpResponse {
47
+ jsonrpc: '2.0';
48
+ id: number | string;
49
+ result?: unknown;
50
+ error?: {
51
+ code: number;
52
+ message: string;
53
+ data?: unknown;
54
+ };
55
+ }
56
+ export interface LocalServices {
57
+ siteData: {
58
+ getSites(): any[];
59
+ getSite(id: string): any | undefined;
60
+ updateSite?(siteID: string, site: Partial<{
61
+ name: string;
62
+ xdebugEnabled: boolean;
63
+ }>): void;
64
+ };
65
+ siteProcessManager: {
66
+ start(site: any): Promise<void>;
67
+ stop(site: any): Promise<void>;
68
+ restart(site: any): Promise<void>;
69
+ getSiteStatus(site: any): Promise<string>;
70
+ };
71
+ wpCli: {
72
+ run(site: any, args: string[], opts?: any): Promise<string | null>;
73
+ };
74
+ deleteSite: {
75
+ deleteSite(opts: {
76
+ site: any;
77
+ trashFiles: boolean;
78
+ updateHosts: boolean;
79
+ }): Promise<void>;
80
+ };
81
+ addSite: {
82
+ addSite(opts: {
83
+ newSiteInfo: {
84
+ siteName: string;
85
+ siteDomain: string;
86
+ sitePath?: string;
87
+ multiSite?: 'no' | 'ms-subdir' | 'ms-subdomain';
88
+ phpVersion?: string;
89
+ webServer?: 'nginx' | 'apache';
90
+ database?: 'mysql' | 'mariadb';
91
+ };
92
+ wpCredentials?: {
93
+ adminUsername?: string;
94
+ adminPassword?: string;
95
+ adminEmail?: string;
96
+ };
97
+ goToSite?: boolean;
98
+ }): Promise<any>;
99
+ };
100
+ localLogger: {
101
+ info(message: string, ...args: any[]): void;
102
+ warn(message: string, ...args: any[]): void;
103
+ error(message: string, ...args: any[]): void;
104
+ debug(message: string, ...args: any[]): void;
105
+ };
106
+ browserManager?: {
107
+ openURL(url: string): Promise<void>;
108
+ };
109
+ cloneSite?: (site: any, newName: string) => Promise<any>;
110
+ exportSite?: (site: any, outputPath: string) => Promise<void>;
111
+ blueprints?: {
112
+ getBlueprints(): Promise<any[]>;
113
+ saveBlueprint(site: any, options: {
114
+ name: string;
115
+ description?: string;
116
+ }): Promise<any>;
117
+ };
118
+ adminer?: {
119
+ open(site: any): Promise<void>;
120
+ };
121
+ x509Cert?: {
122
+ trustCert(site: any): Promise<void>;
123
+ };
124
+ siteProvisioner?: {
125
+ swapService(site: any, role: string, serviceName: string, serviceBinVersion: string, restartRouter?: boolean): Promise<void>;
126
+ };
127
+ importSite?: {
128
+ run(settings: {
129
+ importType?: string;
130
+ zipPath: string;
131
+ siteName: string;
132
+ }): Promise<any>;
133
+ };
134
+ lightningServices?: {
135
+ getRegisteredServices(role?: string): Record<string, Record<string, any>>;
136
+ getServices(role?: string): Promise<Record<string, Record<string, any>>>;
137
+ };
138
+ wpeOAuth?: {
139
+ getAccessToken(): Promise<string | undefined>;
140
+ authenticate(): Promise<{
141
+ accessToken: string;
142
+ refreshToken: string;
143
+ idToken: string;
144
+ }>;
145
+ clearTokens(): Promise<void>;
146
+ };
147
+ capi?: {
148
+ getInstallList(): Promise<any[] | undefined>;
149
+ getAccountList(): Promise<any[] | undefined>;
150
+ getCurrentUser(): Promise<{
151
+ id?: string;
152
+ email?: string;
153
+ } | undefined>;
154
+ getInstall(installId: string): Promise<{
155
+ id: string;
156
+ name: string;
157
+ environment?: string;
158
+ cname?: string;
159
+ } | undefined>;
160
+ };
161
+ wpePush?: {
162
+ push(args: {
163
+ includeSql?: boolean;
164
+ wpengineInstallName: string;
165
+ wpengineInstallId: string;
166
+ wpengineSiteId: string;
167
+ wpenginePrimaryDomain: string;
168
+ localSiteId: string;
169
+ environment?: string;
170
+ files?: string[];
171
+ isMagicSync?: boolean;
172
+ }): Promise<void>;
173
+ pushDatabase(args: {
174
+ wpengineInstallName: string;
175
+ localSiteId: string;
176
+ wpenginePrimaryDomain: string;
177
+ }): Promise<void>;
178
+ };
179
+ wpePull?: {
180
+ pull(args: {
181
+ includeSql?: boolean;
182
+ wpengineInstallName: string;
183
+ wpengineInstallId: string;
184
+ wpengineSiteId: string;
185
+ wpenginePrimaryDomain: string;
186
+ localSiteId: string;
187
+ environment?: string;
188
+ files?: string[];
189
+ isMagicSync?: boolean;
190
+ }): Promise<void>;
191
+ pullDatabase(args: {
192
+ wpengineInstallName: string;
193
+ localSiteId: string;
194
+ wpenginePrimaryDomain: string;
195
+ }): Promise<void>;
196
+ };
197
+ connectHistory?: {
198
+ getEvents(siteId: string): Array<{
199
+ remoteInstallName?: string;
200
+ timestamp: number;
201
+ environment: string;
202
+ direction: 'push' | 'pull';
203
+ status?: 'started' | 'failed' | 'completed';
204
+ }>;
205
+ };
206
+ wpeConnectBase?: {
207
+ listModifications(args: {
208
+ connectArgs: {
209
+ wpengineInstallName: string;
210
+ wpengineInstallId: string;
211
+ wpengineSiteId: string;
212
+ wpenginePrimaryDomain: string;
213
+ localSiteId: string;
214
+ };
215
+ direction: 'push' | 'pull';
216
+ includeIgnored?: boolean;
217
+ }): Promise<Array<{
218
+ path: string;
219
+ type: string;
220
+ size: number;
221
+ mtime: number;
222
+ instruction: string;
223
+ }>>;
224
+ };
225
+ backup?: {
226
+ createBackup(args: {
227
+ site: any;
228
+ provider: 'dropbox' | 'googleDrive';
229
+ accountId: string;
230
+ note?: string;
231
+ }): Promise<{
232
+ snapshotId: string;
233
+ timestamp: string;
234
+ }>;
235
+ listBackups(args: {
236
+ site: any;
237
+ provider: 'dropbox' | 'googleDrive';
238
+ accountId: string;
239
+ }): Promise<Array<{
240
+ snapshotId: string;
241
+ timestamp: string;
242
+ note?: string;
243
+ siteDomain: string;
244
+ services: Record<string, string>;
245
+ }>>;
246
+ restoreBackup(args: {
247
+ site: any;
248
+ provider: 'dropbox' | 'googleDrive';
249
+ accountId: string;
250
+ snapshotId: string;
251
+ }): Promise<void>;
252
+ deleteBackup(args: {
253
+ site: any;
254
+ provider: 'dropbox' | 'googleDrive';
255
+ accountId: string;
256
+ snapshotId: string;
257
+ }): Promise<void>;
258
+ downloadZip(args: {
259
+ site: any;
260
+ provider: 'dropbox' | 'googleDrive';
261
+ accountId: string;
262
+ snapshotId: string;
263
+ }): Promise<string>;
264
+ editBackupDescription(args: {
265
+ site: any;
266
+ provider: 'dropbox' | 'googleDrive';
267
+ accountId: string;
268
+ snapshotId: string;
269
+ newDescription: string;
270
+ }): Promise<void>;
271
+ };
272
+ dropbox?: {
273
+ isAuthenticated(accountId: string): Promise<boolean>;
274
+ getAccount(accountId: string): Promise<{
275
+ id: string;
276
+ email: string;
277
+ } | undefined>;
278
+ };
279
+ googleDrive?: {
280
+ isAuthenticated(accountId: string): Promise<boolean>;
281
+ getAccount(accountId: string): Promise<{
282
+ id: string;
283
+ email: string;
284
+ } | undefined>;
285
+ };
286
+ featureFlags?: {
287
+ isFeatureEnabled(flag: string): boolean;
288
+ };
289
+ userData?: {
290
+ get(opts: {
291
+ name: string;
292
+ defaults: any;
293
+ includeCreatedTime?: boolean;
294
+ persistDefaults?: boolean;
295
+ persistDefaultsEncrypted?: boolean;
296
+ }): any;
297
+ };
298
+ }
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ /**
3
+ * MCP Server Types
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/common/types.ts"],"names":[],"mappings":";AAAA;;GAEG","sourcesContent":["/**\n * MCP Server Types\n */\n\nexport interface McpConnectionInfo {\n  url: string;\n  authToken: string;\n  port: number;\n  version: string;\n  tools: string[];\n}\n\nexport interface McpServerConfig {\n  port: number;\n  authToken?: string;\n}\n\nexport interface McpServerStatus {\n  running: boolean;\n  port: number;\n  uptime: number;\n  error?: string;\n}\n\nexport interface McpToolDefinition {\n  name: string;\n  description: string;\n  inputSchema: {\n    type: 'object';\n    properties: Record<string, unknown>;\n    required?: string[];\n  };\n}\n\nexport interface McpToolResult {\n  content: Array<{\n    type: 'text';\n    text: string;\n  }>;\n  isError?: boolean;\n}\n\nexport interface McpRequest {\n  jsonrpc: '2.0';\n  id: number | string;\n  method: string;\n  params?: {\n    name?: string;\n    arguments?: Record<string, unknown>;\n  };\n}\n\nexport interface McpResponse {\n  jsonrpc: '2.0';\n  id: number | string;\n  result?: unknown;\n  error?: {\n    code: number;\n    message: string;\n    data?: unknown;\n  };\n}\n\nexport interface LocalServices {\n  siteData: {\n    getSites(): any[];\n    getSite(id: string): any | undefined;\n    updateSite?(siteID: string, site: Partial<{ name: string; xdebugEnabled: boolean }>): void;\n  };\n  siteProcessManager: {\n    start(site: any): Promise<void>;\n    stop(site: any): Promise<void>;\n    restart(site: any): Promise<void>;\n    getSiteStatus(site: any): Promise<string>;\n  };\n  wpCli: {\n    run(site: any, args: string[], opts?: any): Promise<string | null>;\n  };\n  deleteSite: {\n    deleteSite(opts: { site: any; trashFiles: boolean; updateHosts: boolean }): Promise<void>;\n  };\n  addSite: {\n    addSite(opts: {\n      newSiteInfo: {\n        siteName: string;\n        siteDomain: string;\n        sitePath?: string;\n        multiSite?: 'no' | 'ms-subdir' | 'ms-subdomain';\n        phpVersion?: string;\n        webServer?: 'nginx' | 'apache';\n        database?: 'mysql' | 'mariadb';\n      };\n      wpCredentials?: {\n        adminUsername?: string;\n        adminPassword?: string;\n        adminEmail?: string;\n      };\n      goToSite?: boolean;\n    }): Promise<any>;\n  };\n  localLogger: {\n    info(message: string, ...args: any[]): void;\n    warn(message: string, ...args: any[]): void;\n    error(message: string, ...args: any[]): void;\n    debug(message: string, ...args: any[]): void;\n  };\n  // Optional services for extended functionality\n  browserManager?: {\n    openURL(url: string): Promise<void>;\n  };\n  cloneSite?: (site: any, newName: string) => Promise<any>;\n  exportSite?: (site: any, outputPath: string) => Promise<void>;\n  blueprints?: {\n    getBlueprints(): Promise<any[]>;\n    saveBlueprint(site: any, options: { name: string; description?: string }): Promise<any>;\n  };\n  // Phase 8 services\n  adminer?: {\n    open(site: any): Promise<void>;\n  };\n  x509Cert?: {\n    trustCert(site: any): Promise<void>;\n  };\n  siteProvisioner?: {\n    swapService(\n      site: any,\n      role: string,\n      serviceName: string,\n      serviceBinVersion: string,\n      restartRouter?: boolean\n    ): Promise<void>;\n  };\n  importSite?: {\n    run(settings: { importType?: string; zipPath: string; siteName: string }): Promise<any>;\n  };\n  // Phase 9 services\n  lightningServices?: {\n    getRegisteredServices(role?: string): Record<string, Record<string, any>>;\n    getServices(role?: string): Promise<Record<string, Record<string, any>>>;\n  };\n  // Phase 11: WP Engine Connect services\n  wpeOAuth?: {\n    getAccessToken(): Promise<string | undefined>;\n    authenticate(): Promise<{ accessToken: string; refreshToken: string; idToken: string }>;\n    clearTokens(): Promise<void>;\n  };\n  capi?: {\n    getInstallList(): Promise<any[] | undefined>;\n    getAccountList(): Promise<any[] | undefined>;\n    getCurrentUser(): Promise<{ id?: string; email?: string } | undefined>;\n    getInstall(\n      installId: string\n    ): Promise<{ id: string; name: string; environment?: string; cname?: string } | undefined>;\n  };\n  // Phase 11c: Sync services\n  wpePush?: {\n    push(args: {\n      includeSql?: boolean;\n      wpengineInstallName: string;\n      wpengineInstallId: string;\n      wpengineSiteId: string;\n      wpenginePrimaryDomain: string;\n      localSiteId: string;\n      environment?: string;\n      files?: string[];\n      isMagicSync?: boolean;\n    }): Promise<void>;\n    pushDatabase(args: {\n      wpengineInstallName: string;\n      localSiteId: string;\n      wpenginePrimaryDomain: string;\n    }): Promise<void>;\n  };\n  wpePull?: {\n    pull(args: {\n      includeSql?: boolean;\n      wpengineInstallName: string;\n      wpengineInstallId: string;\n      wpengineSiteId: string;\n      wpenginePrimaryDomain: string;\n      localSiteId: string;\n      environment?: string;\n      files?: string[];\n      isMagicSync?: boolean;\n    }): Promise<void>;\n    pullDatabase(args: {\n      wpengineInstallName: string;\n      localSiteId: string;\n      wpenginePrimaryDomain: string;\n    }): Promise<void>;\n  };\n  connectHistory?: {\n    getEvents(siteId: string): Array<{\n      remoteInstallName?: string;\n      timestamp: number;\n      environment: string;\n      direction: 'push' | 'pull';\n      status?: 'started' | 'failed' | 'completed';\n    }>;\n  };\n  // Magic Sync change detection\n  wpeConnectBase?: {\n    listModifications(args: {\n      connectArgs: {\n        wpengineInstallName: string;\n        wpengineInstallId: string;\n        wpengineSiteId: string;\n        wpenginePrimaryDomain: string;\n        localSiteId: string;\n      };\n      direction: 'push' | 'pull';\n      includeIgnored?: boolean;\n    }): Promise<\n      Array<{\n        path: string;\n        type: string;\n        size: number;\n        mtime: number;\n        instruction: string;\n      }>\n    >;\n  };\n  // Phase 10: Cloud Backup services\n  backup?: {\n    createBackup(args: {\n      site: any;\n      provider: 'dropbox' | 'googleDrive';\n      accountId: string;\n      note?: string;\n    }): Promise<{ snapshotId: string; timestamp: string }>;\n    listBackups(args: {\n      site: any;\n      provider: 'dropbox' | 'googleDrive';\n      accountId: string;\n    }): Promise<\n      Array<{\n        snapshotId: string;\n        timestamp: string;\n        note?: string;\n        siteDomain: string;\n        services: Record<string, string>;\n      }>\n    >;\n    restoreBackup(args: {\n      site: any;\n      provider: 'dropbox' | 'googleDrive';\n      accountId: string;\n      snapshotId: string;\n    }): Promise<void>;\n    deleteBackup(args: {\n      site: any;\n      provider: 'dropbox' | 'googleDrive';\n      accountId: string;\n      snapshotId: string;\n    }): Promise<void>;\n    downloadZip(args: {\n      site: any;\n      provider: 'dropbox' | 'googleDrive';\n      accountId: string;\n      snapshotId: string;\n    }): Promise<string>; // Returns file path\n    editBackupDescription(args: {\n      site: any;\n      provider: 'dropbox' | 'googleDrive';\n      accountId: string;\n      snapshotId: string;\n      newDescription: string;\n    }): Promise<void>;\n  };\n  dropbox?: {\n    isAuthenticated(accountId: string): Promise<boolean>;\n    getAccount(accountId: string): Promise<{ id: string; email: string } | undefined>;\n  };\n  googleDrive?: {\n    isAuthenticated(accountId: string): Promise<boolean>;\n    getAccount(accountId: string): Promise<{ id: string; email: string } | undefined>;\n  };\n  featureFlags?: {\n    isFeatureEnabled(flag: string): boolean;\n  };\n  // UserData for reading cloud storage accounts\n  userData?: {\n    get(opts: {\n      name: string;\n      defaults: any;\n      includeCreatedTime?: boolean;\n      persistDefaults?: boolean;\n      persistDefaultsEncrypted?: boolean;\n    }): any;\n  };\n}\n"]}
@@ -0,0 +1,25 @@
1
+ /**
2
+ * Connection Info Manager
3
+ * Handles saving/loading MCP connection info for external tools
4
+ */
5
+ import { McpConnectionInfo } from '../../common/types';
6
+ export declare class ConnectionInfoManager {
7
+ private logger;
8
+ constructor(logger: any);
9
+ /**
10
+ * Get platform-specific path for connection info file
11
+ */
12
+ getFilePath(): string;
13
+ /**
14
+ * Save connection info to file
15
+ */
16
+ save(info: McpConnectionInfo): Promise<void>;
17
+ /**
18
+ * Load connection info from file
19
+ */
20
+ load(): Promise<McpConnectionInfo | null>;
21
+ /**
22
+ * Delete connection info file
23
+ */
24
+ delete(): Promise<void>;
25
+ }