@dollhousemcp/mcp-server 1.4.0 → 1.4.2
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/README.md +54 -9
- package/dist/config/updateConfig.d.ts +84 -0
- package/dist/config/updateConfig.d.ts.map +1 -0
- package/dist/config/updateConfig.js +148 -0
- package/dist/generated/version.d.ts +9 -0
- package/dist/generated/version.d.ts.map +1 -0
- package/dist/generated/version.js +9 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +34 -6
- package/dist/portfolio/DefaultElementProvider.d.ts +78 -0
- package/dist/portfolio/DefaultElementProvider.d.ts.map +1 -0
- package/dist/portfolio/DefaultElementProvider.js +398 -0
- package/dist/portfolio/PortfolioManager.d.ts +7 -0
- package/dist/portfolio/PortfolioManager.d.ts.map +1 -1
- package/dist/portfolio/PortfolioManager.js +44 -3
- package/dist/security/commandValidator.d.ts.map +1 -1
- package/dist/security/commandValidator.js +5 -2
- package/dist/security/securityMonitor.d.ts +2 -1
- package/dist/security/securityMonitor.d.ts.map +1 -1
- package/dist/security/securityMonitor.js +1 -1
- package/dist/server/tools/UpdateTools.d.ts.map +1 -1
- package/dist/server/tools/UpdateTools.js +22 -1
- package/dist/server/types.d.ts +1 -0
- package/dist/server/types.d.ts.map +1 -1
- package/dist/server/types.js +1 -1
- package/dist/update/BackupManager.d.ts +17 -0
- package/dist/update/BackupManager.d.ts.map +1 -1
- package/dist/update/BackupManager.js +112 -3
- package/dist/update/UpdateManager.d.ts +19 -0
- package/dist/update/UpdateManager.d.ts.map +1 -1
- package/dist/update/UpdateManager.js +485 -15
- package/dist/update/VersionManager.d.ts +1 -1
- package/dist/update/VersionManager.d.ts.map +1 -1
- package/dist/update/VersionManager.js +62 -15
- package/dist/utils/fileOperations.d.ts +83 -0
- package/dist/utils/fileOperations.d.ts.map +1 -0
- package/dist/utils/fileOperations.js +291 -0
- package/dist/utils/installation.d.ts +30 -0
- package/dist/utils/installation.d.ts.map +1 -0
- package/dist/utils/installation.js +160 -0
- package/package.json +3 -1
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Installation detection utilities
|
|
3
|
+
* Determines whether the application is running from npm or git installation
|
|
4
|
+
*/
|
|
5
|
+
import * as fs from 'fs';
|
|
6
|
+
import * as path from 'path';
|
|
7
|
+
import { fileURLToPath } from 'url';
|
|
8
|
+
import { logger } from './logger.js';
|
|
9
|
+
import { UpdateConfigManager } from '../config/updateConfig.js';
|
|
10
|
+
export class InstallationDetector {
|
|
11
|
+
static cachedType = null;
|
|
12
|
+
// Maximum directory levels to search upward for .git directory
|
|
13
|
+
static get MAX_SEARCH_DEPTH() {
|
|
14
|
+
return UpdateConfigManager.getInstance().getMaxSearchDepth();
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Detect the installation type (npm global, git clone, or unknown)
|
|
18
|
+
*/
|
|
19
|
+
static getInstallationType() {
|
|
20
|
+
// Return cached result if available
|
|
21
|
+
if (this.cachedType !== null) {
|
|
22
|
+
return this.cachedType;
|
|
23
|
+
}
|
|
24
|
+
try {
|
|
25
|
+
// Get the directory where this file is located
|
|
26
|
+
const currentFileUrl = import.meta.url;
|
|
27
|
+
const currentFilePath = fileURLToPath(currentFileUrl);
|
|
28
|
+
let currentDir = path.dirname(currentFilePath);
|
|
29
|
+
// Resolve symlinks to get the real path
|
|
30
|
+
try {
|
|
31
|
+
currentDir = fs.realpathSync(currentDir);
|
|
32
|
+
}
|
|
33
|
+
catch (error) {
|
|
34
|
+
// If realpath fails, continue with original path
|
|
35
|
+
logger.debug('[InstallationDetector] Could not resolve real path, using original');
|
|
36
|
+
}
|
|
37
|
+
// Check if we're in a node_modules directory (npm installation)
|
|
38
|
+
// Use path separator to ensure we match the exact package name
|
|
39
|
+
const npmPattern = path.sep + path.join('node_modules', '@dollhousemcp', 'mcp-server') + path.sep;
|
|
40
|
+
if (currentDir.includes(npmPattern)) {
|
|
41
|
+
logger.debug('[InstallationDetector] Detected npm installation');
|
|
42
|
+
this.cachedType = 'npm';
|
|
43
|
+
return 'npm';
|
|
44
|
+
}
|
|
45
|
+
// Check for .git directory (git installation)
|
|
46
|
+
// Search up from current directory
|
|
47
|
+
let searchDir = currentDir;
|
|
48
|
+
for (let i = 0; i < this.MAX_SEARCH_DEPTH; i++) {
|
|
49
|
+
const gitDir = path.join(searchDir, '.git');
|
|
50
|
+
try {
|
|
51
|
+
if (fs.existsSync(gitDir) && fs.statSync(gitDir).isDirectory()) {
|
|
52
|
+
logger.debug('[InstallationDetector] Detected git installation');
|
|
53
|
+
this.cachedType = 'git';
|
|
54
|
+
return 'git';
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
catch (error) {
|
|
58
|
+
// Ignore errors and continue searching
|
|
59
|
+
}
|
|
60
|
+
const parentDir = path.dirname(searchDir);
|
|
61
|
+
if (parentDir === searchDir) {
|
|
62
|
+
// Reached root directory
|
|
63
|
+
break;
|
|
64
|
+
}
|
|
65
|
+
searchDir = parentDir;
|
|
66
|
+
}
|
|
67
|
+
logger.warn('[InstallationDetector] Could not determine installation type');
|
|
68
|
+
this.cachedType = 'unknown';
|
|
69
|
+
return 'unknown';
|
|
70
|
+
}
|
|
71
|
+
catch (error) {
|
|
72
|
+
logger.error('[InstallationDetector] Error detecting installation type:', error);
|
|
73
|
+
this.cachedType = 'unknown';
|
|
74
|
+
return 'unknown';
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Get the npm global installation path if running from npm
|
|
79
|
+
*/
|
|
80
|
+
static getNpmGlobalPath() {
|
|
81
|
+
if (this.getInstallationType() !== 'npm') {
|
|
82
|
+
return null;
|
|
83
|
+
}
|
|
84
|
+
try {
|
|
85
|
+
const currentFileUrl = import.meta.url;
|
|
86
|
+
const currentFilePath = fileURLToPath(currentFileUrl);
|
|
87
|
+
let currentDir = path.dirname(currentFilePath);
|
|
88
|
+
// Find the root of the npm package
|
|
89
|
+
while (currentDir.includes('node_modules/@dollhousemcp/mcp-server')) {
|
|
90
|
+
const packageJsonPath = path.join(currentDir, 'package.json');
|
|
91
|
+
if (fs.existsSync(packageJsonPath)) {
|
|
92
|
+
return currentDir;
|
|
93
|
+
}
|
|
94
|
+
const parentDir = path.dirname(currentDir);
|
|
95
|
+
if (parentDir === currentDir)
|
|
96
|
+
break;
|
|
97
|
+
currentDir = parentDir;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
catch (error) {
|
|
101
|
+
logger.error('[InstallationDetector] Error finding npm global path:', error);
|
|
102
|
+
}
|
|
103
|
+
return null;
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* Get the git repository root path if running from git
|
|
107
|
+
*/
|
|
108
|
+
static getGitRepositoryPath() {
|
|
109
|
+
if (this.getInstallationType() !== 'git') {
|
|
110
|
+
return null;
|
|
111
|
+
}
|
|
112
|
+
try {
|
|
113
|
+
const currentFileUrl = import.meta.url;
|
|
114
|
+
const currentFilePath = fileURLToPath(currentFileUrl);
|
|
115
|
+
let currentDir = path.dirname(currentFilePath);
|
|
116
|
+
// Search up for .git directory
|
|
117
|
+
for (let i = 0; i < 10; i++) {
|
|
118
|
+
const gitDir = path.join(currentDir, '.git');
|
|
119
|
+
if (fs.existsSync(gitDir) && fs.statSync(gitDir).isDirectory()) {
|
|
120
|
+
return currentDir;
|
|
121
|
+
}
|
|
122
|
+
const parentDir = path.dirname(currentDir);
|
|
123
|
+
if (parentDir === currentDir)
|
|
124
|
+
break;
|
|
125
|
+
currentDir = parentDir;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
catch (error) {
|
|
129
|
+
logger.error('[InstallationDetector] Error finding git repository path:', error);
|
|
130
|
+
}
|
|
131
|
+
return null;
|
|
132
|
+
}
|
|
133
|
+
/**
|
|
134
|
+
* Get a human-readable description of the installation
|
|
135
|
+
*/
|
|
136
|
+
static getInstallationDescription() {
|
|
137
|
+
const type = this.getInstallationType();
|
|
138
|
+
switch (type) {
|
|
139
|
+
case 'npm':
|
|
140
|
+
const npmPath = this.getNpmGlobalPath();
|
|
141
|
+
return npmPath
|
|
142
|
+
? `npm global installation at ${npmPath}`
|
|
143
|
+
: 'npm global installation';
|
|
144
|
+
case 'git':
|
|
145
|
+
const gitPath = this.getGitRepositoryPath();
|
|
146
|
+
return gitPath
|
|
147
|
+
? `git installation at ${gitPath}`
|
|
148
|
+
: 'git installation';
|
|
149
|
+
default:
|
|
150
|
+
return 'unknown installation type';
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* Clear the cached installation type (mainly for testing)
|
|
155
|
+
*/
|
|
156
|
+
static clearCache() {
|
|
157
|
+
this.cachedType = null;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"installation.js","sourceRoot":"","sources":["../../src/utils/installation.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,MAAM,IAAI,CAAC;AACzB,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,EAAE,aAAa,EAAE,MAAM,KAAK,CAAC;AACpC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAIhE,MAAM,OAAO,oBAAoB;IACvB,MAAM,CAAC,UAAU,GAA4B,IAAI,CAAC;IAE1D,+DAA+D;IACvD,MAAM,KAAK,gBAAgB;QACjC,OAAO,mBAAmB,CAAC,WAAW,EAAE,CAAC,iBAAiB,EAAE,CAAC;IAC/D,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,mBAAmB;QACxB,oCAAoC;QACpC,IAAI,IAAI,CAAC,UAAU,KAAK,IAAI,EAAE,CAAC;YAC7B,OAAO,IAAI,CAAC,UAAU,CAAC;QACzB,CAAC;QAED,IAAI,CAAC;YACH,+CAA+C;YAC/C,MAAM,cAAc,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC;YACvC,MAAM,eAAe,GAAG,aAAa,CAAC,cAAc,CAAC,CAAC;YACtD,IAAI,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;YAE/C,wCAAwC;YACxC,IAAI,CAAC;gBACH,UAAU,GAAG,EAAE,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;YAC3C,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,iDAAiD;gBACjD,MAAM,CAAC,KAAK,CAAC,oEAAoE,CAAC,CAAC;YACrF,CAAC;YAED,gEAAgE;YAChE,+DAA+D;YAC/D,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,eAAe,EAAE,YAAY,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC;YAClG,IAAI,UAAU,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;gBACpC,MAAM,CAAC,KAAK,CAAC,kDAAkD,CAAC,CAAC;gBACjE,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;gBACxB,OAAO,KAAK,CAAC;YACf,CAAC;YAED,8CAA8C;YAC9C,mCAAmC;YACnC,IAAI,SAAS,GAAG,UAAU,CAAC;YAC3B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC/C,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;gBAC5C,IAAI,CAAC;oBACH,IAAI,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC;wBAC/D,MAAM,CAAC,KAAK,CAAC,kDAAkD,CAAC,CAAC;wBACjE,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;wBACxB,OAAO,KAAK,CAAC;oBACf,CAAC;gBACH,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBACf,uCAAuC;gBACzC,CAAC;gBAED,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;gBAC1C,IAAI,SAAS,KAAK,SAAS,EAAE,CAAC;oBAC5B,yBAAyB;oBACzB,MAAM;gBACR,CAAC;gBACD,SAAS,GAAG,SAAS,CAAC;YACxB,CAAC;YAED,MAAM,CAAC,IAAI,CAAC,8DAA8D,CAAC,CAAC;YAC5E,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;YAC5B,OAAO,SAAS,CAAC;QACnB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,2DAA2D,EAAE,KAAK,CAAC,CAAC;YACjF,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;YAC5B,OAAO,SAAS,CAAC;QACnB,CAAC;IACH,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,gBAAgB;QACrB,IAAI,IAAI,CAAC,mBAAmB,EAAE,KAAK,KAAK,EAAE,CAAC;YACzC,OAAO,IAAI,CAAC;QACd,CAAC;QAED,IAAI,CAAC;YACH,MAAM,cAAc,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC;YACvC,MAAM,eAAe,GAAG,aAAa,CAAC,cAAc,CAAC,CAAC;YACtD,IAAI,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;YAE/C,mCAAmC;YACnC,OAAO,UAAU,CAAC,QAAQ,CAAC,uCAAuC,CAAC,EAAE,CAAC;gBACpE,MAAM,eAAe,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,cAAc,CAAC,CAAC;gBAC9D,IAAI,EAAE,CAAC,UAAU,CAAC,eAAe,CAAC,EAAE,CAAC;oBACnC,OAAO,UAAU,CAAC;gBACpB,CAAC;gBACD,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;gBAC3C,IAAI,SAAS,KAAK,UAAU;oBAAE,MAAM;gBACpC,UAAU,GAAG,SAAS,CAAC;YACzB,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,uDAAuD,EAAE,KAAK,CAAC,CAAC;QAC/E,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,oBAAoB;QACzB,IAAI,IAAI,CAAC,mBAAmB,EAAE,KAAK,KAAK,EAAE,CAAC;YACzC,OAAO,IAAI,CAAC;QACd,CAAC;QAED,IAAI,CAAC;YACH,MAAM,cAAc,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC;YACvC,MAAM,eAAe,GAAG,aAAa,CAAC,cAAc,CAAC,CAAC;YACtD,IAAI,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;YAE/C,+BAA+B;YAC/B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC5B,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;gBAC7C,IAAI,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC;oBAC/D,OAAO,UAAU,CAAC;gBACpB,CAAC;gBAED,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;gBAC3C,IAAI,SAAS,KAAK,UAAU;oBAAE,MAAM;gBACpC,UAAU,GAAG,SAAS,CAAC;YACzB,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,2DAA2D,EAAE,KAAK,CAAC,CAAC;QACnF,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,0BAA0B;QAC/B,MAAM,IAAI,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAExC,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,KAAK;gBACR,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBACxC,OAAO,OAAO;oBACZ,CAAC,CAAC,8BAA8B,OAAO,EAAE;oBACzC,CAAC,CAAC,yBAAyB,CAAC;YAEhC,KAAK,KAAK;gBACR,MAAM,OAAO,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;gBAC5C,OAAO,OAAO;oBACZ,CAAC,CAAC,uBAAuB,OAAO,EAAE;oBAClC,CAAC,CAAC,kBAAkB,CAAC;YAEzB;gBACE,OAAO,2BAA2B,CAAC;QACvC,CAAC;IACH,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,UAAU;QACf,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC","sourcesContent":["/**\n * Installation detection utilities\n * Determines whether the application is running from npm or git installation\n */\n\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { fileURLToPath } from 'url';\nimport { logger } from './logger.js';\nimport { UpdateConfigManager } from '../config/updateConfig.js';\n\nexport type InstallationType = 'npm' | 'git' | 'unknown';\n\nexport class InstallationDetector {\n  private static cachedType: InstallationType | null = null;\n  \n  // Maximum directory levels to search upward for .git directory\n  private static get MAX_SEARCH_DEPTH(): number {\n    return UpdateConfigManager.getInstance().getMaxSearchDepth();\n  }\n  \n  /**\n   * Detect the installation type (npm global, git clone, or unknown)\n   */\n  static getInstallationType(): InstallationType {\n    // Return cached result if available\n    if (this.cachedType !== null) {\n      return this.cachedType;\n    }\n    \n    try {\n      // Get the directory where this file is located\n      const currentFileUrl = import.meta.url;\n      const currentFilePath = fileURLToPath(currentFileUrl);\n      let currentDir = path.dirname(currentFilePath);\n      \n      // Resolve symlinks to get the real path\n      try {\n        currentDir = fs.realpathSync(currentDir);\n      } catch (error) {\n        // If realpath fails, continue with original path\n        logger.debug('[InstallationDetector] Could not resolve real path, using original');\n      }\n      \n      // Check if we're in a node_modules directory (npm installation)\n      // Use path separator to ensure we match the exact package name\n      const npmPattern = path.sep + path.join('node_modules', '@dollhousemcp', 'mcp-server') + path.sep;\n      if (currentDir.includes(npmPattern)) {\n        logger.debug('[InstallationDetector] Detected npm installation');\n        this.cachedType = 'npm';\n        return 'npm';\n      }\n      \n      // Check for .git directory (git installation)\n      // Search up from current directory\n      let searchDir = currentDir;\n      for (let i = 0; i < this.MAX_SEARCH_DEPTH; i++) {\n        const gitDir = path.join(searchDir, '.git');\n        try {\n          if (fs.existsSync(gitDir) && fs.statSync(gitDir).isDirectory()) {\n            logger.debug('[InstallationDetector] Detected git installation');\n            this.cachedType = 'git';\n            return 'git';\n          }\n        } catch (error) {\n          // Ignore errors and continue searching\n        }\n        \n        const parentDir = path.dirname(searchDir);\n        if (parentDir === searchDir) {\n          // Reached root directory\n          break;\n        }\n        searchDir = parentDir;\n      }\n      \n      logger.warn('[InstallationDetector] Could not determine installation type');\n      this.cachedType = 'unknown';\n      return 'unknown';\n    } catch (error) {\n      logger.error('[InstallationDetector] Error detecting installation type:', error);\n      this.cachedType = 'unknown';\n      return 'unknown';\n    }\n  }\n  \n  /**\n   * Get the npm global installation path if running from npm\n   */\n  static getNpmGlobalPath(): string | null {\n    if (this.getInstallationType() !== 'npm') {\n      return null;\n    }\n    \n    try {\n      const currentFileUrl = import.meta.url;\n      const currentFilePath = fileURLToPath(currentFileUrl);\n      let currentDir = path.dirname(currentFilePath);\n      \n      // Find the root of the npm package\n      while (currentDir.includes('node_modules/@dollhousemcp/mcp-server')) {\n        const packageJsonPath = path.join(currentDir, 'package.json');\n        if (fs.existsSync(packageJsonPath)) {\n          return currentDir;\n        }\n        const parentDir = path.dirname(currentDir);\n        if (parentDir === currentDir) break;\n        currentDir = parentDir;\n      }\n    } catch (error) {\n      logger.error('[InstallationDetector] Error finding npm global path:', error);\n    }\n    \n    return null;\n  }\n  \n  /**\n   * Get the git repository root path if running from git\n   */\n  static getGitRepositoryPath(): string | null {\n    if (this.getInstallationType() !== 'git') {\n      return null;\n    }\n    \n    try {\n      const currentFileUrl = import.meta.url;\n      const currentFilePath = fileURLToPath(currentFileUrl);\n      let currentDir = path.dirname(currentFilePath);\n      \n      // Search up for .git directory\n      for (let i = 0; i < 10; i++) {\n        const gitDir = path.join(currentDir, '.git');\n        if (fs.existsSync(gitDir) && fs.statSync(gitDir).isDirectory()) {\n          return currentDir;\n        }\n        \n        const parentDir = path.dirname(currentDir);\n        if (parentDir === currentDir) break;\n        currentDir = parentDir;\n      }\n    } catch (error) {\n      logger.error('[InstallationDetector] Error finding git repository path:', error);\n    }\n    \n    return null;\n  }\n  \n  /**\n   * Get a human-readable description of the installation\n   */\n  static getInstallationDescription(): string {\n    const type = this.getInstallationType();\n    \n    switch (type) {\n      case 'npm':\n        const npmPath = this.getNpmGlobalPath();\n        return npmPath \n          ? `npm global installation at ${npmPath}`\n          : 'npm global installation';\n          \n      case 'git':\n        const gitPath = this.getGitRepositoryPath();\n        return gitPath\n          ? `git installation at ${gitPath}`\n          : 'git installation';\n          \n      default:\n        return 'unknown installation type';\n    }\n  }\n  \n  /**\n   * Clear the cached installation type (mainly for testing)\n   */\n  static clearCache(): void {\n    this.cachedType = null;\n  }\n}"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dollhousemcp/mcp-server",
|
|
3
|
-
"version": "1.4.
|
|
3
|
+
"version": "1.4.2",
|
|
4
4
|
"description": "DollhouseMCP - A Model Context Protocol (MCP) server that enables dynamic AI persona management from markdown files, allowing Claude and other compatible AI assistants to activate and switch between different behavioral personas.",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -9,12 +9,14 @@
|
|
|
9
9
|
"mcp-server": "dist/index.js"
|
|
10
10
|
},
|
|
11
11
|
"scripts": {
|
|
12
|
+
"prebuild": "node scripts/generate-version.js",
|
|
12
13
|
"build": "tsc",
|
|
13
14
|
"start": "node dist/index.js",
|
|
14
15
|
"dev": "tsx watch src/index.ts",
|
|
15
16
|
"clean": "rm -rf dist",
|
|
16
17
|
"rebuild": "npm run clean && npm run build",
|
|
17
18
|
"setup": "npm install && npm run build",
|
|
19
|
+
"prepublishOnly": "BUILD_TYPE=npm npm run build",
|
|
18
20
|
"update:check": "echo 'Use check_for_updates MCP tool for interactive update checking'",
|
|
19
21
|
"update:pull": "git pull origin main && npm install && npm run build",
|
|
20
22
|
"update:backup": "cp -r . .backup-$(date +%s)",
|