@dollhousemcp/mcp-server 1.6.2 → 1.6.3

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/CHANGELOG.md CHANGED
@@ -7,6 +7,16 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
7
7
 
8
8
  ## [Unreleased]
9
9
 
10
+ ## [1.6.3] - 2025-08-25
11
+
12
+ ### Fixed
13
+ - **OAuth Authentication** - Fixed invalid OAuth client ID and added comprehensive error handling
14
+ - Updated default client ID from incorrect `Ov23liXGGP9jNrBhBNfO` to correct `Ov23li9gyNZP6m9aJ2EP`
15
+ - Added unique error codes throughout OAuth flow for precise debugging
16
+ - Added debug logging at each step of the authentication process
17
+ - Improved error messages to be specific and actionable
18
+ - Fixed TypeScript compilation issue with missing DeviceCodeResponse import
19
+
10
20
  ## [1.6.2] - 2025-08-25
11
21
 
12
22
  ### Fixed
package/README.md CHANGED
@@ -30,9 +30,9 @@ A comprehensive Model Context Protocol (MCP) server that enables dynamic AI pers
30
30
  **🏪 Collection**: https://github.com/DollhouseMCP/collection
31
31
  **📦 NPM Package**: https://www.npmjs.com/package/@dollhousemcp/mcp-server
32
32
  **🌍 Website**: https://dollhousemcp.com (planned)
33
- **📦 Version**: v1.6.2
33
+ **📦 Version**: v1.6.3
34
34
 
35
- > **🎉 New in v1.6.2**: Critical OAuth fix - the default client ID now actually works! The v1.6.1 release had a bug where the default OAuth wasn't being used. This hotfix restores the "just works" authentication experience. Includes all features from v1.6.0.
35
+ > **🎉 New in v1.6.3**: Fixed OAuth authentication with correct client ID and comprehensive error messages. The OAuth client ID has been corrected and detailed error codes added throughout the flow for better debugging.
36
36
 
37
37
  > **⚠️ Breaking Change**: PersonaTools have been streamlined in v1.6.0. 9 redundant tools were removed in favor of ElementTools. See [PersonaTools Migration Guide](docs/PERSONATOOLS_MIGRATION_GUIDE.md) for migration instructions.
38
38
 
@@ -42,7 +42,7 @@ A comprehensive Model Context Protocol (MCP) server that enables dynamic AI pers
42
42
  # Install globally
43
43
  npm install -g @dollhousemcp/mcp-server
44
44
 
45
- # ✅ v1.6.2 fixes OAuth - authentication truly just works now!
45
+ # ✅ v1.6.3 fixes OAuth with correct client ID!
46
46
  # Browse and submit to collection with or without authentication:
47
47
  # npm install -g @dollhousemcp/mcp-server@latest
48
48
 
@@ -1 +1 @@
1
- {"version":3,"file":"GitHubAuthManager.d.ts","sourceRoot":"","sources":["../../src/auth/GitHubAuthManager.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAMhD,MAAM,WAAW,kBAAkB;IACjC,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,gBAAgB,EAAE,MAAM,CAAC;IACzB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,aAAa;IAC5B,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,UAAU;IACzB,eAAe,EAAE,OAAO,CAAC;IACzB,QAAQ,EAAE,OAAO,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,SAAS,CAAC,EAAE,IAAI,CAAC;CAClB;AAED;;;GAGG;AACH,qBAAa,iBAAiB;IAC5B;;;;;;;OAOG;IACH,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,iBAAiB,CAA0B;IAEnE;;;;;OAKG;WACiB,WAAW,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IA4BzD,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,eAAe,CAA0C;IACjF,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAiD;IAClF,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAiC;IAGjE,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,qBAAqB,CAAQ;IACrD,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,iBAAiB,CAAO;IAEhD,OAAO,CAAC,QAAQ,CAAW;IAC3B,OAAO,CAAC,aAAa,CAAgC;gBAEzC,QAAQ,EAAE,QAAQ;IAI9B;;OAEG;YACW,cAAc;IA2C5B;;OAEG;IACG,aAAa,IAAI,OAAO,CAAC,UAAU,CAAC;IA8B1C;;OAEG;IACG,kBAAkB,IAAI,OAAO,CAAC,kBAAkB,CAAC;IA4DvD;;OAEG;IACG,YAAY,CAAC,UAAU,EAAE,MAAM,EAAE,QAAQ,GAAE,MAAgD,GAAG,OAAO,CAAC,aAAa,CAAC;IAkF1H;;OAEG;IACG,sBAAsB,CAAC,aAAa,EAAE,aAAa,GAAG,OAAO,CAAC,UAAU,CAAC;IA4B/E;;OAEG;IACG,mBAAmB,IAAI,OAAO,CAAC,IAAI,CAAC;IAoC1C;;OAEG;YACW,UAAU;IAYxB;;OAEG;YACW,aAAa;IA6E3B;;OAEG;IACH,sBAAsB,CAAC,cAAc,EAAE,kBAAkB,GAAG,MAAM;IAmBlE;;OAEG;IACH,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAK3C;;OAEG;YACW,aAAa;IAmB3B;;OAEG;IACG,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAuB9B;;;OAGG;IACH,OAAO,CAAC,wBAAwB;CAyBjC"}
1
+ {"version":3,"file":"GitHubAuthManager.d.ts","sourceRoot":"","sources":["../../src/auth/GitHubAuthManager.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAMhD,MAAM,WAAW,kBAAkB;IACjC,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,gBAAgB,EAAE,MAAM,CAAC;IACzB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,aAAa;IAC5B,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,UAAU;IACzB,eAAe,EAAE,OAAO,CAAC;IACzB,QAAQ,EAAE,OAAO,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,SAAS,CAAC,EAAE,IAAI,CAAC;CAClB;AAED;;;GAGG;AACH,qBAAa,iBAAiB;IAC5B;;;;;;;OAOG;IACH,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,iBAAiB,CAA0B;IAEnE;;;;;OAKG;WACiB,WAAW,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IA4BzD,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,eAAe,CAA0C;IACjF,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAiD;IAClF,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAiC;IAGjE,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,qBAAqB,CAAQ;IACrD,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,iBAAiB,CAAO;IAEhD,OAAO,CAAC,QAAQ,CAAW;IAC3B,OAAO,CAAC,aAAa,CAAgC;gBAEzC,QAAQ,EAAE,QAAQ;IAI9B;;OAEG;YACW,cAAc;IA2C5B;;OAEG;IACG,aAAa,IAAI,OAAO,CAAC,UAAU,CAAC;IA8B1C;;OAEG;IACG,kBAAkB,IAAI,OAAO,CAAC,kBAAkB,CAAC;IAkIvD;;OAEG;IACG,YAAY,CAAC,UAAU,EAAE,MAAM,EAAE,QAAQ,GAAE,MAAgD,GAAG,OAAO,CAAC,aAAa,CAAC;IAkF1H;;OAEG;IACG,sBAAsB,CAAC,aAAa,EAAE,aAAa,GAAG,OAAO,CAAC,UAAU,CAAC;IA4B/E;;OAEG;IACG,mBAAmB,IAAI,OAAO,CAAC,IAAI,CAAC;IAoC1C;;OAEG;YACW,UAAU;IAYxB;;OAEG;YACW,aAAa;IA6E3B;;OAEG;IACH,sBAAsB,CAAC,cAAc,EAAE,kBAAkB,GAAG,MAAM;IAmBlE;;OAEG;IACH,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAK3C;;OAEG;YACW,aAAa;IAmB3B;;OAEG;IACG,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAuB9B;;;OAGG;IACH,OAAO,CAAC,wBAAwB;CAyBjC"}
@@ -21,7 +21,7 @@ export class GitHubAuthManager {
21
21
  * This Client ID enables the GitHub device flow authentication
22
22
  * allowing users to authenticate with an 8-character code.
23
23
  */
24
- static DEFAULT_CLIENT_ID = 'Ov23liXGGP9jNrBhBNfO';
24
+ static DEFAULT_CLIENT_ID = 'Ov23li9gyNZP6m9aJ2EP';
25
25
  /**
26
26
  * Get the CLIENT_ID from environment variable, ConfigManager, or default
27
27
  * Priority: Environment variable > ConfigManager > Default Client ID
@@ -136,6 +136,12 @@ export class GitHubAuthManager {
136
136
  async initiateDeviceFlow() {
137
137
  const clientId = await GitHubAuthManager.getClientId();
138
138
  // getClientId() always returns a value (env, config, or default)
139
+ // Log the OAuth flow step for debugging
140
+ logger.debug('OAUTH_STEP_1: Getting client ID', { clientId: clientId?.substring(0, 8) + '...' });
141
+ if (!clientId) {
142
+ throw new Error('OAUTH_NO_CLIENT_ID: No OAuth client ID configured. Set DOLLHOUSE_GITHUB_CLIENT_ID environment variable.');
143
+ }
144
+ logger.debug('OAUTH_STEP_2: Initiating device flow', { url: GitHubAuthManager.DEVICE_CODE_URL });
139
145
  try {
140
146
  const response = await this.fetchWithRetry(GitHubAuthManager.DEVICE_CODE_URL, {
141
147
  method: 'POST',
@@ -148,19 +154,58 @@ export class GitHubAuthManager {
148
154
  scope: 'public_repo read:user'
149
155
  })
150
156
  });
157
+ logger.debug('OAUTH_STEP_3: GitHub response', {
158
+ status: response.status,
159
+ statusText: response.statusText,
160
+ headers: {
161
+ 'x-github-request-id': response.headers.get('x-github-request-id'),
162
+ 'x-ratelimit-remaining': response.headers.get('x-ratelimit-remaining')
163
+ }
164
+ });
151
165
  if (!response.ok) {
152
- // Provide user-friendly error messages based on status codes
153
- const errorMessage = this.getErrorMessageForStatus(response.status, 'device flow initialization');
154
- logger.debug('Device flow initiation failed', {
166
+ const responseText = await response.text();
167
+ logger.error('GitHub OAuth endpoint error', {
155
168
  status: response.status,
156
- statusText: response.statusText
169
+ statusText: response.statusText,
170
+ responseBody: responseText,
171
+ clientId: clientId?.substring(0, 8) + '...'
157
172
  });
158
- throw new Error(errorMessage);
173
+ // Parse GitHub's error response for specific error codes
174
+ try {
175
+ const errorData = JSON.parse(responseText);
176
+ if (errorData.error === 'unauthorized_client') {
177
+ throw new Error(`OAUTH_CLIENT_UNAUTHORIZED: OAuth app '${clientId?.substring(0, 8)}...' is not authorized for device flow. The app may need reconfiguration.`);
178
+ }
179
+ if (errorData.error === 'invalid_client') {
180
+ throw new Error(`OAUTH_CLIENT_INVALID: GitHub rejected OAuth client ID '${clientId?.substring(0, 8)}...'. The app may not exist or be disabled.`);
181
+ }
182
+ if (errorData.error_description) {
183
+ throw new Error(`OAUTH_API_ERROR: ${errorData.error_description}`);
184
+ }
185
+ }
186
+ catch (parseError) {
187
+ // If we can't parse the error, provide HTTP status specific error
188
+ if (response.status === 401) {
189
+ throw new Error(`OAUTH_CLIENT_INVALID: GitHub rejected OAuth client ID '${clientId?.substring(0, 8)}...'. The app may not exist or be disabled.`);
190
+ }
191
+ if (response.status === 403) {
192
+ throw new Error(`OAUTH_DEVICE_FLOW_DISABLED: This OAuth app doesn't have device flow enabled. Contact administrator.`);
193
+ }
194
+ if (response.status === 429) {
195
+ throw new Error(`OAUTH_RATE_LIMITED: Too many authentication attempts. Please wait before trying again.`);
196
+ }
197
+ throw new Error(`OAUTH_HTTP_${response.status}: GitHub OAuth failed - ${response.statusText}`);
198
+ }
159
199
  }
160
200
  const data = await response.json();
161
201
  // Validate response
162
202
  if (!data.device_code || !data.user_code || !data.verification_uri) {
163
- throw new Error('Invalid device flow response from GitHub');
203
+ logger.error('Invalid device flow response structure', {
204
+ hasDeviceCode: !!data.device_code,
205
+ hasUserCode: !!data.user_code,
206
+ hasVerificationUri: !!data.verification_uri
207
+ });
208
+ throw new Error('OAUTH_INVALID_RESPONSE: Invalid device flow response from GitHub - missing required fields');
164
209
  }
165
210
  // Log security event for audit trail
166
211
  SecurityMonitor.logSecurityEvent({
@@ -178,11 +223,24 @@ export class GitHubAuthManager {
178
223
  }
179
224
  catch (error) {
180
225
  ErrorHandler.logError('GitHubAuthManager.initiateDeviceFlow', error);
181
- // Re-throw if it's already a properly formatted error
182
- if (error instanceof Error && error.message.includes('GitHub OAuth')) {
183
- throw error;
226
+ // Check if it's a network error
227
+ if (error instanceof Error) {
228
+ // Re-throw if it's already a properly formatted error with code
229
+ if (error.message.startsWith('OAUTH_')) {
230
+ throw error;
231
+ }
232
+ // Format network errors
233
+ if (error.message.includes('ECONNREFUSED') ||
234
+ error.message.includes('ETIMEDOUT') ||
235
+ error.message.includes('ENOTFOUND')) {
236
+ throw new Error(`OAUTH_NETWORK_ERROR: Unable to reach GitHub servers (https://github.com/login/device/code). Check your internet connection.`);
237
+ }
238
+ if (error.message.includes('network')) {
239
+ throw new Error(`OAUTH_NETWORK_ERROR: Network error while connecting to GitHub. Please check your internet connection.`);
240
+ }
184
241
  }
185
- throw new Error('Failed to start GitHub authentication. Please check your internet connection.');
242
+ // Generic fallback (should rarely happen)
243
+ throw new Error(`OAUTH_UNKNOWN_ERROR: Failed to start GitHub authentication - ${error instanceof Error ? error.message : 'Unknown error'}`);
186
244
  }
187
245
  }
188
246
  /**
@@ -504,4 +562,4 @@ Don't have a GitHub account? You'll be prompted to create one (it's free!)
504
562
  }
505
563
  }
506
564
  }
507
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"GitHubAuthManager.js","sourceRoot":"","sources":["../../src/auth/GitHubAuthManager.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * GitHub authentication manager using OAuth device flow\n * Handles authentication for MCP servers without requiring client secrets\n */\n\nimport { TokenManager } from '../security/tokenManager.js';\nimport { logger } from '../utils/logger.js';\nimport { APICache } from '../cache/APICache.js';\nimport { UnicodeValidator } from '../security/validators/unicodeValidator.js';\nimport { SecurityMonitor } from '../security/securityMonitor.js';\nimport { ErrorHandler, ErrorCategory } from '../utils/ErrorHandler.js';\nimport { ConfigManager } from '../config/ConfigManager.js';\n\nexport interface DeviceCodeResponse {\n  device_code: string;\n  user_code: string;\n  verification_uri: string;\n  expires_in: number;\n  interval: number;\n}\n\nexport interface TokenResponse {\n  access_token: string;\n  token_type: string;\n  scope: string;\n}\n\nexport interface AuthStatus {\n  isAuthenticated: boolean;\n  hasToken: boolean;\n  username?: string;\n  scopes?: string[];\n  expiresAt?: Date;\n}\n\n/**\n * Manages GitHub authentication using the OAuth device flow\n * This is the recommended approach for CLI/desktop applications\n */\nexport class GitHubAuthManager {\n  /**\n   * DollhouseMCP's official OAuth App Client ID\n   * This is PUBLIC information - OAuth Client IDs are meant to be visible.\n   * Only Client Secrets are private (device flow doesn't use secrets).\n   * \n   * This Client ID enables the GitHub device flow authentication\n   * allowing users to authenticate with an 8-character code.\n   */\n  private static readonly DEFAULT_CLIENT_ID = 'Ov23liXGGP9jNrBhBNfO';\n  \n  /**\n   * Get the CLIENT_ID from environment variable, ConfigManager, or default\n   * Priority: Environment variable > ConfigManager > Default Client ID\n   * \n   * @returns The OAuth Client ID to use for authentication\n   */\n  public static async getClientId(): Promise<string | null> {\n    // Check environment variable first (for backward compatibility)\n    const envClientId = process.env.DOLLHOUSE_GITHUB_CLIENT_ID;\n    if (envClientId) {\n      logger.debug('Using OAuth Client ID from environment variable');\n      return envClientId;\n    }\n\n    // Check ConfigManager for stored configuration\n    try {\n      const configManager = ConfigManager.getInstance();\n      await configManager.loadConfig();\n      const configClientId = configManager.getGitHubClientId();\n      if (configClientId) {\n        logger.debug('Using OAuth Client ID from config');\n        return configClientId;\n      }\n    } catch (error) {\n      logger.debug('No OAuth Client ID in config', { error });\n    }\n    \n    // Use default DollhouseMCP OAuth App Client ID\n    // This enables \"just works\" experience for NPM installs\n    logger.debug('Using default DollhouseMCP OAuth Client ID');\n    return GitHubAuthManager.DEFAULT_CLIENT_ID;\n  }\n  \n  // GitHub OAuth endpoints\n  private static readonly DEVICE_CODE_URL = 'https://github.com/login/device/code';\n  private static readonly TOKEN_URL = 'https://github.com/login/oauth/access_token';\n  private static readonly USER_URL = 'https://api.github.com/user';\n  \n  // Polling configuration\n  private static readonly DEFAULT_POLL_INTERVAL = 5000; // 5 seconds\n  private static readonly MAX_POLL_ATTEMPTS = 180; // 15 minutes total\n  \n  private apiCache: APICache;\n  private activePolling: AbortController | null = null;\n  \n  constructor(apiCache: APICache) {\n    this.apiCache = apiCache;\n  }\n  \n  /**\n   * Execute a network request with retry logic\n   */\n  private async fetchWithRetry(\n    url: string, \n    options: RequestInit, \n    maxRetries: number = 3,\n    retryDelay: number = 1000\n  ): Promise<Response> {\n    let lastError: Error | null = null;\n    \n    for (let attempt = 1; attempt <= maxRetries; attempt++) {\n      try {\n        const response = await fetch(url, options);\n        return response;\n      } catch (error) {\n        lastError = error as Error;\n        ErrorHandler.logError('GitHubAuthManager.fetchWithRetry', error, { url, attempt });\n        \n        // Check if it's a network error that should be retried\n        const isNetworkError = error instanceof Error && (\n          error.message.includes('ECONNREFUSED') ||\n          error.message.includes('ETIMEDOUT') ||\n          error.message.includes('ENOTFOUND') ||\n          error.message.includes('network')\n        );\n        \n        if (isNetworkError && attempt < maxRetries) {\n          logger.debug(`Network request failed, retrying (${attempt}/${maxRetries})`, {\n            url,\n            error: error.message,\n            nextRetryIn: retryDelay * attempt\n          });\n          \n          // Exponential backoff\n          await new Promise(resolve => setTimeout(resolve, retryDelay * attempt));\n        } else {\n          // Not a network error or last attempt, throw immediately\n          throw error;\n        }\n      }\n    }\n    \n    throw lastError || new Error('Network request failed after all retries');\n  }\n  \n  /**\n   * Check current authentication status\n   */\n  async getAuthStatus(): Promise<AuthStatus> {\n    const token = await TokenManager.getGitHubTokenAsync();\n    \n    if (!token) {\n      return {\n        isAuthenticated: false,\n        hasToken: false\n      };\n    }\n    \n    try {\n      // Try to get user info to validate token\n      const userInfo = await this.fetchUserInfo(token);\n      \n      return {\n        isAuthenticated: true,\n        hasToken: true,\n        username: userInfo.login,\n        scopes: userInfo.scopes\n      };\n    } catch (error) {\n      // Token might be invalid or expired\n      ErrorHandler.logError('GitHubAuthManager.checkAuthStatus', error);\n      return {\n        isAuthenticated: false,\n        hasToken: true // Has token but it's invalid\n      };\n    }\n  }\n  \n  /**\n   * Initiate the device flow authentication process\n   */\n  async initiateDeviceFlow(): Promise<DeviceCodeResponse> {\n    const clientId = await GitHubAuthManager.getClientId();\n    // getClientId() always returns a value (env, config, or default)\n    \n    try {\n      const response = await this.fetchWithRetry(GitHubAuthManager.DEVICE_CODE_URL, {\n        method: 'POST',\n        headers: {\n          'Accept': 'application/json',\n          'Content-Type': 'application/json'\n        },\n        body: JSON.stringify({\n          client_id: clientId,\n          scope: 'public_repo read:user'\n        })\n      });\n      \n      if (!response.ok) {\n        // Provide user-friendly error messages based on status codes\n        const errorMessage = this.getErrorMessageForStatus(response.status, 'device flow initialization');\n        logger.debug('Device flow initiation failed', { \n          status: response.status, \n          statusText: response.statusText \n        });\n        throw new Error(errorMessage);\n      }\n      \n      const data = await response.json();\n      \n      // Validate response\n      if (!data.device_code || !data.user_code || !data.verification_uri) {\n        throw new Error('Invalid device flow response from GitHub');\n      }\n      \n      // Log security event for audit trail\n      SecurityMonitor.logSecurityEvent({\n        type: 'TOKEN_VALIDATION_SUCCESS',\n        severity: 'LOW',\n        source: 'GitHubAuthManager.initiateDeviceFlow',\n        details: 'GitHub OAuth device flow initiated successfully',\n        metadata: {\n          userCode: data.user_code,\n          expiresIn: data.expires_in,\n          interval: data.interval\n        }\n      });\n      \n      return data as DeviceCodeResponse;\n    } catch (error) {\n      ErrorHandler.logError('GitHubAuthManager.initiateDeviceFlow', error);\n      \n      // Re-throw if it's already a properly formatted error\n      if (error instanceof Error && error.message.includes('GitHub OAuth')) {\n        throw error;\n      }\n      \n      throw new Error('Failed to start GitHub authentication. Please check your internet connection.');\n    }\n  }\n  \n  /**\n   * Poll for token after user has authorized the device\n   */\n  async pollForToken(deviceCode: string, interval: number = GitHubAuthManager.DEFAULT_POLL_INTERVAL): Promise<TokenResponse> {\n    // Create new abort controller for this polling session\n    this.activePolling = new AbortController();\n    const signal = this.activePolling.signal;\n    \n    let attempts = 0;\n    \n    try {\n      while (attempts < GitHubAuthManager.MAX_POLL_ATTEMPTS) {\n        // Check if polling was aborted\n        if (signal.aborted) {\n          throw new Error('Authentication polling was cancelled');\n        }\n        \n        attempts++;\n        \n        try {\n        const response = await fetch(GitHubAuthManager.TOKEN_URL, {\n          method: 'POST',\n          headers: {\n            'Accept': 'application/json',\n            'Content-Type': 'application/json'\n          },\n          body: JSON.stringify({\n            client_id: await GitHubAuthManager.getClientId() || '',\n            device_code: deviceCode,\n            grant_type: 'urn:ietf:params:oauth:grant-type:device_code'\n          })\n        });\n        \n        const data = await response.json();\n        \n        // Check for various response states\n        if (data.error) {\n          switch (data.error) {\n            case 'authorization_pending':\n              // User hasn't authorized yet, keep polling\n              break;\n              \n            case 'slow_down':\n              // Increase polling interval\n              interval = Math.min(interval * 1.5, 30000); // Max 30 seconds\n              logger.debug('Slowing down polling interval', { newInterval: interval });\n              break;\n              \n            case 'expired_token':\n              throw new Error('The authorization code has expired. Please start over.');\n              \n            case 'access_denied':\n              throw new Error('Authorization was denied. Please try again.');\n              \n            default:\n              // Log the actual error for debugging\n              logger.debug('OAuth device flow error', { \n                error: data.error, \n                description: data.error_description \n              });\n              throw new Error('Authentication failed. Please try starting the process again.');\n          }\n        } else if (data.access_token) {\n          // Success!\n          return data as TokenResponse;\n        }\n        \n        // Wait before next poll\n        // Wait for interval with abort support\n        await this.waitWithAbort(interval, signal);\n        \n      } catch (error) {\n        // Network errors shouldn't stop polling\n        ErrorHandler.logError('GitHubAuthManager.pollForToken', error, { attempt: attempts });\n        await this.waitWithAbort(interval, signal);\n      }\n    }\n    \n    throw new Error('Authentication timed out. Please try again.');\n    } finally {\n      // Clear active polling reference\n      this.activePolling = null;\n    }\n  }\n  \n  /**\n   * Complete the authentication flow and store the token\n   */\n  async completeAuthentication(tokenResponse: TokenResponse): Promise<AuthStatus> {\n    // Store token securely\n    await this.storeToken(tokenResponse.access_token);\n    \n    // Get user info\n    const userInfo = await this.fetchUserInfo(tokenResponse.access_token);\n    \n    // Log successful authentication completion\n    SecurityMonitor.logSecurityEvent({\n      type: 'TOKEN_VALIDATION_SUCCESS',\n      severity: 'LOW',\n      source: 'GitHubAuthManager.completeAuthentication',\n      details: 'GitHub OAuth device flow completed successfully',\n      metadata: {\n        username: userInfo.login,\n        scopes: tokenResponse.scope.split(' '),\n        tokenType: TokenManager.getTokenType(tokenResponse.access_token)\n      }\n    });\n    \n    return {\n      isAuthenticated: true,\n      hasToken: true,\n      username: userInfo.login,\n      scopes: tokenResponse.scope.split(' ')\n    };\n  }\n  \n  /**\n   * Clear stored authentication and revoke token\n   */\n  async clearAuthentication(): Promise<void> {\n    try {\n      // Get the token before clearing it\n      const token = await TokenManager.getGitHubTokenAsync();\n      \n      if (token) {\n        // Attempt to revoke the token on GitHub\n        // Note: GitHub OAuth tokens don't have a revocation endpoint for device flow tokens\n        // But we'll clear the cache and remove from storage\n        \n        // Clear cached user info\n        this.apiCache.clear();\n        \n        // Log security event for audit trail\n        SecurityMonitor.logSecurityEvent({\n          type: 'TOKEN_CACHE_CLEARED',\n          severity: 'LOW',\n          source: 'GitHubAuthManager.clearAuthentication',\n          details: 'GitHub authentication cleared by user request',\n          metadata: {\n            hadToken: true,\n            tokenPrefix: TokenManager.getTokenPrefix(token)\n          }\n        });\n      }\n      \n      // Remove from secure storage\n      await TokenManager.removeStoredToken();\n      \n      logger.info('GitHub authentication cleared successfully');\n    } catch (error) {\n      ErrorHandler.logError('GitHubAuthManager.clearAuthentication', error);\n      throw ErrorHandler.createError('Failed to clear authentication', ErrorCategory.AUTH_ERROR, undefined, error);\n    }\n  }\n  \n  /**\n   * Store token securely using encrypted file storage\n   */\n  private async storeToken(token: string): Promise<void> {\n    try {\n      await TokenManager.storeGitHubToken(token);\n      logger.info('GitHub token stored securely. You are now authenticated!');\n    } catch (error) {\n      ErrorHandler.logError('GitHubAuthManager.storeToken', error);\n      // Fallback to environment variable instructions\n      logger.info('For manual setup, you can set GITHUB_TOKEN environment variable.');\n      throw ErrorHandler.wrapError(error, 'Failed to store GitHub token', ErrorCategory.AUTH_ERROR);\n    }\n  }\n  \n  /**\n   * Fetch user information from GitHub\n   */\n  private async fetchUserInfo(token: string): Promise<any> {\n    // Check cache first\n    const cached = this.apiCache.get(GitHubAuthManager.USER_URL);\n    if (cached) {\n      return cached;\n    }\n    \n    const response = await this.fetchWithRetry(GitHubAuthManager.USER_URL, {\n      headers: {\n        'Authorization': `Bearer ${token}`,\n        'Accept': 'application/vnd.github.v3+json'\n      }\n    });\n    \n    if (!response.ok) {\n      const errorMessage = this.getErrorMessageForStatus(response.status, 'user information fetch');\n      logger.debug('Failed to fetch user info', { status: response.status });\n      throw new Error(errorMessage);\n    }\n    \n    const data = await response.json();\n    \n    // Normalize username and other text fields to prevent Unicode attacks\n    if (data.login) {\n      const validation = UnicodeValidator.normalize(data.login);\n      if (!validation.isValid) {\n        SecurityMonitor.logSecurityEvent({\n          type: 'UNICODE_VALIDATION_ERROR',\n          severity: 'MEDIUM',\n          source: 'GitHubAuthManager.fetchUserInfo',\n          details: 'GitHub username contains invalid Unicode',\n          metadata: { \n            originalLength: data.login.length,\n            detectedIssues: validation.detectedIssues \n          }\n        });\n        throw new Error('Invalid username format from GitHub');\n      }\n      data.login = validation.normalizedContent;\n    }\n    \n    // Normalize display name if present\n    if (data.name) {\n      const nameValidation = UnicodeValidator.normalize(data.name);\n      if (nameValidation.isValid) {\n        data.name = nameValidation.normalizedContent;\n      } else {\n        // Don't fail on display name, just remove it\n        delete data.name;\n      }\n    }\n    \n    // Add scopes from response headers\n    const scopeHeader = response.headers.get('x-oauth-scopes');\n    if (scopeHeader) {\n      data.scopes = scopeHeader.split(',').map(s => s.trim());\n    }\n    \n    // Log successful authentication for audit trail\n    SecurityMonitor.logSecurityEvent({\n      type: 'TOKEN_VALIDATION_SUCCESS',\n      severity: 'LOW',\n      source: 'GitHubAuthManager.fetchUserInfo',\n      details: 'GitHub user authenticated successfully',\n      metadata: {\n        username: data.login,\n        hasEmail: !!data.email,\n        scopes: data.scopes || []\n      }\n    });\n    \n    // Cache the result\n    this.apiCache.set(GitHubAuthManager.USER_URL, data);\n    \n    return data;\n  }\n  \n  /**\n   * Format authentication instructions for users\n   */\n  formatAuthInstructions(deviceResponse: DeviceCodeResponse): string {\n    return `🔐 **GitHub Authentication Required**\n\nTo access all DollhouseMCP features, please authenticate with GitHub:\n\n1. Visit: **${deviceResponse.verification_uri}**\n2. Enter code: **${deviceResponse.user_code}**\n3. Authorize 'DollhouseMCP Collection'\n\nThis will grant access to:\n✅ Browse the public collection\n✅ Install community content  \n✅ Submit your own creations\n\nDon't have a GitHub account? You'll be prompted to create one (it's free!)\n\n⏱️ This code expires in ${Math.floor(deviceResponse.expires_in / 60)} minutes.`;\n  }\n  \n  /**\n   * Check if user needs to authenticate for a specific action\n   */\n  needsAuthForAction(action: string): boolean {\n    const authRequiredActions = ['submit', 'create_pr', 'manage_content'];\n    return authRequiredActions.includes(action.toLowerCase());\n  }\n  \n  /**\n   * Wait with abort signal support\n   */\n  private async waitWithAbort(ms: number, signal: AbortSignal): Promise<void> {\n    return new Promise((resolve, reject) => {\n      const timeout = setTimeout(resolve, ms);\n      \n      // Listen for abort signal\n      const abortHandler = () => {\n        clearTimeout(timeout);\n        reject(new Error('Wait aborted'));\n      };\n      \n      signal.addEventListener('abort', abortHandler, { once: true });\n      \n      // Clean up after timeout\n      setTimeout(() => {\n        signal.removeEventListener('abort', abortHandler);\n      }, ms);\n    });\n  }\n  \n  /**\n   * Clean up any active operations (called on server shutdown)\n   */\n  async cleanup(): Promise<void> {\n    // Abort any active polling\n    if (this.activePolling) {\n      this.activePolling.abort();\n      this.activePolling = null;\n      \n      SecurityMonitor.logSecurityEvent({\n        type: 'TOKEN_CACHE_CLEARED',\n        severity: 'LOW',\n        source: 'GitHubAuthManager.cleanup',\n        details: 'GitHub auth manager cleaned up on shutdown',\n        metadata: {\n          hadActivePolling: true\n        }\n      });\n      \n      logger.info('GitHub authentication polling cancelled due to shutdown');\n    }\n    \n    // Clear API cache\n    this.apiCache.clear();\n  }\n  \n  /**\n   * Get user-friendly error message based on HTTP status code\n   * Avoids exposing sensitive information while providing helpful guidance\n   */\n  private getErrorMessageForStatus(status: number, operation: string): string {\n    switch (status) {\n      case 400:\n        return `Invalid request to GitHub. Please ensure the OAuth app is properly configured.`;\n      case 401:\n        return `GitHub OAuth is not configured. Please report this issue at: https://github.com/DollhouseMCP/mcp-server/issues`;\n      case 403:\n        return `Access denied by GitHub. The OAuth app may lack required permissions.`;\n      case 404:\n        return `GitHub service not found. This may indicate an API change.`;\n      case 422:\n        return `Invalid parameters sent to GitHub. Please check your configuration.`;\n      case 429:\n        return `Too many requests to GitHub. Please wait a moment and try again.`;\n      case 500:\n      case 502:\n      case 503:\n      case 504:\n        return `GitHub service temporarily unavailable. Please try again in a few moments.`;\n      default:\n        // Log the actual status for debugging, but don't expose it to users\n        logger.debug(`Unexpected status code during ${operation}`, { status });\n        return `Failed to complete ${operation}. Please check your internet connection and try again.`;\n    }\n  }\n}"]}
565
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"GitHubAuthManager.js","sourceRoot":"","sources":["../../src/auth/GitHubAuthManager.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * GitHub authentication manager using OAuth device flow\n * Handles authentication for MCP servers without requiring client secrets\n */\n\nimport { TokenManager } from '../security/tokenManager.js';\nimport { logger } from '../utils/logger.js';\nimport { APICache } from '../cache/APICache.js';\nimport { UnicodeValidator } from '../security/validators/unicodeValidator.js';\nimport { SecurityMonitor } from '../security/securityMonitor.js';\nimport { ErrorHandler, ErrorCategory } from '../utils/ErrorHandler.js';\nimport { ConfigManager } from '../config/ConfigManager.js';\n\nexport interface DeviceCodeResponse {\n  device_code: string;\n  user_code: string;\n  verification_uri: string;\n  expires_in: number;\n  interval: number;\n}\n\nexport interface TokenResponse {\n  access_token: string;\n  token_type: string;\n  scope: string;\n}\n\nexport interface AuthStatus {\n  isAuthenticated: boolean;\n  hasToken: boolean;\n  username?: string;\n  scopes?: string[];\n  expiresAt?: Date;\n}\n\n/**\n * Manages GitHub authentication using the OAuth device flow\n * This is the recommended approach for CLI/desktop applications\n */\nexport class GitHubAuthManager {\n  /**\n   * DollhouseMCP's official OAuth App Client ID\n   * This is PUBLIC information - OAuth Client IDs are meant to be visible.\n   * Only Client Secrets are private (device flow doesn't use secrets).\n   * \n   * This Client ID enables the GitHub device flow authentication\n   * allowing users to authenticate with an 8-character code.\n   */\n  private static readonly DEFAULT_CLIENT_ID = 'Ov23li9gyNZP6m9aJ2EP';\n  \n  /**\n   * Get the CLIENT_ID from environment variable, ConfigManager, or default\n   * Priority: Environment variable > ConfigManager > Default Client ID\n   * \n   * @returns The OAuth Client ID to use for authentication\n   */\n  public static async getClientId(): Promise<string | null> {\n    // Check environment variable first (for backward compatibility)\n    const envClientId = process.env.DOLLHOUSE_GITHUB_CLIENT_ID;\n    if (envClientId) {\n      logger.debug('Using OAuth Client ID from environment variable');\n      return envClientId;\n    }\n\n    // Check ConfigManager for stored configuration\n    try {\n      const configManager = ConfigManager.getInstance();\n      await configManager.loadConfig();\n      const configClientId = configManager.getGitHubClientId();\n      if (configClientId) {\n        logger.debug('Using OAuth Client ID from config');\n        return configClientId;\n      }\n    } catch (error) {\n      logger.debug('No OAuth Client ID in config', { error });\n    }\n    \n    // Use default DollhouseMCP OAuth App Client ID\n    // This enables \"just works\" experience for NPM installs\n    logger.debug('Using default DollhouseMCP OAuth Client ID');\n    return GitHubAuthManager.DEFAULT_CLIENT_ID;\n  }\n  \n  // GitHub OAuth endpoints\n  private static readonly DEVICE_CODE_URL = 'https://github.com/login/device/code';\n  private static readonly TOKEN_URL = 'https://github.com/login/oauth/access_token';\n  private static readonly USER_URL = 'https://api.github.com/user';\n  \n  // Polling configuration\n  private static readonly DEFAULT_POLL_INTERVAL = 5000; // 5 seconds\n  private static readonly MAX_POLL_ATTEMPTS = 180; // 15 minutes total\n  \n  private apiCache: APICache;\n  private activePolling: AbortController | null = null;\n  \n  constructor(apiCache: APICache) {\n    this.apiCache = apiCache;\n  }\n  \n  /**\n   * Execute a network request with retry logic\n   */\n  private async fetchWithRetry(\n    url: string, \n    options: RequestInit, \n    maxRetries: number = 3,\n    retryDelay: number = 1000\n  ): Promise<Response> {\n    let lastError: Error | null = null;\n    \n    for (let attempt = 1; attempt <= maxRetries; attempt++) {\n      try {\n        const response = await fetch(url, options);\n        return response;\n      } catch (error) {\n        lastError = error as Error;\n        ErrorHandler.logError('GitHubAuthManager.fetchWithRetry', error, { url, attempt });\n        \n        // Check if it's a network error that should be retried\n        const isNetworkError = error instanceof Error && (\n          error.message.includes('ECONNREFUSED') ||\n          error.message.includes('ETIMEDOUT') ||\n          error.message.includes('ENOTFOUND') ||\n          error.message.includes('network')\n        );\n        \n        if (isNetworkError && attempt < maxRetries) {\n          logger.debug(`Network request failed, retrying (${attempt}/${maxRetries})`, {\n            url,\n            error: error.message,\n            nextRetryIn: retryDelay * attempt\n          });\n          \n          // Exponential backoff\n          await new Promise(resolve => setTimeout(resolve, retryDelay * attempt));\n        } else {\n          // Not a network error or last attempt, throw immediately\n          throw error;\n        }\n      }\n    }\n    \n    throw lastError || new Error('Network request failed after all retries');\n  }\n  \n  /**\n   * Check current authentication status\n   */\n  async getAuthStatus(): Promise<AuthStatus> {\n    const token = await TokenManager.getGitHubTokenAsync();\n    \n    if (!token) {\n      return {\n        isAuthenticated: false,\n        hasToken: false\n      };\n    }\n    \n    try {\n      // Try to get user info to validate token\n      const userInfo = await this.fetchUserInfo(token);\n      \n      return {\n        isAuthenticated: true,\n        hasToken: true,\n        username: userInfo.login,\n        scopes: userInfo.scopes\n      };\n    } catch (error) {\n      // Token might be invalid or expired\n      ErrorHandler.logError('GitHubAuthManager.checkAuthStatus', error);\n      return {\n        isAuthenticated: false,\n        hasToken: true // Has token but it's invalid\n      };\n    }\n  }\n  \n  /**\n   * Initiate the device flow authentication process\n   */\n  async initiateDeviceFlow(): Promise<DeviceCodeResponse> {\n    const clientId = await GitHubAuthManager.getClientId();\n    // getClientId() always returns a value (env, config, or default)\n    \n    // Log the OAuth flow step for debugging\n    logger.debug('OAUTH_STEP_1: Getting client ID', { clientId: clientId?.substring(0, 8) + '...' });\n    \n    if (!clientId) {\n      throw new Error('OAUTH_NO_CLIENT_ID: No OAuth client ID configured. Set DOLLHOUSE_GITHUB_CLIENT_ID environment variable.');\n    }\n    \n    logger.debug('OAUTH_STEP_2: Initiating device flow', { url: GitHubAuthManager.DEVICE_CODE_URL });\n    \n    try {\n      const response = await this.fetchWithRetry(GitHubAuthManager.DEVICE_CODE_URL, {\n        method: 'POST',\n        headers: {\n          'Accept': 'application/json',\n          'Content-Type': 'application/json'\n        },\n        body: JSON.stringify({\n          client_id: clientId,\n          scope: 'public_repo read:user'\n        })\n      });\n      \n      logger.debug('OAUTH_STEP_3: GitHub response', { \n        status: response.status, \n        statusText: response.statusText,\n        headers: {\n          'x-github-request-id': response.headers.get('x-github-request-id'),\n          'x-ratelimit-remaining': response.headers.get('x-ratelimit-remaining')\n        }\n      });\n      \n      if (!response.ok) {\n        const responseText = await response.text();\n        logger.error('GitHub OAuth endpoint error', { \n          status: response.status,\n          statusText: response.statusText,\n          responseBody: responseText,\n          clientId: clientId?.substring(0, 8) + '...'\n        });\n        \n        // Parse GitHub's error response for specific error codes\n        try {\n          const errorData = JSON.parse(responseText);\n          \n          if (errorData.error === 'unauthorized_client') {\n            throw new Error(`OAUTH_CLIENT_UNAUTHORIZED: OAuth app '${clientId?.substring(0, 8)}...' is not authorized for device flow. The app may need reconfiguration.`);\n          }\n          \n          if (errorData.error === 'invalid_client') {\n            throw new Error(`OAUTH_CLIENT_INVALID: GitHub rejected OAuth client ID '${clientId?.substring(0, 8)}...'. The app may not exist or be disabled.`);\n          }\n          \n          if (errorData.error_description) {\n            throw new Error(`OAUTH_API_ERROR: ${errorData.error_description}`);\n          }\n        } catch (parseError) {\n          // If we can't parse the error, provide HTTP status specific error\n          if (response.status === 401) {\n            throw new Error(`OAUTH_CLIENT_INVALID: GitHub rejected OAuth client ID '${clientId?.substring(0, 8)}...'. The app may not exist or be disabled.`);\n          }\n          \n          if (response.status === 403) {\n            throw new Error(`OAUTH_DEVICE_FLOW_DISABLED: This OAuth app doesn't have device flow enabled. Contact administrator.`);\n          }\n          \n          if (response.status === 429) {\n            throw new Error(`OAUTH_RATE_LIMITED: Too many authentication attempts. Please wait before trying again.`);\n          }\n          \n          throw new Error(`OAUTH_HTTP_${response.status}: GitHub OAuth failed - ${response.statusText}`);\n        }\n      }\n      \n      const data = await response.json();\n      \n      // Validate response\n      if (!data.device_code || !data.user_code || !data.verification_uri) {\n        logger.error('Invalid device flow response structure', { \n          hasDeviceCode: !!data.device_code,\n          hasUserCode: !!data.user_code,\n          hasVerificationUri: !!data.verification_uri\n        });\n        throw new Error('OAUTH_INVALID_RESPONSE: Invalid device flow response from GitHub - missing required fields');\n      }\n      \n      // Log security event for audit trail\n      SecurityMonitor.logSecurityEvent({\n        type: 'TOKEN_VALIDATION_SUCCESS',\n        severity: 'LOW',\n        source: 'GitHubAuthManager.initiateDeviceFlow',\n        details: 'GitHub OAuth device flow initiated successfully',\n        metadata: {\n          userCode: data.user_code,\n          expiresIn: data.expires_in,\n          interval: data.interval\n        }\n      });\n      \n      return data as DeviceCodeResponse;\n    } catch (error) {\n      ErrorHandler.logError('GitHubAuthManager.initiateDeviceFlow', error);\n      \n      // Check if it's a network error\n      if (error instanceof Error) {\n        // Re-throw if it's already a properly formatted error with code\n        if (error.message.startsWith('OAUTH_')) {\n          throw error;\n        }\n        \n        // Format network errors\n        if (error.message.includes('ECONNREFUSED') || \n            error.message.includes('ETIMEDOUT') || \n            error.message.includes('ENOTFOUND')) {\n          throw new Error(`OAUTH_NETWORK_ERROR: Unable to reach GitHub servers (https://github.com/login/device/code). Check your internet connection.`);\n        }\n        \n        if (error.message.includes('network')) {\n          throw new Error(`OAUTH_NETWORK_ERROR: Network error while connecting to GitHub. Please check your internet connection.`);\n        }\n      }\n      \n      // Generic fallback (should rarely happen)\n      throw new Error(`OAUTH_UNKNOWN_ERROR: Failed to start GitHub authentication - ${error instanceof Error ? error.message : 'Unknown error'}`);\n    }\n  }\n  \n  /**\n   * Poll for token after user has authorized the device\n   */\n  async pollForToken(deviceCode: string, interval: number = GitHubAuthManager.DEFAULT_POLL_INTERVAL): Promise<TokenResponse> {\n    // Create new abort controller for this polling session\n    this.activePolling = new AbortController();\n    const signal = this.activePolling.signal;\n    \n    let attempts = 0;\n    \n    try {\n      while (attempts < GitHubAuthManager.MAX_POLL_ATTEMPTS) {\n        // Check if polling was aborted\n        if (signal.aborted) {\n          throw new Error('Authentication polling was cancelled');\n        }\n        \n        attempts++;\n        \n        try {\n        const response = await fetch(GitHubAuthManager.TOKEN_URL, {\n          method: 'POST',\n          headers: {\n            'Accept': 'application/json',\n            'Content-Type': 'application/json'\n          },\n          body: JSON.stringify({\n            client_id: await GitHubAuthManager.getClientId() || '',\n            device_code: deviceCode,\n            grant_type: 'urn:ietf:params:oauth:grant-type:device_code'\n          })\n        });\n        \n        const data = await response.json();\n        \n        // Check for various response states\n        if (data.error) {\n          switch (data.error) {\n            case 'authorization_pending':\n              // User hasn't authorized yet, keep polling\n              break;\n              \n            case 'slow_down':\n              // Increase polling interval\n              interval = Math.min(interval * 1.5, 30000); // Max 30 seconds\n              logger.debug('Slowing down polling interval', { newInterval: interval });\n              break;\n              \n            case 'expired_token':\n              throw new Error('The authorization code has expired. Please start over.');\n              \n            case 'access_denied':\n              throw new Error('Authorization was denied. Please try again.');\n              \n            default:\n              // Log the actual error for debugging\n              logger.debug('OAuth device flow error', { \n                error: data.error, \n                description: data.error_description \n              });\n              throw new Error('Authentication failed. Please try starting the process again.');\n          }\n        } else if (data.access_token) {\n          // Success!\n          return data as TokenResponse;\n        }\n        \n        // Wait before next poll\n        // Wait for interval with abort support\n        await this.waitWithAbort(interval, signal);\n        \n      } catch (error) {\n        // Network errors shouldn't stop polling\n        ErrorHandler.logError('GitHubAuthManager.pollForToken', error, { attempt: attempts });\n        await this.waitWithAbort(interval, signal);\n      }\n    }\n    \n    throw new Error('Authentication timed out. Please try again.');\n    } finally {\n      // Clear active polling reference\n      this.activePolling = null;\n    }\n  }\n  \n  /**\n   * Complete the authentication flow and store the token\n   */\n  async completeAuthentication(tokenResponse: TokenResponse): Promise<AuthStatus> {\n    // Store token securely\n    await this.storeToken(tokenResponse.access_token);\n    \n    // Get user info\n    const userInfo = await this.fetchUserInfo(tokenResponse.access_token);\n    \n    // Log successful authentication completion\n    SecurityMonitor.logSecurityEvent({\n      type: 'TOKEN_VALIDATION_SUCCESS',\n      severity: 'LOW',\n      source: 'GitHubAuthManager.completeAuthentication',\n      details: 'GitHub OAuth device flow completed successfully',\n      metadata: {\n        username: userInfo.login,\n        scopes: tokenResponse.scope.split(' '),\n        tokenType: TokenManager.getTokenType(tokenResponse.access_token)\n      }\n    });\n    \n    return {\n      isAuthenticated: true,\n      hasToken: true,\n      username: userInfo.login,\n      scopes: tokenResponse.scope.split(' ')\n    };\n  }\n  \n  /**\n   * Clear stored authentication and revoke token\n   */\n  async clearAuthentication(): Promise<void> {\n    try {\n      // Get the token before clearing it\n      const token = await TokenManager.getGitHubTokenAsync();\n      \n      if (token) {\n        // Attempt to revoke the token on GitHub\n        // Note: GitHub OAuth tokens don't have a revocation endpoint for device flow tokens\n        // But we'll clear the cache and remove from storage\n        \n        // Clear cached user info\n        this.apiCache.clear();\n        \n        // Log security event for audit trail\n        SecurityMonitor.logSecurityEvent({\n          type: 'TOKEN_CACHE_CLEARED',\n          severity: 'LOW',\n          source: 'GitHubAuthManager.clearAuthentication',\n          details: 'GitHub authentication cleared by user request',\n          metadata: {\n            hadToken: true,\n            tokenPrefix: TokenManager.getTokenPrefix(token)\n          }\n        });\n      }\n      \n      // Remove from secure storage\n      await TokenManager.removeStoredToken();\n      \n      logger.info('GitHub authentication cleared successfully');\n    } catch (error) {\n      ErrorHandler.logError('GitHubAuthManager.clearAuthentication', error);\n      throw ErrorHandler.createError('Failed to clear authentication', ErrorCategory.AUTH_ERROR, undefined, error);\n    }\n  }\n  \n  /**\n   * Store token securely using encrypted file storage\n   */\n  private async storeToken(token: string): Promise<void> {\n    try {\n      await TokenManager.storeGitHubToken(token);\n      logger.info('GitHub token stored securely. You are now authenticated!');\n    } catch (error) {\n      ErrorHandler.logError('GitHubAuthManager.storeToken', error);\n      // Fallback to environment variable instructions\n      logger.info('For manual setup, you can set GITHUB_TOKEN environment variable.');\n      throw ErrorHandler.wrapError(error, 'Failed to store GitHub token', ErrorCategory.AUTH_ERROR);\n    }\n  }\n  \n  /**\n   * Fetch user information from GitHub\n   */\n  private async fetchUserInfo(token: string): Promise<any> {\n    // Check cache first\n    const cached = this.apiCache.get(GitHubAuthManager.USER_URL);\n    if (cached) {\n      return cached;\n    }\n    \n    const response = await this.fetchWithRetry(GitHubAuthManager.USER_URL, {\n      headers: {\n        'Authorization': `Bearer ${token}`,\n        'Accept': 'application/vnd.github.v3+json'\n      }\n    });\n    \n    if (!response.ok) {\n      const errorMessage = this.getErrorMessageForStatus(response.status, 'user information fetch');\n      logger.debug('Failed to fetch user info', { status: response.status });\n      throw new Error(errorMessage);\n    }\n    \n    const data = await response.json();\n    \n    // Normalize username and other text fields to prevent Unicode attacks\n    if (data.login) {\n      const validation = UnicodeValidator.normalize(data.login);\n      if (!validation.isValid) {\n        SecurityMonitor.logSecurityEvent({\n          type: 'UNICODE_VALIDATION_ERROR',\n          severity: 'MEDIUM',\n          source: 'GitHubAuthManager.fetchUserInfo',\n          details: 'GitHub username contains invalid Unicode',\n          metadata: { \n            originalLength: data.login.length,\n            detectedIssues: validation.detectedIssues \n          }\n        });\n        throw new Error('Invalid username format from GitHub');\n      }\n      data.login = validation.normalizedContent;\n    }\n    \n    // Normalize display name if present\n    if (data.name) {\n      const nameValidation = UnicodeValidator.normalize(data.name);\n      if (nameValidation.isValid) {\n        data.name = nameValidation.normalizedContent;\n      } else {\n        // Don't fail on display name, just remove it\n        delete data.name;\n      }\n    }\n    \n    // Add scopes from response headers\n    const scopeHeader = response.headers.get('x-oauth-scopes');\n    if (scopeHeader) {\n      data.scopes = scopeHeader.split(',').map(s => s.trim());\n    }\n    \n    // Log successful authentication for audit trail\n    SecurityMonitor.logSecurityEvent({\n      type: 'TOKEN_VALIDATION_SUCCESS',\n      severity: 'LOW',\n      source: 'GitHubAuthManager.fetchUserInfo',\n      details: 'GitHub user authenticated successfully',\n      metadata: {\n        username: data.login,\n        hasEmail: !!data.email,\n        scopes: data.scopes || []\n      }\n    });\n    \n    // Cache the result\n    this.apiCache.set(GitHubAuthManager.USER_URL, data);\n    \n    return data;\n  }\n  \n  /**\n   * Format authentication instructions for users\n   */\n  formatAuthInstructions(deviceResponse: DeviceCodeResponse): string {\n    return `🔐 **GitHub Authentication Required**\n\nTo access all DollhouseMCP features, please authenticate with GitHub:\n\n1. Visit: **${deviceResponse.verification_uri}**\n2. Enter code: **${deviceResponse.user_code}**\n3. Authorize 'DollhouseMCP Collection'\n\nThis will grant access to:\n✅ Browse the public collection\n✅ Install community content  \n✅ Submit your own creations\n\nDon't have a GitHub account? You'll be prompted to create one (it's free!)\n\n⏱️ This code expires in ${Math.floor(deviceResponse.expires_in / 60)} minutes.`;\n  }\n  \n  /**\n   * Check if user needs to authenticate for a specific action\n   */\n  needsAuthForAction(action: string): boolean {\n    const authRequiredActions = ['submit', 'create_pr', 'manage_content'];\n    return authRequiredActions.includes(action.toLowerCase());\n  }\n  \n  /**\n   * Wait with abort signal support\n   */\n  private async waitWithAbort(ms: number, signal: AbortSignal): Promise<void> {\n    return new Promise((resolve, reject) => {\n      const timeout = setTimeout(resolve, ms);\n      \n      // Listen for abort signal\n      const abortHandler = () => {\n        clearTimeout(timeout);\n        reject(new Error('Wait aborted'));\n      };\n      \n      signal.addEventListener('abort', abortHandler, { once: true });\n      \n      // Clean up after timeout\n      setTimeout(() => {\n        signal.removeEventListener('abort', abortHandler);\n      }, ms);\n    });\n  }\n  \n  /**\n   * Clean up any active operations (called on server shutdown)\n   */\n  async cleanup(): Promise<void> {\n    // Abort any active polling\n    if (this.activePolling) {\n      this.activePolling.abort();\n      this.activePolling = null;\n      \n      SecurityMonitor.logSecurityEvent({\n        type: 'TOKEN_CACHE_CLEARED',\n        severity: 'LOW',\n        source: 'GitHubAuthManager.cleanup',\n        details: 'GitHub auth manager cleaned up on shutdown',\n        metadata: {\n          hadActivePolling: true\n        }\n      });\n      \n      logger.info('GitHub authentication polling cancelled due to shutdown');\n    }\n    \n    // Clear API cache\n    this.apiCache.clear();\n  }\n  \n  /**\n   * Get user-friendly error message based on HTTP status code\n   * Avoids exposing sensitive information while providing helpful guidance\n   */\n  private getErrorMessageForStatus(status: number, operation: string): string {\n    switch (status) {\n      case 400:\n        return `Invalid request to GitHub. Please ensure the OAuth app is properly configured.`;\n      case 401:\n        return `GitHub OAuth is not configured. Please report this issue at: https://github.com/DollhouseMCP/mcp-server/issues`;\n      case 403:\n        return `Access denied by GitHub. The OAuth app may lack required permissions.`;\n      case 404:\n        return `GitHub service not found. This may indicate an API change.`;\n      case 422:\n        return `Invalid parameters sent to GitHub. Please check your configuration.`;\n      case 429:\n        return `Too many requests to GitHub. Please wait a moment and try again.`;\n      case 500:\n      case 502:\n      case 503:\n      case 504:\n        return `GitHub service temporarily unavailable. Please try again in a few moments.`;\n      default:\n        // Log the actual status for debugging, but don't expose it to users\n        logger.debug(`Unexpected status code during ${operation}`, { status });\n        return `Failed to complete ${operation}. Please check your internet connection and try again.`;\n    }\n  }\n}"]}
@@ -2,8 +2,8 @@
2
2
  * Auto-generated file - DO NOT EDIT
3
3
  * Generated at build time by scripts/generate-version.js
4
4
  */
5
- export declare const PACKAGE_VERSION = "1.6.2";
6
- export declare const BUILD_TIMESTAMP = "2025-08-25T22:10:32.929Z";
5
+ export declare const PACKAGE_VERSION = "1.6.3";
6
+ export declare const BUILD_TIMESTAMP = "2025-08-25T23:14:28.135Z";
7
7
  export declare const BUILD_TYPE: 'npm' | 'git';
8
8
  export declare const PACKAGE_NAME = "@dollhousemcp/mcp-server";
9
9
  //# sourceMappingURL=version.d.ts.map
@@ -2,8 +2,8 @@
2
2
  * Auto-generated file - DO NOT EDIT
3
3
  * Generated at build time by scripts/generate-version.js
4
4
  */
5
- export const PACKAGE_VERSION = '1.6.2';
6
- export const BUILD_TIMESTAMP = '2025-08-25T22:10:32.929Z';
5
+ export const PACKAGE_VERSION = '1.6.3';
6
+ export const BUILD_TIMESTAMP = '2025-08-25T23:14:28.135Z';
7
7
  export const BUILD_TYPE = 'npm';
8
8
  export const PACKAGE_NAME = '@dollhousemcp/mcp-server';
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9nZW5lcmF0ZWQvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7O0dBR0c7QUFFSCxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsT0FBTyxDQUFDO0FBQ3ZDLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRywwQkFBMEIsQ0FBQztBQUMxRCxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQWtCLEtBQUssQ0FBQztBQUMvQyxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEF1dG8tZ2VuZXJhdGVkIGZpbGUgLSBETyBOT1QgRURJVFxuICogR2VuZXJhdGVkIGF0IGJ1aWxkIHRpbWUgYnkgc2NyaXB0cy9nZW5lcmF0ZS12ZXJzaW9uLmpzXG4gKi9cblxuZXhwb3J0IGNvbnN0IFBBQ0tBR0VfVkVSU0lPTiA9ICcxLjYuMic7XG5leHBvcnQgY29uc3QgQlVJTERfVElNRVNUQU1QID0gJzIwMjUtMDgtMjVUMjI6MTA6MzIuOTI5Wic7XG5leHBvcnQgY29uc3QgQlVJTERfVFlQRTogJ25wbScgfCAnZ2l0JyA9ICducG0nO1xuZXhwb3J0IGNvbnN0IFBBQ0tBR0VfTkFNRSA9ICdAZG9sbGhvdXNlbWNwL21jcC1zZXJ2ZXInO1xuIl19
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9nZW5lcmF0ZWQvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7O0dBR0c7QUFFSCxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsT0FBTyxDQUFDO0FBQ3ZDLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRywwQkFBMEIsQ0FBQztBQUMxRCxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQWtCLEtBQUssQ0FBQztBQUMvQyxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEF1dG8tZ2VuZXJhdGVkIGZpbGUgLSBETyBOT1QgRURJVFxuICogR2VuZXJhdGVkIGF0IGJ1aWxkIHRpbWUgYnkgc2NyaXB0cy9nZW5lcmF0ZS12ZXJzaW9uLmpzXG4gKi9cblxuZXhwb3J0IGNvbnN0IFBBQ0tBR0VfVkVSU0lPTiA9ICcxLjYuMyc7XG5leHBvcnQgY29uc3QgQlVJTERfVElNRVNUQU1QID0gJzIwMjUtMDgtMjVUMjM6MTQ6MjguMTM1Wic7XG5leHBvcnQgY29uc3QgQlVJTERfVFlQRTogJ25wbScgfCAnZ2l0JyA9ICducG0nO1xuZXhwb3J0IGNvbnN0IFBBQ0tBR0VfTkFNRSA9ICdAZG9sbGhvdXNlbWNwL21jcC1zZXJ2ZXInO1xuIl19
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}