@dollhousemcp/mcp-server 1.5.2 → 1.6.0
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 +56 -0
- package/README.md +494 -111
- package/data/agents/code-reviewer.md +8 -1
- package/data/agents/research-assistant.md +8 -1
- package/data/agents/task-manager.md +8 -1
- package/data/ensembles/business-advisor.md +8 -1
- package/data/ensembles/creative-studio.md +8 -1
- package/data/ensembles/development-team.md +8 -1
- package/data/ensembles/security-analysis-team.md +8 -1
- package/data/memories/conversation-history.md +8 -1
- package/data/memories/learning-progress.md +8 -1
- package/data/memories/project-context.md +8 -1
- package/data/personas/business-consultant.md +8 -1
- package/data/personas/creative-writer.md +8 -1
- package/data/personas/debug-detective.md +8 -1
- package/data/personas/eli5-explainer.md +8 -1
- package/data/personas/security-analyst.md +8 -1
- package/data/personas/technical-analyst.md +8 -1
- package/data/skills/code-review.md +8 -1
- package/data/skills/creative-writing.md +8 -1
- package/data/skills/data-analysis.md +8 -1
- package/data/skills/penetration-testing.md +8 -1
- package/data/skills/research.md +8 -1
- package/data/skills/threat-modeling.md +8 -1
- package/data/skills/translation.md +8 -1
- package/data/templates/code-documentation.md +8 -1
- package/data/templates/email-professional.md +8 -1
- package/data/templates/meeting-notes.md +8 -1
- package/data/templates/penetration-test-report.md +8 -1
- package/data/templates/project-brief.md +8 -1
- package/data/templates/report-executive.md +8 -1
- package/data/templates/security-vulnerability-report.md +8 -1
- package/data/templates/threat-assessment-report.md +8 -1
- package/dist/auth/GitHubAuthManager.d.ts +6 -1
- package/dist/auth/GitHubAuthManager.d.ts.map +1 -1
- package/dist/auth/GitHubAuthManager.js +45 -18
- package/dist/benchmarks/IndexPerformanceBenchmark.d.ts +98 -0
- package/dist/benchmarks/IndexPerformanceBenchmark.d.ts.map +1 -0
- package/dist/benchmarks/IndexPerformanceBenchmark.js +531 -0
- package/dist/cache/CollectionCache.d.ts.map +1 -1
- package/dist/cache/CollectionCache.js +13 -3
- package/dist/cache/CollectionIndexCache.d.ts +77 -0
- package/dist/cache/CollectionIndexCache.d.ts.map +1 -0
- package/dist/cache/CollectionIndexCache.js +349 -0
- package/dist/cache/LRUCache.d.ts +93 -0
- package/dist/cache/LRUCache.d.ts.map +1 -0
- package/dist/cache/LRUCache.js +299 -0
- package/dist/cache/index.d.ts +1 -0
- package/dist/cache/index.d.ts.map +1 -1
- package/dist/cache/index.js +2 -1
- package/dist/collection/CollectionBrowser.d.ts +21 -1
- package/dist/collection/CollectionBrowser.d.ts.map +1 -1
- package/dist/collection/CollectionBrowser.js +130 -10
- package/dist/collection/CollectionIndexManager.d.ts +151 -0
- package/dist/collection/CollectionIndexManager.d.ts.map +1 -0
- package/dist/collection/CollectionIndexManager.js +499 -0
- package/dist/collection/CollectionSearch.d.ts +55 -0
- package/dist/collection/CollectionSearch.d.ts.map +1 -1
- package/dist/collection/CollectionSearch.js +338 -13
- package/dist/collection/CollectionSeeder.d.ts.map +1 -1
- package/dist/collection/CollectionSeeder.js +38 -1
- package/dist/collection/ElementInstaller.d.ts +31 -0
- package/dist/collection/ElementInstaller.d.ts.map +1 -1
- package/dist/collection/ElementInstaller.js +77 -15
- package/dist/collection/PersonaSubmitter.d.ts +1 -1
- package/dist/collection/PersonaSubmitter.d.ts.map +1 -1
- package/dist/collection/PersonaSubmitter.js +2 -2
- package/dist/collection/index.d.ts +1 -0
- package/dist/collection/index.d.ts.map +1 -1
- package/dist/collection/index.js +2 -1
- package/dist/config/ConfigManager.d.ts +78 -0
- package/dist/config/ConfigManager.d.ts.map +1 -0
- package/dist/config/ConfigManager.js +216 -0
- package/dist/config/element-types.d.ts +135 -0
- package/dist/config/element-types.d.ts.map +1 -0
- package/dist/config/element-types.js +108 -0
- package/dist/config/index.d.ts +2 -0
- package/dist/config/index.d.ts.map +1 -1
- package/dist/config/index.js +3 -1
- package/dist/config/portfolio-constants.d.ts +83 -0
- package/dist/config/portfolio-constants.d.ts.map +1 -0
- package/dist/config/portfolio-constants.js +99 -0
- package/dist/elements/BaseElement.d.ts +14 -2
- package/dist/elements/BaseElement.d.ts.map +1 -1
- package/dist/elements/BaseElement.js +88 -6
- package/dist/elements/agents/Agent.d.ts +10 -1
- package/dist/elements/agents/Agent.d.ts.map +1 -1
- package/dist/elements/agents/Agent.js +66 -19
- package/dist/elements/agents/AgentManager.d.ts +2 -0
- package/dist/elements/agents/AgentManager.d.ts.map +1 -1
- package/dist/elements/agents/AgentManager.js +12 -10
- package/dist/elements/skills/Skill.d.ts +10 -1
- package/dist/elements/skills/Skill.d.ts.map +1 -1
- package/dist/elements/skills/Skill.js +40 -3
- package/dist/elements/skills/SkillManager.d.ts +1 -0
- package/dist/elements/skills/SkillManager.d.ts.map +1 -1
- package/dist/elements/skills/SkillManager.js +10 -4
- package/dist/elements/templates/Template.d.ts +10 -1
- package/dist/elements/templates/Template.d.ts.map +1 -1
- package/dist/elements/templates/Template.js +35 -18
- package/dist/elements/templates/TemplateManager.d.ts +1 -1
- package/dist/elements/templates/TemplateManager.d.ts.map +1 -1
- package/dist/elements/templates/TemplateManager.js +6 -5
- package/dist/generated/version.d.ts +2 -2
- package/dist/generated/version.js +3 -3
- package/dist/index.barrel.d.ts +1 -2
- package/dist/index.barrel.d.ts.map +1 -1
- package/dist/index.barrel.js +2 -4
- package/dist/index.d.ts +143 -25
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1883 -310
- package/dist/persona/PersonaElement.d.ts +10 -0
- package/dist/persona/PersonaElement.d.ts.map +1 -1
- package/dist/persona/PersonaElement.js +55 -32
- package/dist/persona/PersonaElementManager.d.ts.map +1 -1
- package/dist/persona/PersonaElementManager.js +13 -11
- package/dist/persona/PersonaLoader.d.ts.map +1 -1
- package/dist/persona/PersonaLoader.js +8 -2
- package/dist/persona/export-import/PersonaImporter.d.ts.map +1 -1
- package/dist/persona/export-import/PersonaImporter.js +24 -5
- package/dist/persona/export-import/PersonaSharer.d.ts +21 -0
- package/dist/persona/export-import/PersonaSharer.d.ts.map +1 -1
- package/dist/persona/export-import/PersonaSharer.js +198 -22
- package/dist/portfolio/DefaultElementProvider.d.ts +90 -0
- package/dist/portfolio/DefaultElementProvider.d.ts.map +1 -1
- package/dist/portfolio/DefaultElementProvider.js +499 -7
- package/dist/portfolio/GitHubPortfolioIndexer.d.ts +129 -0
- package/dist/portfolio/GitHubPortfolioIndexer.d.ts.map +1 -0
- package/dist/portfolio/GitHubPortfolioIndexer.js +475 -0
- package/dist/portfolio/MigrationManager.d.ts.map +1 -1
- package/dist/portfolio/MigrationManager.js +136 -3
- package/dist/portfolio/PortfolioIndexManager.d.ts +130 -0
- package/dist/portfolio/PortfolioIndexManager.d.ts.map +1 -0
- package/dist/portfolio/PortfolioIndexManager.js +478 -0
- package/dist/portfolio/PortfolioManager.d.ts +5 -0
- package/dist/portfolio/PortfolioManager.d.ts.map +1 -1
- package/dist/portfolio/PortfolioManager.js +61 -20
- package/dist/portfolio/PortfolioRepoManager.d.ts +75 -0
- package/dist/portfolio/PortfolioRepoManager.d.ts.map +1 -0
- package/dist/portfolio/PortfolioRepoManager.js +337 -0
- package/dist/portfolio/UnifiedIndexManager.d.ts +388 -0
- package/dist/portfolio/UnifiedIndexManager.d.ts.map +1 -0
- package/dist/portfolio/UnifiedIndexManager.js +1434 -0
- package/dist/portfolio/index.d.ts +15 -0
- package/dist/portfolio/index.d.ts.map +1 -0
- package/dist/portfolio/index.js +15 -0
- package/dist/portfolio/types.d.ts +7 -0
- package/dist/portfolio/types.d.ts.map +1 -1
- package/dist/portfolio/types.js +6 -1
- package/dist/security/InputValidator.d.ts.map +1 -1
- package/dist/security/InputValidator.js +50 -48
- package/dist/security/audit/SecurityAuditor.d.ts.map +1 -1
- package/dist/security/audit/SecurityAuditor.js +17 -9
- package/dist/security/audit/config/suppressions.d.ts.map +1 -1
- package/dist/security/audit/config/suppressions.js +19 -3
- package/dist/security/contentValidator.d.ts +2 -0
- package/dist/security/contentValidator.d.ts.map +1 -1
- package/dist/security/contentValidator.js +115 -4
- package/dist/security/secureYamlParser.d.ts +1 -0
- package/dist/security/secureYamlParser.d.ts.map +1 -1
- package/dist/security/secureYamlParser.js +29 -7
- package/dist/security/securityMonitor.d.ts +1 -1
- package/dist/security/securityMonitor.d.ts.map +1 -1
- package/dist/security/securityMonitor.js +1 -1
- package/dist/security/tokenManager.d.ts +1 -1
- package/dist/security/tokenManager.d.ts.map +1 -1
- package/dist/security/tokenManager.js +30 -10
- package/dist/server/ServerSetup.d.ts +22 -2
- package/dist/server/ServerSetup.d.ts.map +1 -1
- package/dist/server/ServerSetup.js +77 -12
- package/dist/server/tools/AuthTools.d.ts.map +1 -1
- package/dist/server/tools/AuthTools.js +33 -1
- package/dist/server/tools/BuildInfoTools.d.ts +25 -0
- package/dist/server/tools/BuildInfoTools.d.ts.map +1 -0
- package/dist/server/tools/BuildInfoTools.js +36 -0
- package/dist/server/tools/CollectionTools.d.ts.map +1 -1
- package/dist/server/tools/CollectionTools.js +55 -46
- package/dist/server/tools/ConfigTools.d.ts.map +1 -1
- package/dist/server/tools/ConfigTools.js +29 -1
- package/dist/server/tools/PersonaTools.d.ts +4 -2
- package/dist/server/tools/PersonaTools.d.ts.map +1 -1
- package/dist/server/tools/PersonaTools.js +5 -152
- package/dist/server/tools/PortfolioTools.d.ts +12 -0
- package/dist/server/tools/PortfolioTools.d.ts.map +1 -0
- package/dist/server/tools/PortfolioTools.js +221 -0
- package/dist/server/tools/index.d.ts +3 -1
- package/dist/server/tools/index.d.ts.map +1 -1
- package/dist/server/tools/index.js +4 -2
- package/dist/server/types.d.ts +40 -5
- package/dist/server/types.d.ts.map +1 -1
- package/dist/server/types.js +1 -1
- package/dist/services/BuildInfoService.d.ts +84 -0
- package/dist/services/BuildInfoService.d.ts.map +1 -0
- package/dist/services/BuildInfoService.js +271 -0
- package/dist/tools/portfolio/PortfolioElementAdapter.d.ts +54 -0
- package/dist/tools/portfolio/PortfolioElementAdapter.d.ts.map +1 -0
- package/dist/tools/portfolio/PortfolioElementAdapter.js +229 -0
- package/dist/tools/portfolio/submitToPortfolioTool.d.ts +164 -0
- package/dist/tools/portfolio/submitToPortfolioTool.d.ts.map +1 -0
- package/dist/tools/portfolio/submitToPortfolioTool.js +1523 -0
- package/dist/tools/portfolio/types.d.ts +41 -0
- package/dist/tools/portfolio/types.d.ts.map +1 -0
- package/dist/tools/portfolio/types.js +15 -0
- package/dist/types/collection.d.ts +51 -0
- package/dist/types/collection.d.ts.map +1 -1
- package/dist/types/collection.js +1 -1
- package/dist/utils/EarlyTerminationSearch.d.ts +41 -0
- package/dist/utils/EarlyTerminationSearch.d.ts.map +1 -0
- package/dist/utils/EarlyTerminationSearch.js +164 -0
- package/dist/utils/ErrorHandler.d.ts +86 -0
- package/dist/utils/ErrorHandler.d.ts.map +1 -0
- package/dist/utils/ErrorHandler.js +201 -0
- package/dist/utils/FileDiscoveryUtil.d.ts +53 -0
- package/dist/utils/FileDiscoveryUtil.d.ts.map +1 -0
- package/dist/utils/FileDiscoveryUtil.js +169 -0
- package/dist/utils/GitHubRateLimiter.d.ts +88 -0
- package/dist/utils/GitHubRateLimiter.d.ts.map +1 -0
- package/dist/utils/GitHubRateLimiter.js +315 -0
- package/dist/utils/PerformanceMonitor.d.ts +134 -0
- package/dist/utils/PerformanceMonitor.d.ts.map +1 -0
- package/dist/utils/PerformanceMonitor.js +347 -0
- package/dist/utils/RateLimiter.d.ts.map +1 -0
- package/dist/utils/RateLimiter.js +172 -0
- package/dist/utils/SecureDownloader.d.ts +241 -0
- package/dist/utils/SecureDownloader.d.ts.map +1 -0
- package/dist/utils/SecureDownloader.js +759 -0
- package/dist/utils/ToolCache.d.ts +82 -0
- package/dist/utils/ToolCache.d.ts.map +1 -0
- package/dist/utils/ToolCache.js +196 -0
- package/dist/utils/errorCodes.d.ts +136 -0
- package/dist/utils/errorCodes.d.ts.map +1 -0
- package/dist/utils/errorCodes.js +87 -0
- package/dist/utils/index.d.ts +3 -0
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +4 -1
- package/dist/utils/installation.d.ts +1 -1
- package/dist/utils/installation.d.ts.map +1 -1
- package/dist/utils/installation.js +9 -8
- package/dist/utils/searchUtils.d.ts +31 -0
- package/dist/utils/searchUtils.d.ts.map +1 -1
- package/dist/utils/searchUtils.js +62 -1
- package/package.json +17 -7
- package/dist/config/updateConfig.d.ts +0 -84
- package/dist/config/updateConfig.d.ts.map +0 -1
- package/dist/config/updateConfig.js +0 -148
- package/dist/server/tools/UpdateTools.d.ts +0 -10
- package/dist/server/tools/UpdateTools.d.ts.map +0 -1
- package/dist/server/tools/UpdateTools.js +0 -85
- package/dist/update/BackupManager.d.ts +0 -63
- package/dist/update/BackupManager.d.ts.map +0 -1
- package/dist/update/BackupManager.js +0 -370
- package/dist/update/DependencyChecker.d.ts +0 -41
- package/dist/update/DependencyChecker.d.ts.map +0 -1
- package/dist/update/DependencyChecker.js +0 -132
- package/dist/update/RateLimiter.d.ts.map +0 -1
- package/dist/update/RateLimiter.js +0 -172
- package/dist/update/SignatureVerifier.d.ts +0 -71
- package/dist/update/SignatureVerifier.d.ts.map +0 -1
- package/dist/update/SignatureVerifier.js +0 -214
- package/dist/update/UpdateChecker.d.ts +0 -132
- package/dist/update/UpdateChecker.d.ts.map +0 -1
- package/dist/update/UpdateChecker.js +0 -506
- package/dist/update/UpdateManager.d.ts +0 -60
- package/dist/update/UpdateManager.d.ts.map +0 -1
- package/dist/update/UpdateManager.js +0 -730
- package/dist/update/VersionManager.d.ts +0 -31
- package/dist/update/VersionManager.d.ts.map +0 -1
- package/dist/update/VersionManager.js +0 -181
- package/dist/update/index.d.ts +0 -9
- package/dist/update/index.d.ts.map +0 -1
- package/dist/update/index.js +0 -9
- /package/dist/{update → utils}/RateLimiter.d.ts +0 -0
|
@@ -7,6 +7,7 @@ import matter from 'gray-matter';
|
|
|
7
7
|
import { SecureYamlParser } from '../../security/secureYamlParser.js';
|
|
8
8
|
import { ContentValidator } from '../../security/contentValidator.js';
|
|
9
9
|
import { validateFilename, validatePath, validateContentSize } from '../../security/InputValidator.js';
|
|
10
|
+
import { UnicodeValidator } from '../../security/validators/unicodeValidator.js';
|
|
10
11
|
import { FileLockManager } from '../../security/fileLockManager.js';
|
|
11
12
|
import { generateUniqueId } from '../../utils/filesystem.js';
|
|
12
13
|
import { logger } from '../../utils/logger.js';
|
|
@@ -187,12 +188,18 @@ export class PersonaImporter {
|
|
|
187
188
|
try {
|
|
188
189
|
// Validate metadata
|
|
189
190
|
const metadata = await this.validateAndEnrichMetadata(exportData.metadata);
|
|
190
|
-
// Validate content
|
|
191
|
-
const
|
|
191
|
+
// Validate and normalize Unicode content first
|
|
192
|
+
const unicodeResult = UnicodeValidator.normalize(exportData.content);
|
|
193
|
+
if (unicodeResult.severity === 'critical') {
|
|
194
|
+
throw new Error(`Critical Unicode security threat detected: ${unicodeResult.detectedIssues?.join(', ')}`);
|
|
195
|
+
}
|
|
196
|
+
const unicodeNormalizedContent = unicodeResult.normalizedContent;
|
|
197
|
+
// Then validate content for other security threats
|
|
198
|
+
const validationResult = ContentValidator.validateAndSanitize(unicodeNormalizedContent);
|
|
192
199
|
if (!validationResult.isValid && validationResult.severity === 'critical') {
|
|
193
200
|
throw new Error(`Critical security threat detected: ${validationResult.detectedPatterns?.join(', ')}`);
|
|
194
201
|
}
|
|
195
|
-
const sanitizedContent = validationResult.sanitizedContent ||
|
|
202
|
+
const sanitizedContent = validationResult.sanitizedContent || unicodeNormalizedContent;
|
|
196
203
|
// Generate safe filename
|
|
197
204
|
let filename = validateFilename(exportData.filename || `${metadata.name.toLowerCase().replace(/\s+/g, '-')}.md`);
|
|
198
205
|
// Check for conflicts
|
|
@@ -241,6 +248,18 @@ export class PersonaImporter {
|
|
|
241
248
|
if (!metadata.name || !metadata.description) {
|
|
242
249
|
throw new Error("Missing required fields: name and description");
|
|
243
250
|
}
|
|
251
|
+
// Validate and normalize Unicode in metadata fields
|
|
252
|
+
const nameResult = UnicodeValidator.normalize(metadata.name);
|
|
253
|
+
const descResult = UnicodeValidator.normalize(metadata.description);
|
|
254
|
+
if (nameResult.severity === 'critical') {
|
|
255
|
+
throw new Error(`Critical Unicode security threat in persona name: ${nameResult.detectedIssues?.join(', ')}`);
|
|
256
|
+
}
|
|
257
|
+
if (descResult.severity === 'critical') {
|
|
258
|
+
throw new Error(`Critical Unicode security threat in persona description: ${descResult.detectedIssues?.join(', ')}`);
|
|
259
|
+
}
|
|
260
|
+
// Use normalized values
|
|
261
|
+
metadata.name = nameResult.normalizedContent;
|
|
262
|
+
metadata.description = descResult.normalizedContent;
|
|
244
263
|
// Generate unique_id if missing
|
|
245
264
|
if (!metadata.unique_id) {
|
|
246
265
|
metadata.unique_id = generateUniqueId(metadata.name, this.currentUser || 'imported');
|
|
@@ -250,7 +269,7 @@ export class PersonaImporter {
|
|
|
250
269
|
metadata.author = metadata.author || this.currentUser || 'imported';
|
|
251
270
|
metadata.category = metadata.category || 'custom';
|
|
252
271
|
metadata.created_date = metadata.created_date || new Date().toISOString();
|
|
253
|
-
// Validate with YAML parser for security
|
|
272
|
+
// Validate with YAML parser for security using normalized metadata
|
|
254
273
|
const validated = await SecureYamlParser.parse(matter.stringify('', metadata));
|
|
255
274
|
return validated.data;
|
|
256
275
|
}
|
|
@@ -312,4 +331,4 @@ export class PersonaImporter {
|
|
|
312
331
|
return message;
|
|
313
332
|
}
|
|
314
333
|
}
|
|
315
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUGVyc29uYUltcG9ydGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3BlcnNvbmEvZXhwb3J0LWltcG9ydC9QZXJzb25hSW1wb3J0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxPQUFPLEtBQUssRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUNsQyxPQUFPLEtBQUssSUFBSSxNQUFNLE1BQU0sQ0FBQztBQUM3QixPQUFPLE1BQU0sTUFBTSxhQUFhLENBQUM7QUFHakMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDdEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDdEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFlBQVksRUFBaUIsbUJBQW1CLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN0SCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDcEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDN0QsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBVS9DLE1BQU0sT0FBTyxlQUFlO0lBRWhCO0lBQ0E7SUFGVixZQUNVLFdBQW1CLEVBQ25CLFdBQTBCO1FBRDFCLGdCQUFXLEdBQVgsV0FBVyxDQUFRO1FBQ25CLGdCQUFXLEdBQVgsV0FBVyxDQUFlO0lBQ2pDLENBQUM7SUFFSjs7T0FFRztJQUNILEtBQUssQ0FBQyxhQUFhLENBQUMsTUFBYyxFQUFFLGdCQUFzQyxFQUFFLFNBQVMsR0FBRyxLQUFLO1FBQzNGLElBQUksQ0FBQztZQUNILHdCQUF3QjtZQUN4QixJQUFJLFdBQVcsR0FBMkIsSUFBSSxDQUFDO1lBRS9DLDRCQUE0QjtZQUM1QixJQUFJLE1BQU0sQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLElBQUksTUFBTSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFB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YUFBYSxDQUFDO1FBRTVFLElBQUksT0FBTyxDQUFDLFFBQVEsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDaEMsT0FBTyxJQUFJLGNBQWMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFTLEVBQUUsRUFBRSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQztRQUMxRixDQUFDO1FBRUQsSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUM5QixPQUFPLElBQUksZUFBZSxPQUFPLENBQUMsTUFBTSxDQUFDLE1BQU0sYUFBYSxDQUFDO1lBQzdELE9BQU8sSUFBSSxZQUFZLE9BQU8sQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBUyxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7UUFDcEYsQ0FBQztRQUVELE9BQU8sT0FBTyxDQUFDO0lBQ2pCLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogUGVyc29uYSBpbXBvcnQgZnVuY3Rpb25hbGl0eSB3aXRoIHZhbGlkYXRpb25cbiAqL1xuXG5pbXBvcnQgKiBhcyBmcyBmcm9tICdmcy9wcm9taXNlcyc7XG5pbXBvcnQgKiBhcyBwYXRoIGZyb20gJ3BhdGgnO1xuaW1wb3J0IG1hdHRlciBmcm9tICdncmF5LW1hdHRlcic7XG5pbXBvcnQgeyBQZXJzb25hLCBQZXJzb25hTWV0YWRhdGEgfSBmcm9tICcuLi8uLi90eXBlcy9wZXJzb25hLmpzJztcbmltcG9ydCB7IEV4cG9ydGVkUGVyc29uYSwgRXhwb3J0QnVuZGxlIH0gZnJvbSAnLi9QZXJzb25hRXhwb3J0ZXIuanMnO1xuaW1wb3J0IHsgU2VjdXJlWWFtbFBhcnNlciB9IGZyb20gJy4uLy4uL3NlY3VyaXR5L3NlY3VyZVlhbWxQYXJzZXIuanMnO1xuaW1wb3J0IHsgQ29udGVudFZhbGlkYXRvciB9IGZyb20gJy4uLy4uL3NlY3VyaXR5L2NvbnRlbnRWYWxpZGF0b3IuanMnO1xuaW1wb3J0IHsgdmFsaWRhdGVGaWxlbmFtZSwgdmFsaWRhdGVQYXRoLCBzYW5pdGl6ZUlucHV0LCB2YWxpZGF0ZUNvbnRlbnRTaXplIH0gZnJvbSAnLi4vLi4vc2VjdXJpdHkvSW5wdXRWYWxpZGF0b3IuanMnO1xuaW1wb3J0IHsgRmlsZUxvY2tNYW5hZ2VyIH0gZnJvbSAnLi4vLi4vc2VjdXJpdHkvZmlsZUxvY2tNYW5hZ2VyLmpzJztcbmltcG9ydCB7IGdlbmVyYXRlVW5pcXVlSWQgfSBmcm9tICcuLi8uLi91dGlscy9maWxlc3lzdGVtLmpzJztcbmltcG9ydCB7IGxvZ2dlciB9IGZyb20gJy4uLy4uL3V0aWxzL2xvZ2dlci5qcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW1wb3J0UmVzdWx0IHtcbiAgc3VjY2VzczogYm9vbGVhbjtcbiAgbWVzc2FnZTogc3RyaW5nO1xuICBwZXJzb25hPzogUGVyc29uYTtcbiAgZmlsZW5hbWU/OiBzdHJpbmc7XG4gIGNvbmZsaWN0cz86IHN0cmluZ1tdO1xufVxuXG5leHBvcnQgY2xhc3MgUGVyc29uYUltcG9ydGVyIHtcbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBwZXJzb25hc0Rpcjogc3RyaW5nLFxuICAgIHByaXZhdGUgY3VycmVudFVzZXI6IHN0cmluZyB8IG51bGxcbiAgKSB7fVxuXG4gIC8qKlxuICAgKiBJbXBvcnQgYSBwZXJzb25hIGZyb20gdmFyaW91cyBzb3VyY2VzXG4gICAqL1xuICBhc3luYyBpbXBvcnRQZXJzb25hKHNvdXJjZTogc3RyaW5nLCBleGlzdGluZ1BlcnNvbmFzOiBNYXA8c3RyaW5nLCBQZXJzb25hPiwgb3ZlcndyaXRlID0gZmFsc2UpOiBQcm9taXNlPEltcG9ydFJlc3VsdD4ge1xuICAgIHRyeSB7XG4gICAgICAvLyBEZXRlcm1pbmUgc291cmNlIHR5cGVcbiAgICAgIGxldCBwZXJzb25hRGF0YTogRXhwb3J0ZWRQZXJzb25hIHwgbnVsbCA9IG51bGw7XG5cbiAgICAgIC8vIENoZWNrIGlmIGl0J3MgYSBmaWxlIHBhdGhcbiAgICAgIGlmIChzb3VyY2Uuc3RhcnRzV2l0aCgnLycpIHx8IHNvdXJjZS5zdGFydHNXaXRoKCcuLycpIHx8IHNvdXJjZS5lbmRzV2l0aCgnLm1kJykgfHwgc291cmNlLmVuZHNXaXRoKCcuanNvbicpKSB7XG4gICAgICAgIHBlcnNvbmFEYXRhID0gYXdhaXQgdGhpcy5pbXBvcnRGcm9tRmlsZShzb3VyY2UpO1xuICAgICAgfSBcbiAgICAgIC8vIENoZWNrIGlmIGl0J3MgYmFzZTY0IGVuY29kZWRcbiAgICAgIGVsc2UgaWYgKHRoaXMuaXNCYXNlNjQoc291cmNlKSkge1xuICAgICAgICBwZXJzb25hRGF0YSA9IGF3YWl0IHRoaXMuaW1wb3J0RnJvbUJhc2U2NChzb3VyY2UpO1xuICAgICAgfVxuICAgICAgLy8gVHJ5IHBhcnNpbmcgYXMgSlNPTiBkaXJlY3RseVxuICAgICAgZWxzZSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgcGFyc2VkID0gSlNPTi5wYXJzZShzb3VyY2UpO1xuICAgICAgICAgIGlmICh0aGlzLmlzRXhwb3J0QnVuZGxlKHBhcnNlZCkpIHtcbiAgICAgICAgICAgIHJldHVybiB0aGlzLmltcG9ydEJ1bmRsZShwYXJzZWQsIGV4aXN0aW5nUGVyc29uYXMsIG92ZXJ3cml0ZSk7XG4gICAgICAgICAgfSBlbHNlIGlmICh0aGlzLmlzRXhwb3J0ZWRQZXJzb25hKHBhcnNlZCkpIHtcbiAgICAgICAgICAgIHBlcnNvbmFEYXRhID0gcGFyc2VkO1xuICAgICAgICAgIH1cbiAgICAgICAgfSBjYXRjaCB7XG4gICAgICAgICAgLy8gTm90IEpTT04sIG1pZ2h0IGJlIHJhdyBtYXJrZG93blxuICAgICAgICAgIHJldHVybiB0aGlzLmltcG9ydEZyb21NYXJrZG93bihzb3VyY2UsIGV4aXN0aW5nUGVyc29uYXMsIG92ZXJ3cml0ZSk7XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgaWYgKCFwZXJzb25hRGF0YSkge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIHN1Y2Nlc3M6IGZhbHNlLFxuICAgICAgICAgIG1lc3NhZ2U6IFwiQ291bGQgbm90IHBhcnNlIGltcG9ydCBzb3VyY2UuIFBsZWFzZSBwcm92aWRlIGEgZmlsZSBwYXRoLCBKU09OIHN0cmluZywgb3IgYmFzZTY0IGVuY29kZWQgZGF0YS5cIlxuICAgICAgICB9O1xuICAgICAgfVxuXG4gICAgICAvLyBWYWxpZGF0ZSBhbmQgY3JlYXRlIHBlcnNvbmFcbiAgICAgIHJldHVybiBhd2FpdCB0aGlzLmNyZWF0ZVBlcnNvbmFGcm9tRXhwb3J0KHBlcnNvbmFEYXRhLCBleGlzdGluZ1BlcnNvbmFzLCBvdmVyd3JpdGUpO1xuXG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIGxvZ2dlci5lcnJvcignSW1wb3J0IGVycm9yJywgZXJyb3IpO1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgc3VjY2VzczogZmFsc2UsXG4gICAgICAgIG1lc3NhZ2U6IGBJbXBvcnQgZmFpbGVkOiAke2Vycm9yIGluc3RhbmNlb2YgRXJyb3IgPyBlcnJvci5tZXNzYWdlIDogU3RyaW5nKGVycm9yKX1gXG4gICAgICB9O1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBJbXBvcnQgZnJvbSBmaWxlIHBhdGhcbiAgICovXG4gIHByaXZhdGUgYXN5bmMgaW1wb3J0RnJvbUZpbGUoZmlsZVBhdGg6IHN0cmluZyk6IFByb21pc2U8RXhwb3J0ZWRQZXJzb25hIHwgbnVsbD4ge1xuICAgIHRyeSB7XG4gICAgICAvLyBWYWxpZGF0ZSBwYXRoXG4gICAgICBjb25zdCB2YWxpZGF0ZWRQYXRoID0gdmFsaWRhdGVQYXRoKGZpbGVQYXRoKTtcbiAgICAgIGNvbnN0IGNvbnRlbnQgPSBhd2FpdCBmcy5yZWFkRmlsZSh2YWxpZGF0ZWRQYXRoLCAndXRmLTgnKTtcblxuICAgICAgaWYgKGZpbGVQYXRoLmVuZHNXaXRoKCcuanNvbicpKSB7XG4gICAgICAgIGNvbnN0IHBhcnNlZCA9IEpTT04ucGFyc2UoY29udGVudCk7XG4gICAgICAgIGlmICh0aGlzLmlzRXhwb3J0ZWRQZXJzb25hKHBhcnNlZCkpIHtcbiAgICAgICAgICByZXR1cm4gcGFyc2VkO1xuICAgICAgICB9IGVsc2UgaWYgKHRoaXMuaXNFeHBvcnRCdW5kbGUocGFyc2VkKSkge1xuICAgICAgICAgIHRocm93IG5ldyBFcnJvcihcIlRoaXMgaXMgYSBidW5kbGUgZmlsZS4gSXQgd2lsbCBiZSBpbXBvcnRlZCBhcyBtdWx0aXBsZSBwZXJzb25hcy5cIik7XG4gICAgICAgIH1cbiAgICAgIH0gZWxzZSBpZiAoZmlsZVBhdGguZW5kc1dpdGgoJy5tZCcpKSB7XG4gICAgICAgIC8vIFBhcnNlIG1hcmtkb3duIGZpbGVcbiAgICAgICAgY29uc3QgeyBkYXRhLCBjb250ZW50OiBtZENvbnRlbnQgfSA9IG1hdHRlcihjb250ZW50KTtcbiAgICAgICAgY29uc3QgZmlsZW5hbWUgPSBwYXRoLmJhc2VuYW1lKGZpbGVQYXRoKTtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICBtZXRhZGF0YTogZGF0YSBhcyBQZXJzb25hTWV0YWRhdGEsXG4gICAgICAgICAgY29udGVudDogbWRDb250ZW50LFxuICAgICAgICAgIGZpbGVuYW1lOiBmaWxlbmFtZSxcbiAgICAgICAgICBleHBvcnRlZEF0OiBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKClcbiAgICAgICAgfTtcbiAgICAgIH1cbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgbG9nZ2VyLmVycm9yKCdGaWxlIGltcG9ydCBlcnJvcicsIGVycm9yKTtcbiAgICAgIHRocm93IGVycm9yO1xuICAgIH1cbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIC8qKlxuICAgKiBJbXBvcnQgZnJvbSBiYXNlNjQgc3RyaW5nXG4gICAqL1xuICBwcml2YXRlIGFzeW5jIGltcG9ydEZyb21CYXNlNjQoYmFzZTY0OiBzdHJpbmcpOiBQcm9taXNlPEV4cG9ydGVkUGVyc29uYSB8IG51bGw+IHtcbiAgICB0cnkge1xuICAgICAgY29uc3QganNvbiA9IEJ1ZmZlci5mcm9tKGJhc2U2NCwgJ2Jhc2U2NCcpLnRvU3RyaW5nKCd1dGYtOCcpO1xuICAgICAgY29uc3QgcGFyc2VkID0gSlNPTi5wYXJzZShqc29uKTtcbiAgICAgIFxuICAgICAgaWYgKHRoaXMuaXNFeHBvcnRlZFBlcnNvbmEocGFyc2VkKSkge1xuICAgICAgICByZXR1cm4gcGFyc2VkO1xuICAgICAgfSBlbHNlIGlmICh0aGlzLmlzRXhwb3J0QnVuZGxlKHBhcnNlZCkpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKFwiVGhpcyBpcyBhIGJ1bmRsZS4gSXQgd2lsbCBiZSBpbXBvcnRlZCBhcyBtdWx0aXBsZSBwZXJzb25hcy5cIik7XG4gICAgICB9XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIGxvZ2dlci5lcnJvcignQmFzZTY0IGltcG9ydCBlcnJvcicsIGVycm9yKTtcbiAgICB9XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICAvKipcbiAgICogSW1wb3J0IGZyb20gcmF3IG1hcmtkb3duIGNvbnRlbnRcbiAgICovXG4gIHByaXZhdGUgYXN5bmMgaW1wb3J0RnJvbU1hcmtkb3duKGNvbnRlbnQ6IHN0cmluZywgZXhpc3RpbmdQZXJzb25hczogTWFwPHN0cmluZywgUGVyc29uYT4sIG92ZXJ3cml0ZTogYm9vbGVhbik6IFByb21pc2U8SW1wb3J0UmVzdWx0PiB7XG4gICAgdHJ5IHtcbiAgICAgIC8vIFZhbGlkYXRlIGNvbnRlbnQgc2l6ZVxuICAgICAgdmFsaWRhdGVDb250ZW50U2l6ZShjb250ZW50LCAxMDAgKiAxMDI0KTsgLy8gMTAwS0IgbGltaXRcblxuICAgICAgLy8gVHJ5IHRvIHBhcnNlIGFzIG1hcmtkb3duIHdpdGggZnJvbnRtYXR0ZXJcbiAgICAgIGNvbnN0IHsgZGF0YSwgY29udGVudDogbWRDb250ZW50IH0gPSBtYXR0ZXIoY29udGVudCk7XG4gICAgICBcbiAgICAgIGlmICghZGF0YS5uYW1lIHx8ICFkYXRhLmRlc2NyaXB0aW9uKSB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgc3VjY2VzczogZmFsc2UsXG4gICAgICAgICAgbWVzc2FnZTogXCJJbnZhbGlkIHBlcnNvbmEgZm9ybWF0LiBNdXN0IGluY2x1ZGUgbmFtZSBhbmQgZGVzY3JpcHRpb24gaW4gWUFNTCBmcm9udG1hdHRlci5cIlxuICAgICAgICB9O1xuICAgICAgfVxuXG4gICAgICBjb25zdCBtZXRhZGF0YSA9IGRhdGEgYXMgUGVyc29uYU1ldGFkYXRhO1xuICAgICAgY29uc3QgZmlsZW5hbWUgPSBgJHttZXRhZGF0YS5uYW1lLnRvTG93ZXJDYXNlKCkucmVwbGFjZSgvXFxzKy9nLCAnLScpfS5tZGA7XG5cbiAgICAgIGNvbnN0IGV4cG9ydGVkUGVyc29uYTogRXhwb3J0ZWRQZXJzb25hID0ge1xuICAgICAgICBtZXRhZGF0YSxcbiAgICAgICAgY29udGVudDogbWRDb250ZW50LFxuICAgICAgICBmaWxlbmFtZSxcbiAgICAgICAgZXhwb3J0ZWRBdDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxuICAgICAgICBleHBvcnRlZEJ5OiB0aGlzLmN1cnJlbnRVc2VyIHx8IHVuZGVmaW5lZFxuICAgICAgfTtcblxuICAgICAgcmV0dXJuIGF3YWl0IHRoaXMuY3JlYXRlUGVyc29uYUZyb21FeHBvcnQoZXhwb3J0ZWRQZXJzb25hLCBleGlzdGluZ1BlcnNvbmFzLCBvdmVyd3JpdGUpO1xuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICBzdWNjZXNzOiBmYWxzZSxcbiAgICAgICAgbWVzc2FnZTogYEZhaWxlZCB0byBwYXJzZSBtYXJrZG93bjogJHtlcnJvciBpbnN0YW5jZW9mIEVycm9yID8gZXJyb3IubWVzc2FnZSA6IFN0cmluZyhlcnJvcil9YFxuICAgICAgfTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogSW1wb3J0IGEgYnVuZGxlIG9mIHBlcnNvbmFzXG4gICAqL1xuICBwcml2YXRlIGFzeW5jIGltcG9ydEJ1bmRsZShidW5kbGU6IEV4cG9ydEJ1bmRsZSwgZXhpc3RpbmdQZXJzb25hczogTWFwPHN0cmluZywgUGVyc29uYT4sIG92ZXJ3cml0ZTogYm9vbGVhbik6IFByb21pc2U8SW1wb3J0UmVzdWx0PiB7XG4gICAgY29uc3QgcmVzdWx0cyA9IHtcbiAgICAgIHN1Y2Nlc3M6IHRydWUsXG4gICAgICBpbXBvcnRlZDogW10gYXMgc3RyaW5nW10sXG4gICAgICBmYWlsZWQ6IFtdIGFzIHN0cmluZ1tdLFxuICAgICAgY29uZmxpY3RzOiBbXSBhcyBzdHJpbmdbXVxuICAgIH07XG5cbiAgICBmb3IgKGNvbnN0IHBlcnNvbmFEYXRhIG9mIGJ1bmRsZS5wZXJzb25hcykge1xuICAgICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgdGhpcy5jcmVhdGVQZXJzb25hRnJvbUV4cG9ydChwZXJzb25hRGF0YSwgZXhpc3RpbmdQZXJzb25hcywgb3ZlcndyaXRlKTtcbiAgICAgIFxuICAgICAgaWYgKHJlc3VsdC5zdWNjZXNzKSB7XG4gICAgICAgIHJlc3VsdHMuaW1wb3J0ZWQucHVzaChwZXJzb25hRGF0YS5tZXRhZGF0YS5uYW1lKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJlc3VsdHMuZmFpbGVkLnB1c2goYCR7cGVyc29uYURhdGEubWV0YWRhdGEubmFtZX06ICR7cmVzdWx0Lm1lc3NhZ2V9YCk7XG4gICAgICAgIGlmIChyZXN1bHQuY29uZmxpY3RzKSB7XG4gICAgICAgICAgcmVzdWx0cy5jb25mbGljdHMucHVzaCguLi5yZXN1bHQuY29uZmxpY3RzKTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICBzdWNjZXNzOiByZXN1bHRzLmZhaWxlZC5sZW5ndGggPT09IDAsXG4gICAgICBtZXNzYWdlOiB0aGlzLmZvcm1hdEJ1bmRsZUltcG9ydFJlc3VsdChyZXN1bHRzKSxcbiAgICAgIGNvbmZsaWN0czogcmVzdWx0cy5jb25mbGljdHMubGVuZ3RoID4gMCA/IHJlc3VsdHMuY29uZmxpY3RzIDogdW5kZWZpbmVkXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGUgcGVyc29uYSBmcm9tIGV4cG9ydGVkIGRhdGFcbiAgICovXG4gIHByaXZhdGUgYXN5bmMgY3JlYXRlUGVyc29uYUZyb21FeHBvcnQoXG4gICAgZXhwb3J0RGF0YTogRXhwb3J0ZWRQZXJzb25hLCBcbiAgICBleGlzdGluZ1BlcnNvbmFzOiBNYXA8c3RyaW5nLCBQZXJzb25hPiwgXG4gICAgb3ZlcndyaXRlOiBib29sZWFuXG4gICk6IFByb21pc2U8SW1wb3J0UmVzdWx0PiB7XG4gICAgdHJ5IHtcbiAgICAgIC8vIFZhbGlkYXRlIG1ldGFkYXRhXG4gICAgICBjb25zdCBtZXRhZGF0YSA9IGF3YWl0IHRoaXMudmFsaWRhdGVBbmRFbnJpY2hNZXRhZGF0YShleHBvcnREYXRhLm1ldGFkYXRhKTtcbiAgICAgIFxuICAgICAgLy8gVmFsaWRhdGUgY29udGVudFxuICAgICAgY29uc3QgdmFsaWRhdGlvblJlc3VsdCA9IENvbnRlbnRWYWxpZGF0b3IudmFsaWRhdGVBbmRTYW5pdGl6ZShleHBvcnREYXRhLmNvbnRlbnQpO1xuICAgICAgaWYgKCF2YWxpZGF0aW9uUmVzdWx0LmlzVmFsaWQgJiYgdmFsaWRhdGlvblJlc3VsdC5zZXZlcml0eSA9PT0gJ2NyaXRpY2FsJykge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYENyaXRpY2FsIHNlY3VyaXR5IHRocmVhdCBkZXRlY3RlZDogJHt2YWxpZGF0aW9uUmVzdWx0LmRldGVjdGVkUGF0dGVybnM/LmpvaW4oJywgJyl9YCk7XG4gICAgICB9XG4gICAgICBjb25zdCBzYW5pdGl6ZWRDb250ZW50ID0gdmFsaWRhdGlvblJlc3VsdC5zYW5pdGl6ZWRDb250ZW50IHx8IGV4cG9ydERhdGEuY29udGVudDtcblxuICAgICAgLy8gR2VuZXJhdGUgc2FmZSBmaWxlbmFtZVxuICAgICAgbGV0IGZpbGVuYW1lID0gdmFsaWRhdGVGaWxlbmFtZShleHBvcnREYXRhLmZpbGVuYW1lIHx8IGAke21ldGFkYXRhLm5hbWUudG9Mb3dlckNhc2UoKS5yZXBsYWNlKC9cXHMrL2csICctJyl9Lm1kYCk7XG4gICAgICBcbiAgICAgIC8vIENoZWNrIGZvciBjb25mbGljdHNcbiAgICAgIGNvbnN0IGNvbmZsaWN0cyA9IHRoaXMuZmluZENvbmZsaWN0cyhtZXRhZGF0YS5uYW1lLCBmaWxlbmFtZSwgZXhpc3RpbmdQZXJzb25hcyk7XG4gICAgICBpZiAoY29uZmxpY3RzLmxlbmd0aCA+IDAgJiYgIW92ZXJ3cml0ZSkge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIHN1Y2Nlc3M6IGZhbHNlLFxuICAgICAgICAgIG1lc3NhZ2U6IGBQZXJzb25hIGFscmVhZHkgZXhpc3RzOiAke2NvbmZsaWN0cy5qb2luKCcsICcpfS4gVXNlIG92ZXJ3cml0ZT10cnVlIHRvIHJlcGxhY2UuYCxcbiAgICAgICAgICBjb25mbGljdHNcbiAgICAgICAgfTtcbiAgICAgIH1cblxuICAgICAgLy8gQ3JlYXRlIHRoZSBwZXJzb25hIGZpbGVcbiAgICAgIGNvbnN0IHBlcnNvbmFQYXRoID0gcGF0aC5qb2luKHRoaXMucGVyc29uYXNEaXIsIGZpbGVuYW1lKTtcbiAgICAgIGNvbnN0IGZpbGVDb250ZW50ID0gbWF0dGVyLnN0cmluZ2lmeShzYW5pdGl6ZWRDb250ZW50LCBtZXRhZGF0YSk7XG4gICAgICBcbiAgICAgIC8vIFVzZSBmaWxlIGxvY2tpbmcgdG8gcHJldmVudCByYWNlIGNvbmRpdGlvbnNcbiAgICAgIGF3YWl0IEZpbGVMb2NrTWFuYWdlci53aXRoTG9jayhgcGVyc29uYToke21ldGFkYXRhLm5hbWV9YCwgYXN5bmMgKCkgPT4ge1xuICAgICAgICBhd2FpdCBGaWxlTG9ja01hbmFnZXIuYXRvbWljV3JpdGVGaWxlKHBlcnNvbmFQYXRoLCBmaWxlQ29udGVudCk7XG4gICAgICB9KTtcblxuICAgICAgLy8gQ3JlYXRlIHBlcnNvbmEgb2JqZWN0XG4gICAgICBjb25zdCBwZXJzb25hOiBQZXJzb25hID0ge1xuICAgICAgICBtZXRhZGF0YSxcbiAgICAgICAgY29udGVudDogc2FuaXRpemVkQ29udGVudCxcbiAgICAgICAgZmlsZW5hbWUsXG4gICAgICAgIHVuaXF1ZV9pZDogbWV0YWRhdGEudW5pcXVlX2lkIVxuICAgICAgfTtcblxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgc3VjY2VzczogdHJ1ZSxcbiAgICAgICAgbWVzc2FnZTogYFN1Y2Nlc3NmdWxseSBpbXBvcnRlZCBcIiR7bWV0YWRhdGEubmFtZX1cImAsXG4gICAgICAgIHBlcnNvbmEsXG4gICAgICAgIGZpbGVuYW1lXG4gICAgICB9O1xuXG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIGxvZ2dlci5lcnJvcignQ3JlYXRlIHBlcnNvbmEgZXJyb3InLCBlcnJvcik7XG4gICAgICByZXR1cm4ge1xuICAgICAgICBzdWNjZXNzOiBmYWxzZSxcbiAgICAgICAgbWVzc2FnZTogYEZhaWxlZCB0byBjcmVhdGUgcGVyc29uYTogJHtlcnJvciBpbnN0YW5jZW9mIEVycm9yID8gZXJyb3IubWVzc2FnZSA6IFN0cmluZyhlcnJvcil9YFxuICAgICAgfTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogVmFsaWRhdGUgYW5kIGVucmljaCBtZXRhZGF0YVxuICAgKi9cbiAgcHJpdmF0ZSBhc3luYyB2YWxpZGF0ZUFuZEVucmljaE1ldGFkYXRhKG1ldGFkYXRhOiBhbnkpOiBQcm9taXNlPFBlcnNvbmFNZXRhZGF0YT4ge1xuICAgIC8vIEVuc3VyZSByZXF1aXJlZCBmaWVsZHNcbiAgICBpZiAoIW1ldGFkYXRhLm5hbWUgfHwgIW1ldGFkYXRhLmRlc2NyaXB0aW9uKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXCJNaXNzaW5nIHJlcXVpcmVkIGZpZWxkczogbmFtZSBhbmQgZGVzY3JpcHRpb25cIik7XG4gICAgfVxuXG4gICAgLy8gR2VuZXJhdGUgdW5pcXVlX2lkIGlmIG1pc3NpbmdcbiAgICBpZiAoIW1ldGFkYXRhLnVuaXF1ZV9pZCkge1xuICAgICAgbWV0YWRhdGEudW5pcXVlX2lkID0gZ2VuZXJhdGVVbmlxdWVJZChtZXRhZGF0YS5uYW1lLCB0aGlzLmN1cnJlbnRVc2VyIHx8ICdpbXBvcnRlZCcpO1xuICAgIH1cblxuICAgIC8vIFNldCBkZWZhdWx0c1xuICAgIG1ldGFkYXRhLnZlcnNpb24gPSBtZXRhZGF0YS52ZXJzaW9uIHx8ICcxLjAnO1xuICAgIG1ldGFkYXRhLmF1dGhvciA9IG1ldGFkYXRhLmF1dGhvciB8fCB0aGlzLmN1cnJlbnRVc2VyIHx8ICdpbXBvcnRlZCc7XG4gICAgbWV0YWRhdGEuY2F0ZWdvcnkgPSBtZXRhZGF0YS5jYXRlZ29yeSB8fCAnY3VzdG9tJztcbiAgICBtZXRhZGF0YS5jcmVhdGVkX2RhdGUgPSBtZXRhZGF0YS5jcmVhdGVkX2RhdGUgfHwgbmV3IERhdGUoKS50b0lTT1N0cmluZygpO1xuXG4gICAgLy8gVmFsaWRhdGUgd2l0aCBZQU1MIHBhcnNlciBmb3Igc2VjdXJpdHlcbiAgICBjb25zdCB2YWxpZGF0ZWQgPSBhd2FpdCBTZWN1cmVZYW1sUGFyc2VyLnBhcnNlKG1hdHRlci5zdHJpbmdpZnkoJycsIG1ldGFkYXRhKSk7XG5cbiAgICByZXR1cm4gdmFsaWRhdGVkLmRhdGEgYXMgUGVyc29uYU1ldGFkYXRhO1xuICB9XG5cbiAgLyoqXG4gICAqIEZpbmQgY29uZmxpY3RzIHdpdGggZXhpc3RpbmcgcGVyc29uYXNcbiAgICovXG4gIHByaXZhdGUgZmluZENvbmZsaWN0cyhuYW1lOiBzdHJpbmcsIGZpbGVuYW1lOiBzdHJpbmcsIGV4aXN0aW5nUGVyc29uYXM6IE1hcDxzdHJpbmcsIFBlcnNvbmE+KTogc3RyaW5nW10ge1xuICAgIGNvbnN0IGNvbmZsaWN0czogc3RyaW5nW10gPSBbXTtcblxuICAgIGZvciAoY29uc3QgW2tleSwgcGVyc29uYV0gb2YgZXhpc3RpbmdQZXJzb25hcykge1xuICAgICAgaWYgKHBlcnNvbmEubWV0YWRhdGEubmFtZSA9PT0gbmFtZSB8fCBwZXJzb25hLmZpbGVuYW1lID09PSBmaWxlbmFtZSkge1xuICAgICAgICBjb25mbGljdHMucHVzaChrZXkpO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBjb25mbGljdHM7XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2sgaWYgc3RyaW5nIGlzIGJhc2U2NFxuICAgKi9cbiAgcHJpdmF0ZSBpc0Jhc2U2NChzdHI6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIC8vIENoZWNrIGxlbmd0aCBpcyBtdWx0aXBsZSBvZiA0XG4gICAgaWYgKHN0ci5sZW5ndGggJSA0ICE9PSAwKSByZXR1cm4gZmFsc2U7XG4gICAgXG4gICAgLy8gU0VDVVJJVFkgRklYOiBFbnN1cmUgYmFzZTY0IHN0cmluZyBpcyBub3QgZW1wdHlcbiAgICAvLyBQcmV2aW91c2x5OiAvXltBLVphLXowLTkrL10qPXswLDJ9JC8gYWxsb3dlZCBlbXB0eSBzdHJpbmdzXG4gICAgLy8gTm93OiBSZXF1aXJlIGF0IGxlYXN0IG9uZSBjaGFyYWN0ZXIgYmVmb3JlIG9wdGlvbmFsIHBhZGRpbmdcbiAgICByZXR1cm4gL15bQS1aYS16MC05Ky9dKz17MCwyfSQvLnRlc3Qoc3RyKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBUeXBlIGd1YXJkIGZvciBFeHBvcnRlZFBlcnNvbmFcbiAgICovXG4gIHByaXZhdGUgaXNFeHBvcnRlZFBlcnNvbmEob2JqOiBhbnkpOiBvYmogaXMgRXhwb3J0ZWRQZXJzb25hIHtcbiAgICByZXR1cm4gb2JqICYmIFxuICAgICAgdHlwZW9mIG9iai5tZXRhZGF0YSA9PT0gJ29iamVjdCcgJiZcbiAgICAgIHR5cGVvZiBvYmouY29udGVudCA9PT0gJ3N0cmluZycgJiZcbiAgICAgIHR5cGVvZiBvYmouZmlsZW5hbWUgPT09ICdzdHJpbmcnO1xuICB9XG5cbiAgLyoqXG4gICAqIFR5cGUgZ3VhcmQgZm9yIEV4cG9ydEJ1bmRsZVxuICAgKi9cbiAgcHJpdmF0ZSBpc0V4cG9ydEJ1bmRsZShvYmo6IGFueSk6IG9iaiBpcyBFeHBvcnRCdW5kbGUge1xuICAgIHJldHVybiBvYmogJiZcbiAgICAgIHR5cGVvZiBvYmoudmVyc2lvbiA9PT0gJ3N0cmluZycgJiZcbiAgICAgIEFycmF5LmlzQXJyYXkob2JqLnBlcnNvbmFzKSAmJlxuICAgICAgdHlwZW9mIG9iai5wZXJzb25hQ291bnQgPT09ICdudW1iZXInO1xuICB9XG5cbiAgLyoqXG4gICAqIEZvcm1hdCBidW5kbGUgaW1wb3J0IHJlc3VsdHNcbiAgICovXG4gIHByaXZhdGUgZm9ybWF0QnVuZGxlSW1wb3J0UmVzdWx0KHJlc3VsdHM6IGFueSk6IHN0cmluZyB7XG4gICAgbGV0IG1lc3NhZ2UgPSBgQnVuZGxlIEltcG9ydCBTdW1tYXJ5OlxcbmA7XG4gICAgbWVzc2FnZSArPSBg4pyFIFN1Y2Nlc3NmdWxseSBpbXBvcnRlZDogJHtyZXN1bHRzLmltcG9ydGVkLmxlbmd0aH0gcGVyc29uYXNcXG5gO1xuICAgIFxuICAgIGlmIChyZXN1bHRzLmltcG9ydGVkLmxlbmd0aCA+IDApIHtcbiAgICAgIG1lc3NhZ2UgKz0gYEltcG9ydGVkOlxcbiR7cmVzdWx0cy5pbXBvcnRlZC5tYXAoKG46IHN0cmluZykgPT4gYCAgLSAke259YCkuam9pbignXFxuJyl9XFxuYDtcbiAgICB9XG5cbiAgICBpZiAocmVzdWx0cy5mYWlsZWQubGVuZ3RoID4gMCkge1xuICAgICAgbWVzc2FnZSArPSBgXFxu4p2MIEZhaWxlZDogJHtyZXN1bHRzLmZhaWxlZC5sZW5ndGh9IHBlcnNvbmFzXFxuYDtcbiAgICAgIG1lc3NhZ2UgKz0gYEVycm9yczpcXG4ke3Jlc3VsdHMuZmFpbGVkLm1hcCgoZTogc3RyaW5nKSA9PiBgICAtICR7ZX1gKS5qb2luKCdcXG4nKX1gO1xuICAgIH1cblxuICAgIHJldHVybiBtZXNzYWdlO1xuICB9XG59Il19
|
|
334
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUGVyc29uYUltcG9ydGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3BlcnNvbmEvZXhwb3J0LWltcG9ydC9QZXJzb25hSW1wb3J0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxPQUFPLEtBQUssRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUNsQyxPQUFPLEtBQUssSUFBSSxNQUFNLE1BQU0sQ0FBQztBQUM3QixPQUFPLE1BQU0sTUFBTSxhQUFhLENBQUM7QUFHakMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDdEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDdEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFlBQVksRUFBaUIsbUJBQW1CLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN0SCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQztBQUNqRixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDcEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDN0QsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBVS9DLE1BQU0sT0FBTyxlQUFlO0lBRWhCO0lBQ0E7SUFGVixZQUNVLFdBQW1CLEVBQ25CLFdBQTBCO1FBRDFCLGdCQUFXLEdBQVgsV0FBVyxDQUFRO1FBQ25CLGdCQUFXLEdBQVgsV0FBVyxDQUFlO0lBQ2pDLENBQUM7SUFFSjs7T0FFRztJQUNILEtBQUssQ0FBQyxhQUFhLENBQUMsTUFBYyxFQUFFLGdCQUFzQyxFQUFFLFNBQVMsR0FBRyxLQUFLO1FBQzNGLElBQUksQ0FBQztZQUNILHdCQUF3QjtZQUN4QixJQUFJLFdBQVcsR0FBMkIsSUFBSSxDQUFDO1lBRS9DLDRCQUE0QjtZQUM1QixJQUFJLE1BQU0sQ0FBQyxVQUFVLENBQUMsR0FB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QyxFQUFFLENBQUM7WUFDaEMsT0FBTyxJQUFJLGNBQWMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFTLEVBQUUsRUFBRSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQztRQUMxRixDQUFDO1FBRUQsSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUM5QixPQUFPLElBQUksZUFBZSxPQUFPLENBQUMsTUFBTSxDQUFDLE1BQU0sYUFBYSxDQUFDO1lBQzdELE9BQU8sSUFBSSxZQUFZLE9BQU8sQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBUyxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7UUFDcEYsQ0FBQztRQUVELE9BQU8sT0FBTyxDQUFDO0lBQ2pCLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogUGVyc29uYSBpbXBvcnQgZnVuY3Rpb25hbGl0eSB3aXRoIHZhbGlkYXRpb25cbiAqL1xuXG5pbXBvcnQgKiBhcyBmcyBmcm9tICdmcy9wcm9taXNlcyc7XG5pbXBvcnQgKiBhcyBwYXRoIGZyb20gJ3BhdGgnO1xuaW1wb3J0IG1hdHRlciBmcm9tICdncmF5LW1hdHRlcic7XG5pbXBvcnQgeyBQZXJzb25hLCBQZXJzb25hTWV0YWRhdGEgfSBmcm9tICcuLi8uLi90eXBlcy9wZXJzb25hLmpzJztcbmltcG9ydCB7IEV4cG9ydGVkUGVyc29uYSwgRXhwb3J0QnVuZGxlIH0gZnJvbSAnLi9QZXJzb25hRXhwb3J0ZXIuanMnO1xuaW1wb3J0IHsgU2VjdXJlWWFtbFBhcnNlciB9IGZyb20gJy4uLy4uL3NlY3VyaXR5L3NlY3VyZVlhbWxQYXJzZXIuanMnO1xuaW1wb3J0IHsgQ29udGVudFZhbGlkYXRvciB9IGZyb20gJy4uLy4uL3NlY3VyaXR5L2NvbnRlbnRWYWxpZGF0b3IuanMnO1xuaW1wb3J0IHsgdmFsaWRhdGVGaWxlbmFtZSwgdmFsaWRhdGVQYXRoLCBzYW5pdGl6ZUlucHV0LCB2YWxpZGF0ZUNvbnRlbnRTaXplIH0gZnJvbSAnLi4vLi4vc2VjdXJpdHkvSW5wdXRWYWxpZGF0b3IuanMnO1xuaW1wb3J0IHsgVW5pY29kZVZhbGlkYXRvciB9IGZyb20gJy4uLy4uL3NlY3VyaXR5L3ZhbGlkYXRvcnMvdW5pY29kZVZhbGlkYXRvci5qcyc7XG5pbXBvcnQgeyBGaWxlTG9ja01hbmFnZXIgfSBmcm9tICcuLi8uLi9zZWN1cml0eS9maWxlTG9ja01hbmFnZXIuanMnO1xuaW1wb3J0IHsgZ2VuZXJhdGVVbmlxdWVJZCB9IGZyb20gJy4uLy4uL3V0aWxzL2ZpbGVzeXN0ZW0uanMnO1xuaW1wb3J0IHsgbG9nZ2VyIH0gZnJvbSAnLi4vLi4vdXRpbHMvbG9nZ2VyLmpzJztcblxuZXhwb3J0IGludGVyZmFjZSBJbXBvcnRSZXN1bHQge1xuICBzdWNjZXNzOiBib29sZWFuO1xuICBtZXNzYWdlOiBzdHJpbmc7XG4gIHBlcnNvbmE/OiBQZXJzb25hO1xuICBmaWxlbmFtZT86IHN0cmluZztcbiAgY29uZmxpY3RzPzogc3RyaW5nW107XG59XG5cbmV4cG9ydCBjbGFzcyBQZXJzb25hSW1wb3J0ZXIge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHBlcnNvbmFzRGlyOiBzdHJpbmcsXG4gICAgcHJpdmF0ZSBjdXJyZW50VXNlcjogc3RyaW5nIHwgbnVsbFxuICApIHt9XG5cbiAgLyoqXG4gICAqIEltcG9ydCBhIHBlcnNvbmEgZnJvbSB2YXJpb3VzIHNvdXJjZXNcbiAgICovXG4gIGFzeW5jIGltcG9ydFBlcnNvbmEoc291cmNlOiBzdHJpbmcsIGV4aXN0aW5nUGVyc29uYXM6IE1hcDxzdHJpbmcsIFBlcnNvbmE+LCBvdmVyd3JpdGUgPSBmYWxzZSk6IFByb21pc2U8SW1wb3J0UmVzdWx0PiB7XG4gICAgdHJ5IHtcbiAgICAgIC8vIERldGVybWluZSBzb3VyY2UgdHlwZVxuICAgICAgbGV0IHBlcnNvbmFEYXRhOiBFeHBvcnRlZFBlcnNvbmEgfCBudWxsID0gbnVsbDtcblxuICAgICAgLy8gQ2hlY2sgaWYgaXQncyBhIGZpbGUgcGF0aFxuICAgICAgaWYgKHNvdXJjZS5zdGFydHNXaXRoKCcvJykgfHwgc291cmNlLnN0YXJ0c1dpdGgoJy4vJykgfHwgc291cmNlLmVuZHNXaXRoKCcubWQnKSB8fCBzb3VyY2UuZW5kc1dpdGgoJy5qc29uJykpIHtcbiAgICAgICAgcGVyc29uYURhdGEgPSBhd2FpdCB0aGlzLmltcG9ydEZyb21GaWxlKHNvdXJjZSk7XG4gICAgICB9IFxuICAgICAgLy8gQ2hlY2sgaWYgaXQncyBiYXNlNjQgZW5jb2RlZFxuICAgICAgZWxzZSBpZiAodGhpcy5pc0Jhc2U2NChzb3VyY2UpKSB7XG4gICAgICAgIHBlcnNvbmFEYXRhID0gYXdhaXQgdGhpcy5pbXBvcnRGcm9tQmFzZTY0KHNvdXJjZSk7XG4gICAgICB9XG4gICAgICAvLyBUcnkgcGFyc2luZyBhcyBKU09OIGRpcmVjdGx5XG4gICAgICBlbHNlIHtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICBjb25zdCBwYXJzZWQgPSBKU09OLnBhcnNlKHNvdXJjZSk7XG4gICAgICAgICAgaWYgKHRoaXMuaXNFeHBvcnRCdW5kbGUocGFyc2VkKSkge1xuICAgICAgICAgICAgcmV0dXJuIHRoaXMuaW1wb3J0QnVuZGxlKHBhcnNlZCwgZXhpc3RpbmdQZXJzb25hcywgb3ZlcndyaXRlKTtcbiAgICAgICAgICB9IGVsc2UgaWYgKHRoaXMuaXNFeHBvcnRlZFBlcnNvbmEocGFyc2VkKSkge1xuICAgICAgICAgICAgcGVyc29uYURhdGEgPSBwYXJzZWQ7XG4gICAgICAgICAgfVxuICAgICAgICB9IGNhdGNoIHtcbiAgICAgICAgICAvLyBOb3QgSlNPTiwgbWlnaHQgYmUgcmF3IG1hcmtkb3duXG4gICAgICAgICAgcmV0dXJuIHRoaXMuaW1wb3J0RnJvbU1hcmtkb3duKHNvdXJjZSwgZXhpc3RpbmdQZXJzb25hcywgb3ZlcndyaXRlKTtcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBpZiAoIXBlcnNvbmFEYXRhKSB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgc3VjY2VzczogZmFsc2UsXG4gICAgICAgICAgbWVzc2FnZTogXCJDb3VsZCBub3QgcGFyc2UgaW1wb3J0IHNvdXJjZS4gUGxlYXNlIHByb3ZpZGUgYSBmaWxlIHBhdGgsIEpTT04gc3RyaW5nLCBvciBiYXNlNjQgZW5jb2RlZCBkYXRhLlwiXG4gICAgICAgIH07XG4gICAgICB9XG5cbiAgICAgIC8vIFZhbGlkYXRlIGFuZCBjcmVhdGUgcGVyc29uYVxuICAgICAgcmV0dXJuIGF3YWl0IHRoaXMuY3JlYXRlUGVyc29uYUZyb21FeHBvcnQocGVyc29uYURhdGEsIGV4aXN0aW5nUGVyc29uYXMsIG92ZXJ3cml0ZSk7XG5cbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgbG9nZ2VyLmVycm9yKCdJbXBvcnQgZXJyb3InLCBlcnJvcik7XG4gICAgICByZXR1cm4ge1xuICAgICAgICBzdWNjZXNzOiBmYWxzZSxcbiAgICAgICAgbWVzc2FnZTogYEltcG9ydCBmYWlsZWQ6ICR7ZXJyb3IgaW5zdGFuY2VvZiBFcnJvciA/IGVycm9yLm1lc3NhZ2UgOiBTdHJpbmcoZXJyb3IpfWBcbiAgICAgIH07XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEltcG9ydCBmcm9tIGZpbGUgcGF0aFxuICAgKi9cbiAgcHJpdmF0ZSBhc3luYyBpbXBvcnRGcm9tRmlsZShmaWxlUGF0aDogc3RyaW5nKTogUHJvbWlzZTxFeHBvcnRlZFBlcnNvbmEgfCBudWxsPiB7XG4gICAgdHJ5IHtcbiAgICAgIC8vIFZhbGlkYXRlIHBhdGhcbiAgICAgIGNvbnN0IHZhbGlkYXRlZFBhdGggPSB2YWxpZGF0ZVBhdGgoZmlsZVBhdGgpO1xuICAgICAgY29uc3QgY29udGVudCA9IGF3YWl0IGZzLnJlYWRGaWxlKHZhbGlkYXRlZFBhdGgsICd1dGYtOCcpO1xuXG4gICAgICBpZiAoZmlsZVBhdGguZW5kc1dpdGgoJy5qc29uJykpIHtcbiAgICAgICAgY29uc3QgcGFyc2VkID0gSlNPTi5wYXJzZShjb250ZW50KTtcbiAgICAgICAgaWYgKHRoaXMuaXNFeHBvcnRlZFBlcnNvbmEocGFyc2VkKSkge1xuICAgICAgICAgIHJldHVybiBwYXJzZWQ7XG4gICAgICAgIH0gZWxzZSBpZiAodGhpcy5pc0V4cG9ydEJ1bmRsZShwYXJzZWQpKSB7XG4gICAgICAgICAgdGhyb3cgbmV3IEVycm9yKFwiVGhpcyBpcyBhIGJ1bmRsZSBmaWxlLiBJdCB3aWxsIGJlIGltcG9ydGVkIGFzIG11bHRpcGxlIHBlcnNvbmFzLlwiKTtcbiAgICAgICAgfVxuICAgICAgfSBlbHNlIGlmIChmaWxlUGF0aC5lbmRzV2l0aCgnLm1kJykpIHtcbiAgICAgICAgLy8gUGFyc2UgbWFya2Rvd24gZmlsZVxuICAgICAgICBjb25zdCB7IGRhdGEsIGNvbnRlbnQ6IG1kQ29udGVudCB9ID0gbWF0dGVyKGNvbnRlbnQpO1xuICAgICAgICBjb25zdCBmaWxlbmFtZSA9IHBhdGguYmFzZW5hbWUoZmlsZVBhdGgpO1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIG1ldGFkYXRhOiBkYXRhIGFzIFBlcnNvbmFNZXRhZGF0YSxcbiAgICAgICAgICBjb250ZW50OiBtZENvbnRlbnQsXG4gICAgICAgICAgZmlsZW5hbWU6IGZpbGVuYW1lLFxuICAgICAgICAgIGV4cG9ydGVkQXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKVxuICAgICAgICB9O1xuICAgICAgfVxuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICBsb2dnZXIuZXJyb3IoJ0ZpbGUgaW1wb3J0IGVycm9yJywgZXJyb3IpO1xuICAgICAgdGhyb3cgZXJyb3I7XG4gICAgfVxuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgLyoqXG4gICAqIEltcG9ydCBmcm9tIGJhc2U2NCBzdHJpbmdcbiAgICovXG4gIHByaXZhdGUgYXN5bmMgaW1wb3J0RnJvbUJhc2U2NChiYXNlNjQ6IHN0cmluZyk6IFByb21pc2U8RXhwb3J0ZWRQZXJzb25hIHwgbnVsbD4ge1xuICAgIHRyeSB7XG4gICAgICBjb25zdCBqc29uID0gQnVmZmVyLmZyb20oYmFzZTY0LCAnYmFzZTY0JykudG9TdHJpbmcoJ3V0Zi04Jyk7XG4gICAgICBjb25zdCBwYXJzZWQgPSBKU09OLnBhcnNlKGpzb24pO1xuICAgICAgXG4gICAgICBpZiAodGhpcy5pc0V4cG9ydGVkUGVyc29uYShwYXJzZWQpKSB7XG4gICAgICAgIHJldHVybiBwYXJzZWQ7XG4gICAgICB9IGVsc2UgaWYgKHRoaXMuaXNFeHBvcnRCdW5kbGUocGFyc2VkKSkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXCJUaGlzIGlzIGEgYnVuZGxlLiBJdCB3aWxsIGJlIGltcG9ydGVkIGFzIG11bHRpcGxlIHBlcnNvbmFzLlwiKTtcbiAgICAgIH1cbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgbG9nZ2VyLmVycm9yKCdCYXNlNjQgaW1wb3J0IGVycm9yJywgZXJyb3IpO1xuICAgIH1cbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIC8qKlxuICAgKiBJbXBvcnQgZnJvbSByYXcgbWFya2Rvd24gY29udGVudFxuICAgKi9cbiAgcHJpdmF0ZSBhc3luYyBpbXBvcnRGcm9tTWFya2Rvd24oY29udGVudDogc3RyaW5nLCBleGlzdGluZ1BlcnNvbmFzOiBNYXA8c3RyaW5nLCBQZXJzb25hPiwgb3ZlcndyaXRlOiBib29sZWFuKTogUHJvbWlzZTxJbXBvcnRSZXN1bHQ+IHtcbiAgICB0cnkge1xuICAgICAgLy8gVmFsaWRhdGUgY29udGVudCBzaXplXG4gICAgICB2YWxpZGF0ZUNvbnRlbnRTaXplKGNvbnRlbnQsIDEwMCAqIDEwMjQpOyAvLyAxMDBLQiBsaW1pdFxuXG4gICAgICAvLyBUcnkgdG8gcGFyc2UgYXMgbWFya2Rvd24gd2l0aCBmcm9udG1hdHRlclxuICAgICAgY29uc3QgeyBkYXRhLCBjb250ZW50OiBtZENvbnRlbnQgfSA9IG1hdHRlcihjb250ZW50KTtcbiAgICAgIFxuICAgICAgaWYgKCFkYXRhLm5hbWUgfHwgIWRhdGEuZGVzY3JpcHRpb24pIHtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICBzdWNjZXNzOiBmYWxzZSxcbiAgICAgICAgICBtZXNzYWdlOiBcIkludmFsaWQgcGVyc29uYSBmb3JtYXQuIE11c3QgaW5jbHVkZSBuYW1lIGFuZCBkZXNjcmlwdGlvbiBpbiBZQU1MIGZyb250bWF0dGVyLlwiXG4gICAgICAgIH07XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IG1ldGFkYXRhID0gZGF0YSBhcyBQZXJzb25hTWV0YWRhdGE7XG4gICAgICBjb25zdCBmaWxlbmFtZSA9IGAke21ldGFkYXRhLm5hbWUudG9Mb3dlckNhc2UoKS5yZXBsYWNlKC9cXHMrL2csICctJyl9Lm1kYDtcblxuICAgICAgY29uc3QgZXhwb3J0ZWRQZXJzb25hOiBFeHBvcnRlZFBlcnNvbmEgPSB7XG4gICAgICAgIG1ldGFkYXRhLFxuICAgICAgICBjb250ZW50OiBtZENvbnRlbnQsXG4gICAgICAgIGZpbGVuYW1lLFxuICAgICAgICBleHBvcnRlZEF0OiBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCksXG4gICAgICAgIGV4cG9ydGVkQnk6IHRoaXMuY3VycmVudFVzZXIgfHwgdW5kZWZpbmVkXG4gICAgICB9O1xuXG4gICAgICByZXR1cm4gYXdhaXQgdGhpcy5jcmVhdGVQZXJzb25hRnJvbUV4cG9ydChleHBvcnRlZFBlcnNvbmEsIGV4aXN0aW5nUGVyc29uYXMsIG92ZXJ3cml0ZSk7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIHN1Y2Nlc3M6IGZhbHNlLFxuICAgICAgICBtZXNzYWdlOiBgRmFpbGVkIHRvIHBhcnNlIG1hcmtkb3duOiAke2Vycm9yIGluc3RhbmNlb2YgRXJyb3IgPyBlcnJvci5tZXNzYWdlIDogU3RyaW5nKGVycm9yKX1gXG4gICAgICB9O1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBJbXBvcnQgYSBidW5kbGUgb2YgcGVyc29uYXNcbiAgICovXG4gIHByaXZhdGUgYXN5bmMgaW1wb3J0QnVuZGxlKGJ1bmRsZTogRXhwb3J0QnVuZGxlLCBleGlzdGluZ1BlcnNvbmFzOiBNYXA8c3RyaW5nLCBQZXJzb25hPiwgb3ZlcndyaXRlOiBib29sZWFuKTogUHJvbWlzZTxJbXBvcnRSZXN1bHQ+IHtcbiAgICBjb25zdCByZXN1bHRzID0ge1xuICAgICAgc3VjY2VzczogdHJ1ZSxcbiAgICAgIGltcG9ydGVkOiBbXSBhcyBzdHJpbmdbXSxcbiAgICAgIGZhaWxlZDogW10gYXMgc3RyaW5nW10sXG4gICAgICBjb25mbGljdHM6IFtdIGFzIHN0cmluZ1tdXG4gICAgfTtcblxuICAgIGZvciAoY29uc3QgcGVyc29uYURhdGEgb2YgYnVuZGxlLnBlcnNvbmFzKSB7XG4gICAgICBjb25zdCByZXN1bHQgPSBhd2FpdCB0aGlzLmNyZWF0ZVBlcnNvbmFGcm9tRXhwb3J0KHBlcnNvbmFEYXRhLCBleGlzdGluZ1BlcnNvbmFzLCBvdmVyd3JpdGUpO1xuICAgICAgXG4gICAgICBpZiAocmVzdWx0LnN1Y2Nlc3MpIHtcbiAgICAgICAgcmVzdWx0cy5pbXBvcnRlZC5wdXNoKHBlcnNvbmFEYXRhLm1ldGFkYXRhLm5hbWUpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmVzdWx0cy5mYWlsZWQucHVzaChgJHtwZXJzb25hRGF0YS5tZXRhZGF0YS5uYW1lfTogJHtyZXN1bHQubWVzc2FnZX1gKTtcbiAgICAgICAgaWYgKHJlc3VsdC5jb25mbGljdHMpIHtcbiAgICAgICAgICByZXN1bHRzLmNvbmZsaWN0cy5wdXNoKC4uLnJlc3VsdC5jb25mbGljdHMpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIHN1Y2Nlc3M6IHJlc3VsdHMuZmFpbGVkLmxlbmd0aCA9PT0gMCxcbiAgICAgIG1lc3NhZ2U6IHRoaXMuZm9ybWF0QnVuZGxlSW1wb3J0UmVzdWx0KHJlc3VsdHMpLFxuICAgICAgY29uZmxpY3RzOiByZXN1bHRzLmNvbmZsaWN0cy5sZW5ndGggPiAwID8gcmVzdWx0cy5jb25mbGljdHMgOiB1bmRlZmluZWRcbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZSBwZXJzb25hIGZyb20gZXhwb3J0ZWQgZGF0YVxuICAgKi9cbiAgcHJpdmF0ZSBhc3luYyBjcmVhdGVQZXJzb25hRnJvbUV4cG9ydChcbiAgICBleHBvcnREYXRhOiBFeHBvcnRlZFBlcnNvbmEsIFxuICAgIGV4aXN0aW5nUGVyc29uYXM6IE1hcDxzdHJpbmcsIFBlcnNvbmE+LCBcbiAgICBvdmVyd3JpdGU6IGJvb2xlYW5cbiAgKTogUHJvbWlzZTxJbXBvcnRSZXN1bHQ+IHtcbiAgICB0cnkge1xuICAgICAgLy8gVmFsaWRhdGUgbWV0YWRhdGFcbiAgICAgIGNvbnN0IG1ldGFkYXRhID0gYXdhaXQgdGhpcy52YWxpZGF0ZUFuZEVucmljaE1ldGFkYXRhKGV4cG9ydERhdGEubWV0YWRhdGEpO1xuICAgICAgXG4gICAgICAvLyBWYWxpZGF0ZSBhbmQgbm9ybWFsaXplIFVuaWNvZGUgY29udGVudCBmaXJzdFxuICAgICAgY29uc3QgdW5pY29kZVJlc3VsdCA9IFVuaWNvZGVWYWxpZGF0b3Iubm9ybWFsaXplKGV4cG9ydERhdGEuY29udGVudCk7XG4gICAgICBpZiAodW5pY29kZVJlc3VsdC5zZXZlcml0eSA9PT0gJ2NyaXRpY2FsJykge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYENyaXRpY2FsIFVuaWNvZGUgc2VjdXJpdHkgdGhyZWF0IGRldGVjdGVkOiAke3VuaWNvZGVSZXN1bHQuZGV0ZWN0ZWRJc3N1ZXM/LmpvaW4oJywgJyl9YCk7XG4gICAgICB9XG4gICAgICBjb25zdCB1bmljb2RlTm9ybWFsaXplZENvbnRlbnQgPSB1bmljb2RlUmVzdWx0Lm5vcm1hbGl6ZWRDb250ZW50O1xuXG4gICAgICAvLyBUaGVuIHZhbGlkYXRlIGNvbnRlbnQgZm9yIG90aGVyIHNlY3VyaXR5IHRocmVhdHNcbiAgICAgIGNvbnN0IHZhbGlkYXRpb25SZXN1bHQgPSBDb250ZW50VmFsaWRhdG9yLnZhbGlkYXRlQW5kU2FuaXRpemUodW5pY29kZU5vcm1hbGl6ZWRDb250ZW50KTtcbiAgICAgIGlmICghdmFsaWRhdGlvblJlc3VsdC5pc1ZhbGlkICYmIHZhbGlkYXRpb25SZXN1bHQuc2V2ZXJpdHkgPT09ICdjcml0aWNhbCcpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBDcml0aWNhbCBzZWN1cml0eSB0aHJlYXQgZGV0ZWN0ZWQ6ICR7dmFsaWRhdGlvblJlc3VsdC5kZXRlY3RlZFBhdHRlcm5zPy5qb2luKCcsICcpfWApO1xuICAgICAgfVxuICAgICAgY29uc3Qgc2FuaXRpemVkQ29udGVudCA9IHZhbGlkYXRpb25SZXN1bHQuc2FuaXRpemVkQ29udGVudCB8fCB1bmljb2RlTm9ybWFsaXplZENvbnRlbnQ7XG5cbiAgICAgIC8vIEdlbmVyYXRlIHNhZmUgZmlsZW5hbWVcbiAgICAgIGxldCBmaWxlbmFtZSA9IHZhbGlkYXRlRmlsZW5hbWUoZXhwb3J0RGF0YS5maWxlbmFtZSB8fCBgJHttZXRhZGF0YS5uYW1lLnRvTG93ZXJDYXNlKCkucmVwbGFjZSgvXFxzKy9nLCAnLScpfS5tZGApO1xuICAgICAgXG4gICAgICAvLyBDaGVjayBmb3IgY29uZmxpY3RzXG4gICAgICBjb25zdCBjb25mbGljdHMgPSB0aGlzLmZpbmRDb25mbGljdHMobWV0YWRhdGEubmFtZSwgZmlsZW5hbWUsIGV4aXN0aW5nUGVyc29uYXMpO1xuICAgICAgaWYgKGNvbmZsaWN0cy5sZW5ndGggPiAwICYmICFvdmVyd3JpdGUpIHtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICBzdWNjZXNzOiBmYWxzZSxcbiAgICAgICAgICBtZXNzYWdlOiBgUGVyc29uYSBhbHJlYWR5IGV4aXN0czogJHtjb25mbGljdHMuam9pbignLCAnKX0uIFVzZSBvdmVyd3JpdGU9dHJ1ZSB0byByZXBsYWNlLmAsXG4gICAgICAgICAgY29uZmxpY3RzXG4gICAgICAgIH07XG4gICAgICB9XG5cbiAgICAgIC8vIENyZWF0ZSB0aGUgcGVyc29uYSBmaWxlXG4gICAgICBjb25zdCBwZXJzb25hUGF0aCA9IHBhdGguam9pbih0aGlzLnBlcnNvbmFzRGlyLCBmaWxlbmFtZSk7XG4gICAgICBjb25zdCBmaWxlQ29udGVudCA9IG1hdHRlci5zdHJpbmdpZnkoc2FuaXRpemVkQ29udGVudCwgbWV0YWRhdGEpO1xuICAgICAgXG4gICAgICAvLyBVc2UgZmlsZSBsb2NraW5nIHRvIHByZXZlbnQgcmFjZSBjb25kaXRpb25zXG4gICAgICBhd2FpdCBGaWxlTG9ja01hbmFnZXIud2l0aExvY2soYHBlcnNvbmE6JHttZXRhZGF0YS5uYW1lfWAsIGFzeW5jICgpID0+IHtcbiAgICAgICAgYXdhaXQgRmlsZUxvY2tNYW5hZ2VyLmF0b21pY1dyaXRlRmlsZShwZXJzb25hUGF0aCwgZmlsZUNvbnRlbnQpO1xuICAgICAgfSk7XG5cbiAgICAgIC8vIENyZWF0ZSBwZXJzb25hIG9iamVjdFxuICAgICAgY29uc3QgcGVyc29uYTogUGVyc29uYSA9IHtcbiAgICAgICAgbWV0YWRhdGEsXG4gICAgICAgIGNvbnRlbnQ6IHNhbml0aXplZENvbnRlbnQsXG4gICAgICAgIGZpbGVuYW1lLFxuICAgICAgICB1bmlxdWVfaWQ6IG1ldGFkYXRhLnVuaXF1ZV9pZCFcbiAgICAgIH07XG5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIHN1Y2Nlc3M6IHRydWUsXG4gICAgICAgIG1lc3NhZ2U6IGBTdWNjZXNzZnVsbHkgaW1wb3J0ZWQgXCIke21ldGFkYXRhLm5hbWV9XCJgLFxuICAgICAgICBwZXJzb25hLFxuICAgICAgICBmaWxlbmFtZVxuICAgICAgfTtcblxuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICBsb2dnZXIuZXJyb3IoJ0NyZWF0ZSBwZXJzb25hIGVycm9yJywgZXJyb3IpO1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgc3VjY2VzczogZmFsc2UsXG4gICAgICAgIG1lc3NhZ2U6IGBGYWlsZWQgdG8gY3JlYXRlIHBlcnNvbmE6ICR7ZXJyb3IgaW5zdGFuY2VvZiBFcnJvciA/IGVycm9yLm1lc3NhZ2UgOiBTdHJpbmcoZXJyb3IpfWBcbiAgICAgIH07XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFZhbGlkYXRlIGFuZCBlbnJpY2ggbWV0YWRhdGFcbiAgICovXG4gIHByaXZhdGUgYXN5bmMgdmFsaWRhdGVBbmRFbnJpY2hNZXRhZGF0YShtZXRhZGF0YTogYW55KTogUHJvbWlzZTxQZXJzb25hTWV0YWRhdGE+IHtcbiAgICAvLyBFbnN1cmUgcmVxdWlyZWQgZmllbGRzXG4gICAgaWYgKCFtZXRhZGF0YS5uYW1lIHx8ICFtZXRhZGF0YS5kZXNjcmlwdGlvbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFwiTWlzc2luZyByZXF1aXJlZCBmaWVsZHM6IG5hbWUgYW5kIGRlc2NyaXB0aW9uXCIpO1xuICAgIH1cblxuICAgIC8vIFZhbGlkYXRlIGFuZCBub3JtYWxpemUgVW5pY29kZSBpbiBtZXRhZGF0YSBmaWVsZHNcbiAgICBjb25zdCBuYW1lUmVzdWx0ID0gVW5pY29kZVZhbGlkYXRvci5ub3JtYWxpemUobWV0YWRhdGEubmFtZSk7XG4gICAgY29uc3QgZGVzY1Jlc3VsdCA9IFVuaWNvZGVWYWxpZGF0b3Iubm9ybWFsaXplKG1ldGFkYXRhLmRlc2NyaXB0aW9uKTtcbiAgICBcbiAgICBpZiAobmFtZVJlc3VsdC5zZXZlcml0eSA9PT0gJ2NyaXRpY2FsJykge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBDcml0aWNhbCBVbmljb2RlIHNlY3VyaXR5IHRocmVhdCBpbiBwZXJzb25hIG5hbWU6ICR7bmFtZVJlc3VsdC5kZXRlY3RlZElzc3Vlcz8uam9pbignLCAnKX1gKTtcbiAgICB9XG4gICAgaWYgKGRlc2NSZXN1bHQuc2V2ZXJpdHkgPT09ICdjcml0aWNhbCcpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgQ3JpdGljYWwgVW5pY29kZSBzZWN1cml0eSB0aHJlYXQgaW4gcGVyc29uYSBkZXNjcmlwdGlvbjogJHtkZXNjUmVzdWx0LmRldGVjdGVkSXNzdWVzPy5qb2luKCcsICcpfWApO1xuICAgIH1cblxuICAgIC8vIFVzZSBub3JtYWxpemVkIHZhbHVlc1xuICAgIG1ldGFkYXRhLm5hbWUgPSBuYW1lUmVzdWx0Lm5vcm1hbGl6ZWRDb250ZW50O1xuICAgIG1ldGFkYXRhLmRlc2NyaXB0aW9uID0gZGVzY1Jlc3VsdC5ub3JtYWxpemVkQ29udGVudDtcblxuICAgIC8vIEdlbmVyYXRlIHVuaXF1ZV9pZCBpZiBtaXNzaW5nXG4gICAgaWYgKCFtZXRhZGF0YS51bmlxdWVfaWQpIHtcbiAgICAgIG1ldGFkYXRhLnVuaXF1ZV9pZCA9IGdlbmVyYXRlVW5pcXVlSWQobWV0YWRhdGEubmFtZSwgdGhpcy5jdXJyZW50VXNlciB8fCAnaW1wb3J0ZWQnKTtcbiAgICB9XG5cbiAgICAvLyBTZXQgZGVmYXVsdHNcbiAgICBtZXRhZGF0YS52ZXJzaW9uID0gbWV0YWRhdGEudmVyc2lvbiB8fCAnMS4wJztcbiAgICBtZXRhZGF0YS5hdXRob3IgPSBtZXRhZGF0YS5hdXRob3IgfHwgdGhpcy5jdXJyZW50VXNlciB8fCAnaW1wb3J0ZWQnO1xuICAgIG1ldGFkYXRhLmNhdGVnb3J5ID0gbWV0YWRhdGEuY2F0ZWdvcnkgfHwgJ2N1c3RvbSc7XG4gICAgbWV0YWRhdGEuY3JlYXRlZF9kYXRlID0gbWV0YWRhdGEuY3JlYXRlZF9kYXRlIHx8IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKTtcblxuICAgIC8vIFZhbGlkYXRlIHdpdGggWUFNTCBwYXJzZXIgZm9yIHNlY3VyaXR5IHVzaW5nIG5vcm1hbGl6ZWQgbWV0YWRhdGFcbiAgICBjb25zdCB2YWxpZGF0ZWQgPSBhd2FpdCBTZWN1cmVZYW1sUGFyc2VyLnBhcnNlKG1hdHRlci5zdHJpbmdpZnkoJycsIG1ldGFkYXRhKSk7XG5cbiAgICByZXR1cm4gdmFsaWRhdGVkLmRhdGEgYXMgUGVyc29uYU1ldGFkYXRhO1xuICB9XG5cbiAgLyoqXG4gICAqIEZpbmQgY29uZmxpY3RzIHdpdGggZXhpc3RpbmcgcGVyc29uYXNcbiAgICovXG4gIHByaXZhdGUgZmluZENvbmZsaWN0cyhuYW1lOiBzdHJpbmcsIGZpbGVuYW1lOiBzdHJpbmcsIGV4aXN0aW5nUGVyc29uYXM6IE1hcDxzdHJpbmcsIFBlcnNvbmE+KTogc3RyaW5nW10ge1xuICAgIGNvbnN0IGNvbmZsaWN0czogc3RyaW5nW10gPSBbXTtcblxuICAgIGZvciAoY29uc3QgW2tleSwgcGVyc29uYV0gb2YgZXhpc3RpbmdQZXJzb25hcykge1xuICAgICAgaWYgKHBlcnNvbmEubWV0YWRhdGEubmFtZSA9PT0gbmFtZSB8fCBwZXJzb25hLmZpbGVuYW1lID09PSBmaWxlbmFtZSkge1xuICAgICAgICBjb25mbGljdHMucHVzaChrZXkpO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBjb25mbGljdHM7XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2sgaWYgc3RyaW5nIGlzIGJhc2U2NFxuICAgKi9cbiAgcHJpdmF0ZSBpc0Jhc2U2NChzdHI6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIC8vIENoZWNrIGxlbmd0aCBpcyBtdWx0aXBsZSBvZiA0XG4gICAgaWYgKHN0ci5sZW5ndGggJSA0ICE9PSAwKSByZXR1cm4gZmFsc2U7XG4gICAgXG4gICAgLy8gU0VDVVJJVFkgRklYOiBFbnN1cmUgYmFzZTY0IHN0cmluZyBpcyBub3QgZW1wdHlcbiAgICAvLyBQcmV2aW91c2x5OiAvXltBLVphLXowLTkrL10qPXswLDJ9JC8gYWxsb3dlZCBlbXB0eSBzdHJpbmdzXG4gICAgLy8gTm93OiBSZXF1aXJlIGF0IGxlYXN0IG9uZSBjaGFyYWN0ZXIgYmVmb3JlIG9wdGlvbmFsIHBhZGRpbmdcbiAgICByZXR1cm4gL15bQS1aYS16MC05Ky9dKz17MCwyfSQvLnRlc3Qoc3RyKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBUeXBlIGd1YXJkIGZvciBFeHBvcnRlZFBlcnNvbmFcbiAgICovXG4gIHByaXZhdGUgaXNFeHBvcnRlZFBlcnNvbmEob2JqOiBhbnkpOiBvYmogaXMgRXhwb3J0ZWRQZXJzb25hIHtcbiAgICByZXR1cm4gb2JqICYmIFxuICAgICAgdHlwZW9mIG9iai5tZXRhZGF0YSA9PT0gJ29iamVjdCcgJiZcbiAgICAgIHR5cGVvZiBvYmouY29udGVudCA9PT0gJ3N0cmluZycgJiZcbiAgICAgIHR5cGVvZiBvYmouZmlsZW5hbWUgPT09ICdzdHJpbmcnO1xuICB9XG5cbiAgLyoqXG4gICAqIFR5cGUgZ3VhcmQgZm9yIEV4cG9ydEJ1bmRsZVxuICAgKi9cbiAgcHJpdmF0ZSBpc0V4cG9ydEJ1bmRsZShvYmo6IGFueSk6IG9iaiBpcyBFeHBvcnRCdW5kbGUge1xuICAgIHJldHVybiBvYmogJiZcbiAgICAgIHR5cGVvZiBvYmoudmVyc2lvbiA9PT0gJ3N0cmluZycgJiZcbiAgICAgIEFycmF5LmlzQXJyYXkob2JqLnBlcnNvbmFzKSAmJlxuICAgICAgdHlwZW9mIG9iai5wZXJzb25hQ291bnQgPT09ICdudW1iZXInO1xuICB9XG5cbiAgLyoqXG4gICAqIEZvcm1hdCBidW5kbGUgaW1wb3J0IHJlc3VsdHNcbiAgICovXG4gIHByaXZhdGUgZm9ybWF0QnVuZGxlSW1wb3J0UmVzdWx0KHJlc3VsdHM6IGFueSk6IHN0cmluZyB7XG4gICAgbGV0IG1lc3NhZ2UgPSBgQnVuZGxlIEltcG9ydCBTdW1tYXJ5OlxcbmA7XG4gICAgbWVzc2FnZSArPSBg4pyFIFN1Y2Nlc3NmdWxseSBpbXBvcnRlZDogJHtyZXN1bHRzLmltcG9ydGVkLmxlbmd0aH0gcGVyc29uYXNcXG5gO1xuICAgIFxuICAgIGlmIChyZXN1bHRzLmltcG9ydGVkLmxlbmd0aCA+IDApIHtcbiAgICAgIG1lc3NhZ2UgKz0gYEltcG9ydGVkOlxcbiR7cmVzdWx0cy5pbXBvcnRlZC5tYXAoKG46IHN0cmluZykgPT4gYCAgLSAke259YCkuam9pbignXFxuJyl9XFxuYDtcbiAgICB9XG5cbiAgICBpZiAocmVzdWx0cy5mYWlsZWQubGVuZ3RoID4gMCkge1xuICAgICAgbWVzc2FnZSArPSBgXFxu4p2MIEZhaWxlZDogJHtyZXN1bHRzLmZhaWxlZC5sZW5ndGh9IHBlcnNvbmFzXFxuYDtcbiAgICAgIG1lc3NhZ2UgKz0gYEVycm9yczpcXG4ke3Jlc3VsdHMuZmFpbGVkLm1hcCgoZTogc3RyaW5nKSA9PiBgICAtICR7ZX1gKS5qb2luKCdcXG4nKX1gO1xuICAgIH1cblxuICAgIHJldHVybiBtZXNzYWdlO1xuICB9XG59Il19
|
|
@@ -1,5 +1,15 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Persona sharing functionality via URLs
|
|
3
|
+
*
|
|
4
|
+
* SECURITY FIX IMPLEMENTED (Defense-in-Depth Validation):
|
|
5
|
+
* 1. CRITICAL: Added validate-before-return pattern in all import methods
|
|
6
|
+
* 2. HIGH: Content security validation using ContentValidator before data return
|
|
7
|
+
* 3. MEDIUM: Size validation to prevent memory exhaustion attacks
|
|
8
|
+
* 4. MEDIUM: Structure validation to prevent malformed data processing
|
|
9
|
+
* 5. DEFENSE-IN-DEPTH: Multiple validation layers before PersonaImporter processing
|
|
10
|
+
*
|
|
11
|
+
* This provides defense-in-depth security by validating content at the earliest
|
|
12
|
+
* possible point before any data is returned to calling code or file operations.
|
|
3
13
|
*/
|
|
4
14
|
import { Persona } from '../../types/persona.js';
|
|
5
15
|
import { GitHubClient } from '../../collection/GitHubClient.js';
|
|
@@ -22,6 +32,7 @@ export declare class PersonaSharer {
|
|
|
22
32
|
sharePersona(persona: Persona, expiryDays?: number): Promise<ShareResult>;
|
|
23
33
|
/**
|
|
24
34
|
* Import a persona from a share URL
|
|
35
|
+
* SECURITY FIX: Validate ALL content before returning any data
|
|
25
36
|
*/
|
|
26
37
|
importFromUrl(url: string): Promise<{
|
|
27
38
|
success: boolean;
|
|
@@ -56,5 +67,15 @@ export declare class PersonaSharer {
|
|
|
56
67
|
* Format share success message
|
|
57
68
|
*/
|
|
58
69
|
private formatShareSuccess;
|
|
70
|
+
/**
|
|
71
|
+
* SECURITY FIX: Validate persona data before any processing
|
|
72
|
+
* This provides defense-in-depth validation before content reaches file operations
|
|
73
|
+
*/
|
|
74
|
+
private validatePersonaData;
|
|
75
|
+
/**
|
|
76
|
+
* ENHANCED SECURITY FIX: Comprehensive Content-Type validation
|
|
77
|
+
* Strengthens MIME type validation with comprehensive security checks
|
|
78
|
+
*/
|
|
79
|
+
private validateContentType;
|
|
59
80
|
}
|
|
60
81
|
//# sourceMappingURL=PersonaSharer.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PersonaSharer.d.ts","sourceRoot":"","sources":["../../../src/persona/export-import/PersonaSharer.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"PersonaSharer.d.ts","sourceRoot":"","sources":["../../../src/persona/export-import/PersonaSharer.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAWhE,MAAM,WAAW,WAAW;IAC1B,OAAO,EAAE,OAAO,CAAC;IACjB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,qBAAa,aAAa;IAKtB,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,WAAW;IALrB,OAAO,CAAC,QAAQ,CAAkB;IAClC,OAAO,CAAC,iBAAiB,CAAc;gBAG7B,YAAY,EAAE,YAAY,EAC1B,WAAW,EAAE,MAAM,GAAG,IAAI;IAcpC;;OAEG;IACG,YAAY,CAAC,OAAO,EAAE,OAAO,EAAE,UAAU,GAAE,MAAU,GAAG,OAAO,CAAC,WAAW,CAAC;IAwElF;;;OAGG;IACG,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,IAAI,CAAC,EAAE,GAAG,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IAwF5F;;OAEG;YACW,UAAU;IA+ExB;;OAEG;IACH,OAAO,CAAC,eAAe;IAYvB;;OAEG;YACW,cAAc;IAwF5B;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAgJxB;;OAEG;YACW,mBAAmB;IAwCjC;;OAEG;IACH,OAAO,CAAC,aAAa;IAKrB;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAmB1B;;;OAGG;YACW,mBAAmB;IAkDjC;;;OAGG;IACH,OAAO,CAAC,mBAAmB;CAsG5B"}
|