@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.
- package/addon-dist/bin/mcp-stdio.js +2808 -0
- package/addon-dist/lib/common/constants.d.ts +22 -0
- package/addon-dist/lib/common/constants.js +26 -0
- package/addon-dist/lib/common/theme.d.ts +68 -0
- package/addon-dist/lib/common/theme.js +126 -0
- package/addon-dist/lib/common/types.d.ts +298 -0
- package/addon-dist/lib/common/types.js +6 -0
- package/addon-dist/lib/main/config/ConnectionInfo.d.ts +25 -0
- package/addon-dist/lib/main/config/ConnectionInfo.js +82 -0
- package/addon-dist/lib/main/index.d.ts +12 -0
- package/addon-dist/lib/main/index.js +3322 -0
- package/addon-dist/lib/main/mcp/McpAuth.d.ts +37 -0
- package/addon-dist/lib/main/mcp/McpAuth.js +87 -0
- package/addon-dist/lib/main/mcp/McpServer.d.ts +67 -0
- package/addon-dist/lib/main/mcp/McpServer.js +343 -0
- package/addon-dist/lib/main/mcp/tools/changePhpVersion.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/changePhpVersion.js +81 -0
- package/addon-dist/lib/main/mcp/tools/cloneSite.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/cloneSite.js +66 -0
- package/addon-dist/lib/main/mcp/tools/createSite.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/createSite.js +137 -0
- package/addon-dist/lib/main/mcp/tools/deleteSite.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/deleteSite.js +72 -0
- package/addon-dist/lib/main/mcp/tools/exportDatabase.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/exportDatabase.js +72 -0
- package/addon-dist/lib/main/mcp/tools/exportSite.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/exportSite.js +103 -0
- package/addon-dist/lib/main/mcp/tools/getLocalInfo.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/getLocalInfo.js +72 -0
- package/addon-dist/lib/main/mcp/tools/getSite.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/getSite.js +68 -0
- package/addon-dist/lib/main/mcp/tools/getSiteLogs.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/getSiteLogs.js +149 -0
- package/addon-dist/lib/main/mcp/tools/helpers.d.ts +59 -0
- package/addon-dist/lib/main/mcp/tools/helpers.js +179 -0
- package/addon-dist/lib/main/mcp/tools/importDatabase.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/importDatabase.js +109 -0
- package/addon-dist/lib/main/mcp/tools/importSite.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/importSite.js +149 -0
- package/addon-dist/lib/main/mcp/tools/index.d.ts +26 -0
- package/addon-dist/lib/main/mcp/tools/index.js +117 -0
- package/addon-dist/lib/main/mcp/tools/listBlueprints.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/listBlueprints.js +54 -0
- package/addon-dist/lib/main/mcp/tools/listServices.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/listServices.js +112 -0
- package/addon-dist/lib/main/mcp/tools/listSites.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/listSites.js +62 -0
- package/addon-dist/lib/main/mcp/tools/openAdminer.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/openAdminer.js +59 -0
- package/addon-dist/lib/main/mcp/tools/openSite.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/openSite.js +62 -0
- package/addon-dist/lib/main/mcp/tools/renameSite.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/renameSite.js +70 -0
- package/addon-dist/lib/main/mcp/tools/restartSite.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/restartSite.js +56 -0
- package/addon-dist/lib/main/mcp/tools/saveBlueprint.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/saveBlueprint.js +89 -0
- package/addon-dist/lib/main/mcp/tools/startSite.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/startSite.js +54 -0
- package/addon-dist/lib/main/mcp/tools/stopSite.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/stopSite.js +54 -0
- package/addon-dist/lib/main/mcp/tools/toggleXdebug.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/toggleXdebug.js +69 -0
- package/addon-dist/lib/main/mcp/tools/trustSsl.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/trustSsl.js +59 -0
- package/addon-dist/lib/main/mcp/tools/wpCli.d.ts +7 -0
- package/addon-dist/lib/main/mcp/tools/wpCli.js +110 -0
- package/addon-dist/lib/main.d.ts +1 -0
- package/addon-dist/lib/main.js +10 -0
- package/addon-dist/lib/renderer/index.d.ts +7 -0
- package/addon-dist/lib/renderer/index.js +479 -0
- package/addon-dist/package.json +73 -0
- package/bin/lwp.js +10 -0
- package/lib/bootstrap/index.d.ts +98 -0
- package/lib/bootstrap/index.js +493 -0
- package/lib/bootstrap/paths.d.ts +28 -0
- package/lib/bootstrap/paths.js +96 -0
- package/lib/client/GraphQLClient.d.ts +38 -0
- package/lib/client/GraphQLClient.js +71 -0
- package/lib/client/index.d.ts +4 -0
- package/lib/client/index.js +10 -0
- package/lib/formatters/index.d.ts +75 -0
- package/lib/formatters/index.js +139 -0
- package/lib/index.d.ts +8 -0
- package/lib/index.js +1173 -0
- 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
|
+
}
|