@dollhousemcp/mcp-server 1.9.0 → 1.9.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.
Files changed (33) hide show
  1. package/CHANGELOG.md +47 -0
  2. package/README.github.md +68 -33
  3. package/README.md +3 -3
  4. package/README.md.backup +964 -52
  5. package/README.npm.md +3 -3
  6. package/dist/generated/version.d.ts +2 -2
  7. package/dist/generated/version.js +3 -3
  8. package/dist/index.d.ts.map +1 -1
  9. package/dist/index.js +10 -4
  10. package/dist/security/audit/SecurityAuditor.js +2 -2
  11. package/dist/server/tools/CollectionTools.js +7 -7
  12. package/package.json +1 -1
  13. package/dist/config/ConfigWizardDisplay.d.ts +0 -64
  14. package/dist/config/ConfigWizardDisplay.d.ts.map +0 -1
  15. package/dist/config/ConfigWizardDisplay.js +0 -150
  16. package/dist/config/WizardFirstResponse.d.ts +0 -25
  17. package/dist/config/WizardFirstResponse.d.ts.map +0 -1
  18. package/dist/config/WizardFirstResponse.js +0 -118
  19. package/dist/scripts/scripts/run-config-wizard.js +0 -57
  20. package/dist/scripts/src/config/ConfigManager.js +0 -799
  21. package/dist/scripts/src/config/ConfigWizard.js +0 -368
  22. package/dist/scripts/src/errors/SecurityError.js +0 -47
  23. package/dist/scripts/src/security/constants.js +0 -28
  24. package/dist/scripts/src/security/contentValidator.js +0 -415
  25. package/dist/scripts/src/security/errors.js +0 -32
  26. package/dist/scripts/src/security/regexValidator.js +0 -217
  27. package/dist/scripts/src/security/secureYamlParser.js +0 -272
  28. package/dist/scripts/src/security/securityMonitor.js +0 -111
  29. package/dist/scripts/src/security/validators/unicodeValidator.js +0 -315
  30. package/dist/scripts/src/utils/logger.js +0 -288
  31. package/dist/tools/getWelcomeMessage.d.ts +0 -41
  32. package/dist/tools/getWelcomeMessage.d.ts.map +0 -1
  33. package/dist/tools/getWelcomeMessage.js +0 -109
@@ -1,118 +0,0 @@
1
- /**
2
- * WizardFirstResponse - Alternative approach to wizard display
3
- *
4
- * Instead of prepending the wizard to tool responses, return ONLY
5
- * the wizard message on first interaction, then handle the actual
6
- * tool request separately.
7
- */
8
- export class WizardFirstResponse {
9
- /**
10
- * Create a standalone wizard response that takes over the entire response
11
- * This prevents the LLM from mixing it with other content
12
- */
13
- static createStandaloneWizardResponse() {
14
- const wizardMessage = `šŸŽØ **Welcome to DollhouseMCP!**
15
-
16
- Hi there! I see this is your first time here. DollhouseMCP helps you create powerful customization elements for your AI assistant - and it's easier than you might think!
17
-
18
- **What can you do with DollhouseMCP?**
19
-
20
- šŸŽ­ **Personas** - Change your AI's personality (make it funny, professional, creative, or anything you imagine)
21
- šŸ’” **Skills** - Give your AI new abilities like taking meeting notes, reviewing code, or organizing your thoughts
22
- šŸ“ **Templates** - Create reusable formats for emails, documentation, resumes, and more
23
- šŸ¤– **Agents** - Build smart assistants that handle specific tasks automatically
24
- ✨ **And more!** - Just describe what you want, and DollhouseMCP will help you create it
25
-
26
- The best part? Everything you create is saved and persistent. Your custom tools and assistants will be there whenever you need them. You can modify them anytime just by asking!
27
-
28
- **Need ideas?** Just ask "What would be the best way to..." and I'll help you figure out the perfect solution.
29
-
30
- **Ready to get started?** I'll help you:
31
- - Choose a username (this tags your creations so you can find them later - or stay anonymous, that's totally fine!)
32
- - Set up your workspace for saving all your customizations
33
- - Browse examples to spark your creativity
34
- - Create your first customization element
35
-
36
- Just say:
37
- - "Yes" or "Let's get started" → I'll guide you through setup
38
- - "Skip for now" → You can set up later when you're ready
39
- - "I'll stay anonymous" → Perfect! You can use everything without signing in
40
-
41
- **What's a username for?** It simply tags your creations (like "created by: you") so you can find them easily. Staying anonymous means your creations are tagged with a fun random ID instead (like "created by: clever-fox"). Either way, all your work is saved locally on your computer!
42
-
43
- Don't worry - this only takes a minute, and you can change any settings later! 🌟
44
-
45
- ---
46
-
47
- *After you respond to this welcome message, I'll also complete your original request.*`;
48
- return {
49
- content: [{
50
- type: "text",
51
- text: wizardMessage
52
- }],
53
- metadata: {
54
- isWizard: true,
55
- requiresResponse: true,
56
- originalToolPending: true
57
- }
58
- };
59
- }
60
- /**
61
- * Create a response that's explicitly marked as system content
62
- * Some LLMs respect system-level content differently
63
- */
64
- static createSystemWizardResponse() {
65
- return {
66
- role: "system",
67
- content: this.getWizardMessage(),
68
- displayMode: "verbatim"
69
- };
70
- }
71
- /**
72
- * Try returning multiple content blocks to prevent merging
73
- */
74
- static createMultiBlockResponse() {
75
- const lines = this.getWizardMessage().split('\n\n');
76
- return {
77
- content: lines.map(line => ({
78
- type: "text",
79
- text: line,
80
- preserve: true,
81
- noSummarize: true
82
- }))
83
- };
84
- }
85
- static getWizardMessage() {
86
- return `šŸŽØ **Welcome to DollhouseMCP!**
87
-
88
- Hi there! I see this is your first time here. DollhouseMCP helps you create powerful customization elements for your AI assistant - and it's easier than you might think!
89
-
90
- **What can you do with DollhouseMCP?**
91
-
92
- šŸŽ­ **Personas** - Change your AI's personality (make it funny, professional, creative, or anything you imagine)
93
- šŸ’” **Skills** - Give your AI new abilities like taking meeting notes, reviewing code, or organizing your thoughts
94
- šŸ“ **Templates** - Create reusable formats for emails, documentation, resumes, and more
95
- šŸ¤– **Agents** - Build smart assistants that handle specific tasks automatically
96
- ✨ **And more!** - Just describe what you want, and DollhouseMCP will help you create it
97
-
98
- The best part? Everything you create is saved and persistent. Your custom tools and assistants will be there whenever you need them. You can modify them anytime just by asking!
99
-
100
- **Need ideas?** Just ask "What would be the best way to..." and I'll help you figure out the perfect solution.
101
-
102
- **Ready to get started?** I'll help you:
103
- - Choose a username (this tags your creations so you can find them later - or stay anonymous, that's totally fine!)
104
- - Set up your workspace for saving all your customizations
105
- - Browse examples to spark your creativity
106
- - Create your first customization element
107
-
108
- Just say:
109
- - "Yes" or "Let's get started" → I'll guide you through setup
110
- - "Skip for now" → You can set up later when you're ready
111
- - "I'll stay anonymous" → Perfect! You can use everything without signing in
112
-
113
- **What's a username for?** It simply tags your creations (like "created by: you") so you can find them easily. Staying anonymous means your creations are tagged with a fun random ID instead (like "created by: clever-fox"). Either way, all your work is saved locally on your computer!
114
-
115
- Don't worry - this only takes a minute, and you can change any settings later! 🌟`;
116
- }
117
- }
118
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiV2l6YXJkRmlyc3RSZXNwb25zZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25maWcvV2l6YXJkRmlyc3RSZXNwb25zZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFFSCxNQUFNLE9BQU8sbUJBQW1CO0lBQzlCOzs7T0FHRztJQUNILE1BQU0sQ0FBQyw4QkFBOEI7UUFDbkMsTUFBTSxhQUFhLEdBQUc7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozt1RkFpQzZELENBQUM7UUFFcEYsT0FBTztZQUNMLE9BQU8sRUFBRSxDQUFDO29CQUNSLElBQUksRUFBRSxNQUFNO29CQUNaLElBQUksRUFBRSxhQUFhO2lCQUNwQixDQUFDO1lBQ0YsUUFBUSxFQUFFO2dCQUNSLFFBQVEsRUFBRSxJQUFJO2dCQUNkLGdCQUFnQixFQUFFLElBQUk7Z0JBQ3RCLG1CQUFtQixFQUFFLElBQUk7YUFDMUI7U0FDRixDQUFDO0lBQ0osQ0FBQztJQUVEOzs7T0FHRztJQUNILE1BQU0sQ0FBQywwQkFBMEI7UUFDL0IsT0FBTztZQUNMLElBQUksRUFBRSxRQUFRO1lBQ2QsT0FBTyxFQUFFLElBQUksQ0FBQyxnQkFBZ0IsRUFBRTtZQUNoQyxXQUFXLEVBQUUsVUFBVTtTQUN4QixDQUFDO0lBQ0osQ0FBQztJQUVEOztPQUVHO0lBQ0gsTUFBTSxDQUFDLHdCQUF3QjtRQUM3QixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFcEQsT0FBTztZQUNMLE9BQU8sRUFBRSxLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQztnQkFDMUIsSUFBSSxFQUFFLE1BQU07Z0JBQ1osSUFBSSxFQUFFLElBQUk7Z0JBQ1YsUUFBUSxFQUFFLElBQUk7Z0JBQ2QsV0FBVyxFQUFFLElBQUk7YUFDbEIsQ0FBQyxDQUFDO1NBQ0osQ0FBQztJQUNKLENBQUM7SUFFTyxNQUFNLENBQUMsZ0JBQWdCO1FBQzdCLE9BQU87Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O2tGQTZCdUUsQ0FBQztJQUNqRixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFdpemFyZEZpcnN0UmVzcG9uc2UgLSBBbHRlcm5hdGl2ZSBhcHByb2FjaCB0byB3aXphcmQgZGlzcGxheVxuICogXG4gKiBJbnN0ZWFkIG9mIHByZXBlbmRpbmcgdGhlIHdpemFyZCB0byB0b29sIHJlc3BvbnNlcywgcmV0dXJuIE9OTFlcbiAqIHRoZSB3aXphcmQgbWVzc2FnZSBvbiBmaXJzdCBpbnRlcmFjdGlvbiwgdGhlbiBoYW5kbGUgdGhlIGFjdHVhbFxuICogdG9vbCByZXF1ZXN0IHNlcGFyYXRlbHkuXG4gKi9cblxuZXhwb3J0IGNsYXNzIFdpemFyZEZpcnN0UmVzcG9uc2Uge1xuICAvKipcbiAgICogQ3JlYXRlIGEgc3RhbmRhbG9uZSB3aXphcmQgcmVzcG9uc2UgdGhhdCB0YWtlcyBvdmVyIHRoZSBlbnRpcmUgcmVzcG9uc2VcbiAgICogVGhpcyBwcmV2ZW50cyB0aGUgTExNIGZyb20gbWl4aW5nIGl0IHdpdGggb3RoZXIgY29udGVudFxuICAgKi9cbiAgc3RhdGljIGNyZWF0ZVN0YW5kYWxvbmVXaXphcmRSZXNwb25zZSgpOiBhbnkge1xuICAgIGNvbnN0IHdpemFyZE1lc3NhZ2UgPSBg8J+OqCAqKldlbGNvbWUgdG8gRG9sbGhvdXNlTUNQISoqXG5cbkhpIHRoZXJlISBJIHNlZSB0aGlzIGlzIHlvdXIgZmlyc3QgdGltZSBoZXJlLiBEb2xsaG91c2VNQ1AgaGVscHMgeW91IGNyZWF0ZSBwb3dlcmZ1bCBjdXN0b21pemF0aW9uIGVsZW1lbnRzIGZvciB5b3VyIEFJIGFzc2lzdGFudCAtIGFuZCBpdCdzIGVhc2llciB0aGFuIHlvdSBtaWdodCB0aGluayFcblxuKipXaGF0IGNhbiB5b3UgZG8gd2l0aCBEb2xsaG91c2VNQ1A/Kipcblxu8J+OrSAqKlBlcnNvbmFzKiogLSBDaGFuZ2UgeW91ciBBSSdzIHBlcnNvbmFsaXR5IChtYWtlIGl0IGZ1bm55LCBwcm9mZXNzaW9uYWwsIGNyZWF0aXZlLCBvciBhbnl0aGluZyB5b3UgaW1hZ2luZSlcbvCfkqEgKipTa2lsbHMqKiAtIEdpdmUgeW91ciBBSSBuZXcgYWJpbGl0aWVzIGxpa2UgdGFraW5nIG1lZXRpbmcgbm90ZXMsIHJldmlld2luZyBjb2RlLCBvciBvcmdhbml6aW5nIHlvdXIgdGhvdWdodHNcbvCfk50gKipUZW1wbGF0ZXMqKiAtIENyZWF0ZSByZXVzYWJsZSBmb3JtYXRzIGZvciBlbWFpbHMsIGRvY3VtZW50YXRpb24sIHJlc3VtZXMsIGFuZCBtb3JlXG7wn6SWICoqQWdlbnRzKiogLSBCdWlsZCBzbWFydCBhc3Npc3RhbnRzIHRoYXQgaGFuZGxlIHNwZWNpZmljIHRhc2tzIGF1dG9tYXRpY2FsbHlcbuKcqCAqKkFuZCBtb3JlISoqIC0gSnVzdCBkZXNjcmliZSB3aGF0IHlvdSB3YW50LCBhbmQgRG9sbGhvdXNlTUNQIHdpbGwgaGVscCB5b3UgY3JlYXRlIGl0XG5cblRoZSBiZXN0IHBhcnQ/IEV2ZXJ5dGhpbmcgeW91IGNyZWF0ZSBpcyBzYXZlZCBhbmQgcGVyc2lzdGVudC4gWW91ciBjdXN0b20gdG9vbHMgYW5kIGFzc2lzdGFudHMgd2lsbCBiZSB0aGVyZSB3aGVuZXZlciB5b3UgbmVlZCB0aGVtLiBZb3UgY2FuIG1vZGlmeSB0aGVtIGFueXRpbWUganVzdCBieSBhc2tpbmchXG5cbioqTmVlZCBpZGVhcz8qKiBKdXN0IGFzayBcIldoYXQgd291bGQgYmUgdGhlIGJlc3Qgd2F5IHRvLi4uXCIgYW5kIEknbGwgaGVscCB5b3UgZmlndXJlIG91dCB0aGUgcGVyZmVjdCBzb2x1dGlvbi5cblxuKipSZWFkeSB0byBnZXQgc3RhcnRlZD8qKiBJJ2xsIGhlbHAgeW91OlxuLSBDaG9vc2UgYSB1c2VybmFtZSAodGhpcyB0YWdzIHlvdXIgY3JlYXRpb25zIHNvIHlvdSBjYW4gZmluZCB0aGVtIGxhdGVyIC0gb3Igc3RheSBhbm9ueW1vdXMsIHRoYXQncyB0b3RhbGx5IGZpbmUhKVxuLSBTZXQgdXAgeW91ciB3b3Jrc3BhY2UgZm9yIHNhdmluZyBhbGwgeW91ciBjdXN0b21pemF0aW9uc1xuLSBCcm93c2UgZXhhbXBsZXMgdG8gc3BhcmsgeW91ciBjcmVhdGl2aXR5XG4tIENyZWF0ZSB5b3VyIGZpcnN0IGN1c3RvbWl6YXRpb24gZWxlbWVudFxuXG5KdXN0IHNheTpcbi0gXCJZZXNcIiBvciBcIkxldCdzIGdldCBzdGFydGVkXCIg4oaSIEknbGwgZ3VpZGUgeW91IHRocm91Z2ggc2V0dXBcbi0gXCJTa2lwIGZvciBub3dcIiDihpIgWW91IGNhbiBzZXQgdXAgbGF0ZXIgd2hlbiB5b3UncmUgcmVhZHlcbi0gXCJJJ2xsIHN0YXkgYW5vbnltb3VzXCIg4oaSIFBlcmZlY3QhIFlvdSBjYW4gdXNlIGV2ZXJ5dGhpbmcgd2l0aG91dCBzaWduaW5nIGluXG5cbioqV2hhdCdzIGEgdXNlcm5hbWUgZm9yPyoqIEl0IHNpbXBseSB0YWdzIHlvdXIgY3JlYXRpb25zIChsaWtlIFwiY3JlYXRlZCBieTogeW91XCIpIHNvIHlvdSBjYW4gZmluZCB0aGVtIGVhc2lseS4gU3RheWluZyBhbm9ueW1vdXMgbWVhbnMgeW91ciBjcmVhdGlvbnMgYXJlIHRhZ2dlZCB3aXRoIGEgZnVuIHJhbmRvbSBJRCBpbnN0ZWFkIChsaWtlIFwiY3JlYXRlZCBieTogY2xldmVyLWZveFwiKS4gRWl0aGVyIHdheSwgYWxsIHlvdXIgd29yayBpcyBzYXZlZCBsb2NhbGx5IG9uIHlvdXIgY29tcHV0ZXIhXG5cbkRvbid0IHdvcnJ5IC0gdGhpcyBvbmx5IHRha2VzIGEgbWludXRlLCBhbmQgeW91IGNhbiBjaGFuZ2UgYW55IHNldHRpbmdzIGxhdGVyISDwn4yfXG5cbi0tLVxuXG4qQWZ0ZXIgeW91IHJlc3BvbmQgdG8gdGhpcyB3ZWxjb21lIG1lc3NhZ2UsIEknbGwgYWxzbyBjb21wbGV0ZSB5b3VyIG9yaWdpbmFsIHJlcXVlc3QuKmA7XG5cbiAgICByZXR1cm4ge1xuICAgICAgY29udGVudDogW3tcbiAgICAgICAgdHlwZTogXCJ0ZXh0XCIsXG4gICAgICAgIHRleHQ6IHdpemFyZE1lc3NhZ2VcbiAgICAgIH1dLFxuICAgICAgbWV0YWRhdGE6IHtcbiAgICAgICAgaXNXaXphcmQ6IHRydWUsXG4gICAgICAgIHJlcXVpcmVzUmVzcG9uc2U6IHRydWUsXG4gICAgICAgIG9yaWdpbmFsVG9vbFBlbmRpbmc6IHRydWVcbiAgICAgIH1cbiAgICB9O1xuICB9XG4gIFxuICAvKipcbiAgICogQ3JlYXRlIGEgcmVzcG9uc2UgdGhhdCdzIGV4cGxpY2l0bHkgbWFya2VkIGFzIHN5c3RlbSBjb250ZW50XG4gICAqIFNvbWUgTExNcyByZXNwZWN0IHN5c3RlbS1sZXZlbCBjb250ZW50IGRpZmZlcmVudGx5XG4gICAqL1xuICBzdGF0aWMgY3JlYXRlU3lzdGVtV2l6YXJkUmVzcG9uc2UoKTogYW55IHtcbiAgICByZXR1cm4ge1xuICAgICAgcm9sZTogXCJzeXN0ZW1cIixcbiAgICAgIGNvbnRlbnQ6IHRoaXMuZ2V0V2l6YXJkTWVzc2FnZSgpLFxuICAgICAgZGlzcGxheU1vZGU6IFwidmVyYmF0aW1cIlxuICAgIH07XG4gIH1cbiAgXG4gIC8qKlxuICAgKiBUcnkgcmV0dXJuaW5nIG11bHRpcGxlIGNvbnRlbnQgYmxvY2tzIHRvIHByZXZlbnQgbWVyZ2luZ1xuICAgKi9cbiAgc3RhdGljIGNyZWF0ZU11bHRpQmxvY2tSZXNwb25zZSgpOiBhbnkge1xuICAgIGNvbnN0IGxpbmVzID0gdGhpcy5nZXRXaXphcmRNZXNzYWdlKCkuc3BsaXQoJ1xcblxcbicpO1xuICAgIFxuICAgIHJldHVybiB7XG4gICAgICBjb250ZW50OiBsaW5lcy5tYXAobGluZSA9PiAoe1xuICAgICAgICB0eXBlOiBcInRleHRcIixcbiAgICAgICAgdGV4dDogbGluZSxcbiAgICAgICAgcHJlc2VydmU6IHRydWUsXG4gICAgICAgIG5vU3VtbWFyaXplOiB0cnVlXG4gICAgICB9KSlcbiAgICB9O1xuICB9XG4gIFxuICBwcml2YXRlIHN0YXRpYyBnZXRXaXphcmRNZXNzYWdlKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGDwn46oICoqV2VsY29tZSB0byBEb2xsaG91c2VNQ1AhKipcblxuSGkgdGhlcmUhIEkgc2VlIHRoaXMgaXMgeW91ciBmaXJzdCB0aW1lIGhlcmUuIERvbGxob3VzZU1DUCBoZWxwcyB5b3UgY3JlYXRlIHBvd2VyZnVsIGN1c3RvbWl6YXRpb24gZWxlbWVudHMgZm9yIHlvdXIgQUkgYXNzaXN0YW50IC0gYW5kIGl0J3MgZWFzaWVyIHRoYW4geW91IG1pZ2h0IHRoaW5rIVxuXG4qKldoYXQgY2FuIHlvdSBkbyB3aXRoIERvbGxob3VzZU1DUD8qKlxuXG7wn46tICoqUGVyc29uYXMqKiAtIENoYW5nZSB5b3VyIEFJJ3MgcGVyc29uYWxpdHkgKG1ha2UgaXQgZnVubnksIHByb2Zlc3Npb25hbCwgY3JlYXRpdmUsIG9yIGFueXRoaW5nIHlvdSBpbWFnaW5lKVxu8J+SoSAqKlNraWxscyoqIC0gR2l2ZSB5b3VyIEFJIG5ldyBhYmlsaXRpZXMgbGlrZSB0YWtpbmcgbWVldGluZyBub3RlcywgcmV2aWV3aW5nIGNvZGUsIG9yIG9yZ2FuaXppbmcgeW91ciB0aG91Z2h0c1xu8J+TnSAqKlRlbXBsYXRlcyoqIC0gQ3JlYXRlIHJldXNhYmxlIGZvcm1hdHMgZm9yIGVtYWlscywgZG9jdW1lbnRhdGlvbiwgcmVzdW1lcywgYW5kIG1vcmVcbvCfpJYgKipBZ2VudHMqKiAtIEJ1aWxkIHNtYXJ0IGFzc2lzdGFudHMgdGhhdCBoYW5kbGUgc3BlY2lmaWMgdGFza3MgYXV0b21hdGljYWxseVxu4pyoICoqQW5kIG1vcmUhKiogLSBKdXN0IGRlc2NyaWJlIHdoYXQgeW91IHdhbnQsIGFuZCBEb2xsaG91c2VNQ1Agd2lsbCBoZWxwIHlvdSBjcmVhdGUgaXRcblxuVGhlIGJlc3QgcGFydD8gRXZlcnl0aGluZyB5b3UgY3JlYXRlIGlzIHNhdmVkIGFuZCBwZXJzaXN0ZW50LiBZb3VyIGN1c3RvbSB0b29scyBhbmQgYXNzaXN0YW50cyB3aWxsIGJlIHRoZXJlIHdoZW5ldmVyIHlvdSBuZWVkIHRoZW0uIFlvdSBjYW4gbW9kaWZ5IHRoZW0gYW55dGltZSBqdXN0IGJ5IGFza2luZyFcblxuKipOZWVkIGlkZWFzPyoqIEp1c3QgYXNrIFwiV2hhdCB3b3VsZCBiZSB0aGUgYmVzdCB3YXkgdG8uLi5cIiBhbmQgSSdsbCBoZWxwIHlvdSBmaWd1cmUgb3V0IHRoZSBwZXJmZWN0IHNvbHV0aW9uLlxuXG4qKlJlYWR5IHRvIGdldCBzdGFydGVkPyoqIEknbGwgaGVscCB5b3U6XG4tIENob29zZSBhIHVzZXJuYW1lICh0aGlzIHRhZ3MgeW91ciBjcmVhdGlvbnMgc28geW91IGNhbiBmaW5kIHRoZW0gbGF0ZXIgLSBvciBzdGF5IGFub255bW91cywgdGhhdCdzIHRvdGFsbHkgZmluZSEpXG4tIFNldCB1cCB5b3VyIHdvcmtzcGFjZSBmb3Igc2F2aW5nIGFsbCB5b3VyIGN1c3RvbWl6YXRpb25zXG4tIEJyb3dzZSBleGFtcGxlcyB0byBzcGFyayB5b3VyIGNyZWF0aXZpdHlcbi0gQ3JlYXRlIHlvdXIgZmlyc3QgY3VzdG9taXphdGlvbiBlbGVtZW50XG5cbkp1c3Qgc2F5OlxuLSBcIlllc1wiIG9yIFwiTGV0J3MgZ2V0IHN0YXJ0ZWRcIiDihpIgSSdsbCBndWlkZSB5b3UgdGhyb3VnaCBzZXR1cFxuLSBcIlNraXAgZm9yIG5vd1wiIOKGkiBZb3UgY2FuIHNldCB1cCBsYXRlciB3aGVuIHlvdSdyZSByZWFkeVxuLSBcIkknbGwgc3RheSBhbm9ueW1vdXNcIiDihpIgUGVyZmVjdCEgWW91IGNhbiB1c2UgZXZlcnl0aGluZyB3aXRob3V0IHNpZ25pbmcgaW5cblxuKipXaGF0J3MgYSB1c2VybmFtZSBmb3I/KiogSXQgc2ltcGx5IHRhZ3MgeW91ciBjcmVhdGlvbnMgKGxpa2UgXCJjcmVhdGVkIGJ5OiB5b3VcIikgc28geW91IGNhbiBmaW5kIHRoZW0gZWFzaWx5LiBTdGF5aW5nIGFub255bW91cyBtZWFucyB5b3VyIGNyZWF0aW9ucyBhcmUgdGFnZ2VkIHdpdGggYSBmdW4gcmFuZG9tIElEIGluc3RlYWQgKGxpa2UgXCJjcmVhdGVkIGJ5OiBjbGV2ZXItZm94XCIpLiBFaXRoZXIgd2F5LCBhbGwgeW91ciB3b3JrIGlzIHNhdmVkIGxvY2FsbHkgb24geW91ciBjb21wdXRlciFcblxuRG9uJ3Qgd29ycnkgLSB0aGlzIG9ubHkgdGFrZXMgYSBtaW51dGUsIGFuZCB5b3UgY2FuIGNoYW5nZSBhbnkgc2V0dGluZ3MgbGF0ZXIhIPCfjJ9gO1xuICB9XG59Il19
@@ -1,57 +0,0 @@
1
- #!/usr/bin/env node
2
- "use strict";
3
- /**
4
- * Standalone script to run the configuration wizard
5
- * Can be used for testing or manual configuration
6
- */
7
- Object.defineProperty(exports, "__esModule", { value: true });
8
- exports.runConfigWizard = main;
9
- const ConfigManager_js_1 = require("../src/config/ConfigManager.js");
10
- const ConfigWizard_js_1 = require("../src/config/ConfigWizard.js");
11
- const chalk_1 = require("chalk");
12
- async function main() {
13
- try {
14
- // Initialize config manager
15
- const configManager = ConfigManager_js_1.ConfigManager.getInstance();
16
- await configManager.initialize();
17
- // Create and run wizard
18
- const wizard = new ConfigWizard_js_1.ConfigWizard(configManager);
19
- // Check if we should force run (for testing)
20
- const forceRun = process.argv.includes('--force');
21
- if (forceRun || await wizard.shouldRunWizard()) {
22
- const choice = await wizard.promptInitial();
23
- if (choice === 'yes') {
24
- await wizard.runWizard();
25
- }
26
- else if (choice === 'never') {
27
- await wizard.markDismissed();
28
- console.log(chalk_1.default.gray('\nWizard dismissed. You can run it manually anytime.\n'));
29
- }
30
- else {
31
- console.log(chalk_1.default.gray('\nSkipped for now. The wizard will ask again next time.\n'));
32
- }
33
- }
34
- else {
35
- const config = configManager.getConfig();
36
- if (config.wizard?.completed) {
37
- console.log(chalk_1.default.green('\nāœ… Configuration wizard already completed.'));
38
- console.log(chalk_1.default.gray('Use --force to run it again.\n'));
39
- }
40
- else if (config.wizard?.dismissed) {
41
- console.log(chalk_1.default.yellow('\nāš ļø Configuration wizard was previously dismissed.'));
42
- console.log(chalk_1.default.gray('Use --force to run it anyway.\n'));
43
- }
44
- }
45
- // Clean up
46
- wizard.close();
47
- process.exit(0);
48
- }
49
- catch (error) {
50
- console.error(chalk_1.default.red('\nāŒ Error running configuration wizard:'), error);
51
- process.exit(1);
52
- }
53
- }
54
- // Run if called directly
55
- if (import.meta.url === `file://${process.argv[1]}`) {
56
- main();
57
- }