@akson/cortex-analytics 0.9.0 → 0.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli.js +4 -4
- package/dist/cli.js.map +1 -1
- package/dist/index.js +4 -4
- package/dist/index.js.map +1 -1
- package/package.json +4 -4
package/dist/cli.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../package.json","../src/cli.ts","../src/analytics-manager.ts","../src/help.ts"],"sourcesContent":["{\n \"name\": \"@akson/cortex-analytics\",\n \"version\": \"0.9.0\",\n \"description\": \"Unified CLI for Cortex analytics operations across all platforms\",\n \"type\": \"module\",\n \"main\": \"dist/index.js\",\n \"bin\": {\n \"akson\": \"./dist/cli.js\",\n \"cortex-analytics\": \"./dist/cli.js\"\n },\n \"scripts\": {\n \"build\": \"tsup\",\n \"dev\": \"tsup --watch\",\n \"clean\": \"rm -rf dist\",\n \"lint\": \"eslint src --ext .ts\",\n \"test\": \"vitest\",\n \"type-check\": \"tsc --noEmit\"\n },\n \"dependencies\": {\n \"@akson/cortex-gsc\": \"workspace:*\",\n \"@akson/cortex-gtm\": \"workspace:*\",\n \"@akson/cortex-posthog\": \"workspace:*\",\n \"chalk\": \"^5.5.0\",\n \"commander\": \"^14.0.0\",\n \"inquirer\": \"^13.1.0\",\n \"js-yaml\": \"^4.1.0\",\n \"ora\": \"^8.1.1\",\n \"table\": \"^6.9.0\"\n },\n \"devDependencies\": {\n \"@types/inquirer\": \"^9.0.7\",\n \"@types/js-yaml\": \"^4.0.9\",\n \"@types/node\": \"^22\",\n \"eslint\": \"^8\",\n \"tsup\": \"^8.5.0\",\n \"typescript\": \"^5.9.2\",\n \"vitest\": \"^3.2.4\"\n },\n \"engines\": {\n \"node\": \">=18.0.0\"\n },\n \"keywords\": [\n \"cli\",\n \"analytics\",\n \"gtm\",\n \"google-ads\",\n \"posthog\",\n \"gsc\",\n \"cortex\"\n ],\n \"author\": \"Akson <contact@akson.ch>\",\n \"license\": \"MIT\",\n \"homepage\": \"https://github.com/antoineschaller/cortex-packages/tree/main/packages/@akson/cortex-analytics\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/antoineschaller/cortex-packages.git\",\n \"directory\": \"packages/@akson/cortex-analytics\"\n },\n \"types\": \"dist/index.d.ts\",\n \"exports\": {\n \".\": {\n \"types\": \"./dist/index.d.ts\",\n \"import\": \"./dist/index.js\"\n }\n },\n \"files\": [\n \"dist\",\n \"README.md\",\n \"LICENSE\"\n ],\n \"gitHead\": \"b3a6a0832bb2fd230473076bde1bfc7810e9ac31\"\n}\n","#!/usr/bin/env node\n\n/**\n * Akson Analytics CLI\n *\n * Unified command-line interface for MyArmy analytics operations\n */\n\nimport chalk from \"chalk\";\nimport { Command } from \"commander\";\nimport { AnalyticsManager } from \"./analytics-manager.js\";\nimport {\n showComprehensiveHelp,\n showQuickStart,\n showSwissMarketHelp,\n showPlatformStatus,\n showExamples,\n showTroubleshooting,\n showGettingStarted,\n getVersion,\n getCommands,\n} from \"./help.js\";\n\nconst program = new Command();\n\nprogram\n .name(\"akson\")\n .description(\"Unified CLI for MyArmy analytics operations\")\n .version(getVersion());\n\n// ============================================================================\n// HELP COMMANDS - Enhanced documentation and guidance\n// ============================================================================\n\nprogram\n .command(\"comprehensive-help\")\n .alias(\"help-all\")\n .description(\"Show comprehensive help with all commands and examples\")\n .action(() => {\n showComprehensiveHelp();\n });\n\nprogram\n .command(\"quick-start\")\n .alias(\"start\")\n .description(\"Show quick start guide for new users\")\n .action(() => {\n showQuickStart();\n });\n\nprogram\n .command(\"swiss-market\")\n .alias(\"swiss\")\n .description(\"Show Swiss military market specific help and keywords\")\n .action(() => {\n showSwissMarketHelp();\n });\n\nprogram\n .command(\"platform-status\")\n .alias(\"status\")\n .description(\"Show platform configuration status and setup instructions\")\n .action(() => {\n showPlatformStatus();\n });\n\nprogram\n .command(\"examples\")\n .description(\"Show common use cases and examples\")\n .action(() => {\n showExamples();\n });\n\nprogram\n .command(\"troubleshooting\")\n .alias(\"troubleshoot\")\n .description(\"Show troubleshooting guide for common issues\")\n .action(() => {\n showTroubleshooting();\n });\n\nprogram\n .command(\"getting-started\")\n .alias(\"start-guide\")\n .description(\"Show complete getting started guide\")\n .action(() => {\n showGettingStarted();\n });\n\nprogram\n .command(\"version-info\")\n .description(\"Show version and dependency information\")\n .action(() => {\n const version = getVersion();\n const commands = getCommands();\n\n console.log(\n chalk.cyan.bold(`\n@akson/cortex-analytics v${version}\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n\n📦 PACKAGE DEPENDENCIES:\n • @akson/cortex-gtm: GTM operations and configuration\n • @akson/cortex-gsc: Google Search Console integration \n • @akson/cortex-google-ads: Google Ads reporting and analysis\n • @akson/cortex-posthog: PostHog analytics and experiments\n • @akson/cortex-utilities: Shared utilities and types\n\n🎯 AVAILABLE MODULES:\n • ${commands.length} command modules\n • ${commands.reduce(\n (acc, mod) => acc + mod.commands.length,\n 0\n )} total commands\n • Swiss military market specialization\n • Cross-platform analytics integration\n\n📋 COMMAND CATEGORIES:\n${commands\n .map((mod) => ` • ${mod.module}: ${mod.commands.length} commands`)\n .join(\"\\n\")}\n\nFor more information: akson comprehensive-help\n`)\n );\n });\n\n// ============================================================================\n// CORE ANALYTICS COMMANDS\n// ============================================================================\n\n// Health check command\nprogram\n .command(\"health\")\n .description(\"Check health of all analytics platforms\")\n .option(\"-v, --verbose\", \"Show detailed health information\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.healthCheck(options.verbose);\n });\n\n// Event standardization commands\nconst eventCmd = program\n .command(\"events\")\n .description(\"Event standardization and mapping operations\");\n\neventCmd\n .command(\"standardize\")\n .description(\"Standardize events across platforms\")\n .requiredOption(\"-e, --events <events...>\", \"Events to standardize\")\n .option(\n \"-s, --source <platform>\",\n \"Source platform (gtm|google-ads|posthog|gsc|meta)\"\n )\n .option(\"-t, --target <platform>\", \"Target platform (optional)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.standardizeEvents(options);\n });\n\neventCmd\n .command(\"score\")\n .description(\"Calculate lead scores for events\")\n .requiredOption(\"-f, --file <path>\", \"JSON file with events to score\")\n .option(\"-m, --method <method>\", \"Scoring method (default|custom)\", \"default\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.scoreLeads(options);\n });\n\n// Platform-specific commands\nconst gtmCmd = program\n .command(\"gtm\")\n .description(\"Google Tag Manager operations\");\n\ngtmCmd\n .command(\"sync\")\n .description(\"Sync GTM configuration\")\n .action(async () => {\n const manager = new AnalyticsManager();\n await manager.gtmSync();\n });\n\ngtmCmd\n .command(\"fix-variable-references\")\n .description(\"Fix incorrect variable references in GTM tags\")\n .option(\"-d, --dry-run\", \"Preview changes without applying them\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmFixVariableReferences(options);\n });\n\ngtmCmd\n .command(\"update-google-ads-id\")\n .description(\"Update Google Ads ID from 659644670 to 8847935674 in GTM\")\n .action(async () => {\n const manager = new AnalyticsManager();\n await manager.gtmUpdateGoogleAdsId();\n });\n\ngtmCmd\n .command(\"update-event-names\")\n .description(\n \"Update event names from enhanced_funnel_stage to lead_funnel_stage\"\n )\n .action(async () => {\n const manager = new AnalyticsManager();\n await manager.gtmUpdateEventNames();\n });\n\ngtmCmd\n .command(\"remove-triggers\")\n .description(\"Remove triggers from GTM\")\n .requiredOption(\"-i, --ids <ids...>\", \"Trigger IDs to remove\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.removeTriggers(options.ids);\n });\n\ngtmCmd\n .command(\"create-tag\")\n .description(\"Create a new GTM tag\")\n .requiredOption(\"-n, --name <name>\", \"Tag name\")\n .requiredOption(\"-t, --type <type>\", \"Tag type (e.g., gaawe, html, gclidw)\")\n .option(\"-c, --config <json>\", \"Additional configuration as JSON string\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmCreateTag(options);\n });\n\ngtmCmd\n .command(\"delete-tag\")\n .description(\"Delete a GTM tag\")\n .requiredOption(\"-i, --id <id>\", \"Tag ID to delete\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmDeleteTag(options.id);\n });\n\ngtmCmd\n .command(\"create-trigger\")\n .description(\"Create a new GTM trigger\")\n .requiredOption(\"-n, --name <name>\", \"Trigger name\")\n .requiredOption(\n \"-t, --type <type>\",\n \"Trigger type (e.g., customEvent, pageview, click)\"\n )\n .option(\"-c, --config <json>\", \"Additional configuration as JSON string\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmCreateTrigger(options);\n });\n\ngtmCmd\n .command(\"delete-trigger\")\n .description(\"Delete a GTM trigger\")\n .requiredOption(\"-i, --id <id>\", \"Trigger ID to delete\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmDeleteTrigger(options.id);\n });\n\ngtmCmd\n .command(\"query\")\n .description(\"Query GTM configuration\")\n .option(\n \"-t, --type <type>\",\n \"Query type: variables|tags|triggers|workspaces|versions|all\",\n \"all\"\n )\n .option(\"-f, --filter <filter>\", \"Filter results by name or type\")\n .option(\"-w, --workspace <id>\", \"Workspace ID (optional)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmQuery(options);\n });\n\n// Version management commands\ngtmCmd\n .command(\"versions\")\n .description(\"List all published versions\")\n .option(\"-l, --limit <number>\", \"Limit number of versions to show\", \"10\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmListVersions(options);\n });\n\ngtmCmd\n .command(\"version\")\n .description(\"Get specific version details\")\n .requiredOption(\"-v, --version <id>\", \"Version ID to retrieve\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmGetVersion(options);\n });\n\ngtmCmd\n .command(\"version-live\")\n .description(\"Get currently published live version\")\n .action(async () => {\n const manager = new AnalyticsManager();\n await manager.gtmGetLiveVersion();\n });\n\ngtmCmd\n .command(\"version-compare\")\n .description(\"Compare versions or version with workspace\")\n .requiredOption(\"--version1 <id>\", \"First version ID\")\n .option(\n \"--version2 <id>\",\n \"Second version ID (if not provided, compares with workspace)\"\n )\n .option(\"-o, --output <path>\", \"Save comparison to file\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmCompareVersions(options);\n });\n\ngtmCmd\n .command(\"version-create\")\n .description(\"Create version from current workspace\")\n .requiredOption(\"-n, --name <name>\", \"Version name\")\n .option(\"-d, --description <notes>\", \"Version description/notes\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmCreateVersion(options);\n });\n\n// =============================================================================\n// WORKSPACE STATE MANAGEMENT COMMANDS\n// =============================================================================\n\ngtmCmd\n .command(\"workspace-state\")\n .description(\"Get current workspace state (snapshot)\")\n .option(\n \"-w, --workspace <id>\",\n \"Workspace ID (defaults to current workspace)\"\n )\n .option(\"-o, --output <path>\", \"Save workspace state to file\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmGetWorkspaceState(options);\n });\n\ngtmCmd\n .command(\"workspace-snapshot\")\n .description(\"Save workspace state to snapshot file\")\n .requiredOption(\"-f, --file <path>\", \"Snapshot file path\")\n .option(\n \"-w, --workspace <id>\",\n \"Workspace ID (defaults to current workspace)\"\n )\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmSaveWorkspaceSnapshot(options);\n });\n\ngtmCmd\n .command(\"workspace-compare\")\n .description(\"Compare current workspace with snapshot or live version\")\n .option(\"-f, --file <path>\", \"Compare with snapshot file\")\n .option(\"--with-live\", \"Compare with live published version\")\n .option(\n \"-w, --workspace <id>\",\n \"Workspace ID (defaults to current workspace)\"\n )\n .option(\"-o, --output <path>\", \"Save comparison to file\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmCompareWorkspace(options);\n });\n\n// Note: GTM publishing via API has limitations and is not recommended for production use\n// Use the GTM UI for publishing workspaces to production\n\n// Terraform-style commands for GTM\ngtmCmd\n .command(\"init\")\n .description(\"Initialize GTM Terraform workspace\")\n .option(\"-c, --config <path>\", \"Configuration file path\", \"gtm.config.yaml\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformInit(options);\n });\n\ngtmCmd\n .command(\"plan\")\n .description(\"Show changes that would be applied to GTM\")\n .option(\"-c, --config <path>\", \"Configuration file path\", \"gtm.config.yaml\")\n .option(\"-o, --out <path>\", \"Save plan to file\")\n .option(\n \"-w, --workspace <id>\",\n \"Workspace ID to use (defaults to Default Workspace)\"\n )\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformPlan(options);\n });\n\ngtmCmd\n .command(\"apply\")\n .description(\"Apply GTM configuration changes\")\n .option(\"-c, --config <path>\", \"Configuration file path\", \"gtm.config.yaml\")\n .option(\"-p, --plan <path>\", \"Apply from saved plan file\")\n .option(\n \"-w, --workspace <id>\",\n \"Workspace ID to use (defaults to Default Workspace)\"\n )\n .option(\"-y, --yes\", \"Auto-approve changes\")\n .option(\"-v, --verbose\", \"Enable verbose logging for detailed debugging\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformApply(options);\n });\n\ngtmCmd\n .command(\"incremental-sync\")\n .description(\n \"Enhanced incremental sync with validation and proper error handling\"\n )\n .option(\"-c, --config <path>\", \"Configuration file path\", \"gtm.config.yaml\")\n .option(\"--dry-run\", \"Show what would be changed without applying\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmIncrementalSync(options);\n });\n\ngtmCmd\n .command(\"destroy\")\n .description(\"Destroy GTM resources\")\n .option(\"-c, --config <path>\", \"Configuration file path\", \"gtm.config.yaml\")\n .option(\"-y, --yes\", \"Auto-approve destruction\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformDestroy(options);\n });\n\ngtmCmd\n .command(\"import\")\n .description(\"Import existing GTM resources into state\")\n .requiredOption(\"-t, --type <type>\", \"Resource type (tag|trigger|variable)\")\n .requiredOption(\"-n, --name <name>\", \"Resource name\")\n .requiredOption(\"-i, --id <id>\", \"GTM resource ID\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformImport(options);\n });\n\ngtmCmd\n .command(\"show\")\n .description(\"Show current GTM state\")\n .option(\"-f, --format <format>\", \"Output format (json|yaml|table)\", \"table\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformShow(options);\n });\n\ngtmCmd\n .command(\"create-workspace\")\n .description(\"Create a new GTM workspace\")\n .requiredOption(\"-n, --name <name>\", \"Workspace name\")\n .option(\"-d, --description <description>\", \"Workspace description\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmCreateWorkspace(options);\n });\n\ngtmCmd\n .command(\"validate\")\n .description(\"Validate GTM configuration file\")\n .option(\"-c, --config <path>\", \"Configuration file path\", \"gtm.config.yaml\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformValidate(options);\n });\n\ngtmCmd\n .command(\"state\")\n .description(\"Advanced state management\")\n .addCommand(\n new Command(\"list\")\n .description(\"List resources in state\")\n .option(\"-t, --type <type>\", \"Filter by resource type\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformStateList(options);\n })\n )\n .addCommand(\n new Command(\"show\")\n .description(\"Show specific resource\")\n .requiredOption(\n \"-a, --address <address>\",\n \"Resource address (e.g., gtm_tag.example)\"\n )\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformStateShow(options);\n })\n )\n .addCommand(\n new Command(\"remove\")\n .description(\"Remove resource from state\")\n .requiredOption(\"-a, --address <address>\", \"Resource address to remove\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformStateRemove(options);\n })\n );\n\nconst posthogCmd = program\n .command(\"posthog\")\n .description(\"PostHog analytics operations\");\n\nposthogCmd\n .command(\"query\")\n .description(\"Execute HogQL query\")\n .requiredOption(\"-q, --query <query>\", \"HogQL query to execute\")\n .option(\"-l, --limit <number>\", \"Result limit\", \"100\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogQuery(options);\n });\n\nposthogCmd\n .command(\"funnel\")\n .description(\"Analyze conversion funnel\")\n .requiredOption(\"-e, --events <events...>\", \"Funnel events in order\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-E, --end <date>\", \"End date (YYYY-MM-DD)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogFunnel(options);\n });\n\n// PostHog Feature Flags & Experiments\nposthogCmd\n .command(\"flags\")\n .description(\"List all feature flags\")\n .option(\"-p, --project <id>\", \"Project ID (optional if configured)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogListFlags(options);\n });\n\nposthogCmd\n .command(\"flag\")\n .description(\"Get specific feature flag details\")\n .requiredOption(\"-i, --id <id>\", \"Feature flag ID\")\n .option(\"-p, --project <id>\", \"Project ID (optional if configured)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogGetFlag(options);\n });\n\nposthogCmd\n .command(\"create-flag\")\n .description(\"Create new feature flag\")\n .requiredOption(\"-k, --key <key>\", \"Feature flag key\")\n .requiredOption(\"-n, --name <name>\", \"Feature flag name\")\n .option(\"-d, --description <desc>\", \"Feature flag description\")\n .option(\"--active\", \"Set flag as active\", true)\n .option(\"-r, --rollout <percent>\", \"Rollout percentage (0-100)\", \"100\")\n .option(\"-p, --project <id>\", \"Project ID (optional if configured)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogCreateFlag(options);\n });\n\nposthogCmd\n .command(\"create-experiment\")\n .description(\"Create multivariate experiment\")\n .requiredOption(\"-k, --key <key>\", \"Experiment key\")\n .requiredOption(\"-n, --name <name>\", \"Experiment name\")\n .requiredOption(\"-v, --variants <variants>\", \"Comma-separated variant keys\")\n .option(\"-d, --description <desc>\", \"Experiment description\")\n .option(\"--equal-split\", \"Split variants equally\", true)\n .option(\"-r, --rollout <percent>\", \"Overall rollout percentage\", \"100\")\n .option(\"--continuity\", \"Ensure experience continuity\", true)\n .option(\"-p, --project <id>\", \"Project ID (optional if configured)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogCreateExperiment(options);\n });\n\nposthogCmd\n .command(\"update-flag\")\n .description(\"Update existing feature flag\")\n .requiredOption(\"-i, --id <id>\", \"Feature flag ID\")\n .option(\"-n, --name <name>\", \"New name\")\n .option(\"-d, --description <desc>\", \"New description\")\n .option(\"--active <boolean>\", \"Set active status (true/false)\")\n .option(\"-r, --rollout <percent>\", \"New rollout percentage\")\n .option(\"-p, --project <id>\", \"Project ID (optional if configured)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogUpdateFlag(options);\n });\n\nposthogCmd\n .command(\"delete-flag\")\n .description(\"Delete feature flag\")\n .requiredOption(\"-i, --id <id>\", \"Feature flag ID\")\n .option(\"-p, --project <id>\", \"Project ID (optional if configured)\")\n .option(\"-y, --yes\", \"Skip confirmation\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogDeleteFlag(options);\n });\n\nposthogCmd\n .command(\"evaluate\")\n .description(\"Evaluate feature flags for user\")\n .requiredOption(\"-u, --user <id>\", \"Distinct user ID\")\n .option(\"-g, --groups <groups>\", \"JSON string of group properties\")\n .option(\"--person-props <props>\", \"JSON string of person properties\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogEvaluateFlags(options);\n });\n\nconst gadsCmd = program.command(\"gads\").description(\"Google Ads operations\");\n\ngadsCmd\n .command(\"conversions\")\n .description(\"Get conversion data\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.googleAdsConversions(options);\n });\n\ngadsCmd\n .command(\"report\")\n .description(\"Generate comprehensive Google Ads report\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\n \"-c, --customer <id>\",\n \"Customer ID (uses config default if not provided)\"\n )\n .option(\"-o, --output <format>\", \"Output format (json|table)\", \"table\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.googleAdsComprehensiveReport(options);\n });\n\ngadsCmd\n .command(\"keywords\")\n .description(\"Get keyword performance report\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\n \"-c, --customer <id>\",\n \"Customer ID (uses config default if not provided)\"\n )\n .option(\"-l, --limit <number>\", \"Number of keywords to return\", \"1000\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.googleAdsKeywords(options);\n });\n\ngadsCmd\n .command(\"search-terms\")\n .description(\"Get search terms report\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\n \"-c, --customer <id>\",\n \"Customer ID (uses config default if not provided)\"\n )\n .option(\"-l, --limit <number>\", \"Number of search terms to return\", \"1000\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.googleAdsSearchTerms(options);\n });\n\ngadsCmd\n .command(\"historical\")\n .description(\"Perform historical analysis with anomaly and trend detection\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\n \"-c, --customer <id>\",\n \"Customer ID (uses config default if not provided)\"\n )\n .option(\n \"-g, --granularity <level>\",\n \"Data granularity (daily|weekly|monthly)\",\n \"daily\"\n )\n .option(\"--detect-anomalies\", \"Enable anomaly detection\")\n .option(\"--analyze-trends\", \"Enable trend analysis\")\n .option(\"--analyze-seasonality\", \"Enable seasonality analysis\")\n .option(\n \"-o, --output <format>\",\n \"Output format (json|csv|markdown|table)\",\n \"table\"\n )\n .option(\"--output-file <path>\", \"Save output to file\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.googleAdsHistorical(options);\n });\n\ngadsCmd\n .command(\"swiss-market\")\n .description(\"Specialized Swiss military market analysis\")\n .option(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .option(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\n \"-c, --customer <id>\",\n \"Customer ID (uses config default if not provided)\"\n )\n .option(\"--include-competitors\", \"Include competitor analysis\")\n .option(\"--analyze-seasonality\", \"Analyze seasonal recruitment patterns\")\n .option(\"--opportunity-analysis\", \"Identify market opportunities\")\n .option(\n \"-o, --output <format>\",\n \"Output format (json|csv|markdown|table)\",\n \"table\"\n )\n .option(\"--output-file <path>\", \"Save output to file\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.googleAdsSwissMarket(options);\n });\n\n// Meta/Facebook Ads operations\nconst metaCmd = program\n .command(\"meta\")\n .description(\"Meta/Facebook Ads operations\");\n\nmetaCmd\n .command(\"campaigns\")\n .description(\"Get campaign performance\")\n .option(\"-l, --limit <number>\", \"Number of campaigns to return\", \"100\")\n .option(\"-o, --output <format>\", \"Output format (json|table)\", \"table\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.metaCampaigns(options);\n });\n\nmetaCmd\n .command(\"insights\")\n .description(\"Get account insights\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\n \"--level <level>\",\n \"Insight level (account|campaign|adset|ad)\",\n \"account\"\n )\n .option(\"-o, --output <format>\", \"Output format (json|table)\", \"table\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.metaInsights(options);\n });\n\nmetaCmd\n .command(\"conversions\")\n .description(\"Get conversion report\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\n \"--level <level>\",\n \"Insight level (account|campaign|adset|ad)\",\n \"account\"\n )\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.metaConversions(options);\n });\n\n// SEO analysis operations\nconst seoCmd = program\n .command(\"seo\")\n .description(\"SEO analysis and optimization\");\n\nseoCmd\n .command(\"audit\")\n .description(\"Run comprehensive SEO audit\")\n .requiredOption(\"-u, --url <url>\", \"URL to audit\")\n .option(\"-d, --device <device>\", \"Device type (mobile|desktop)\", \"mobile\")\n .option(\"-o, --output <format>\", \"Output format (json|table)\", \"table\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.seoAudit(options);\n });\n\nseoCmd\n .command(\"core-web-vitals\")\n .description(\"Analyze Core Web Vitals\")\n .requiredOption(\"-u, --url <url>\", \"URL to analyze\")\n .option(\"-d, --device <device>\", \"Device type (mobile|desktop)\", \"mobile\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.seoCoreWebVitals(options);\n });\n\nseoCmd\n .command(\"schema\")\n .description(\"Validate structured data schema\")\n .requiredOption(\"-u, --url <url>\", \"URL to validate\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.seoSchemaValidation(options);\n });\n\nseoCmd\n .command(\"geo\")\n .description(\"Analyze GEO (Generative Engine Optimization)\")\n .requiredOption(\"-u, --url <url>\", \"URL to analyze\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.seoGEOAnalysis(options);\n });\n\nconst gscCmd = program\n .command(\"gsc\")\n .description(\"Google Search Console operations\");\n\ngscCmd\n .command(\"rankings\")\n .description(\"Check keyword rankings\")\n .requiredOption(\"-k, --keywords <keywords...>\", \"Keywords to check\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gscRankings(options);\n });\n\ngscCmd\n .command(\"report\")\n .description(\"Generate comprehensive GSC SEO report\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-u, --url <url>\", \"Site URL (uses config default if not provided)\")\n .option(\"-o, --output <format>\", \"Output format (json|table)\", \"table\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gscComprehensiveReport(options);\n });\n\ngscCmd\n .command(\"enhanced-report\")\n .description(\n \"Generate enhanced GSC report with schema analysis and URL inspections\"\n )\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-o, --output <file>\", \"Output file (JSON)\")\n .option(\"--no-schema\", \"Skip schema analysis\")\n .option(\"--no-inspections\", \"Skip URL inspections\")\n .option(\n \"--max-keywords <number>\",\n \"Maximum keywords to analyze (default: 100)\"\n )\n .option(\"--max-pages <number>\", \"Maximum pages to analyze (default: 50)\")\n .option(\"--max-inspections <number>\", \"Maximum URLs to inspect (default: 10)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gscEnhancedReport(options);\n });\n\ngscCmd\n .command(\"keywords\")\n .description(\"Get top performing keywords\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-l, --limit <number>\", \"Number of keywords to return\", \"100\")\n .option(\"-u, --url <url>\", \"Site URL (uses config default if not provided)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gscTopKeywords(options);\n });\n\ngscCmd\n .command(\"pages\")\n .description(\"Get top performing pages\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-l, --limit <number>\", \"Number of pages to return\", \"100\")\n .option(\"-u, --url <url>\", \"Site URL (uses config default if not provided)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gscTopPages(options);\n });\n\n// Cross-platform analysis\nprogram\n .command(\"analyze\")\n .description(\"Cross-platform analytics analysis\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-p, --platforms <platforms...>\", \"Platforms to analyze\", [\n \"posthog\",\n \"gsc\",\n \"google-ads\",\n ])\n .option(\"-v, --events <events...>\", \"Specific events to analyze\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.crossPlatformAnalysis(options);\n });\n\n// Interactive setup\nprogram\n .command(\"setup\")\n .description(\"Interactive setup for analytics configuration\")\n .action(async () => {\n const manager = new AnalyticsManager();\n await manager.interactiveSetup();\n });\n\n// Dashboard command\nprogram\n .command(\"dashboard\")\n .description(\"Generate unified analytics dashboard\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-o, --output <format>\", \"Output format (json|table)\", \"table\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.generateDashboard(options);\n });\n\n// Comprehensive SEO/GEO report for MyArmy\nprogram\n .command(\"myarmy-report\")\n .description(\"Generate comprehensive MyArmy.ch SEO/GEO optimization report\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-u, --url <url>\", \"URL to analyze\", \"https://myarmy.ch\")\n .option(\"-d, --device <device>\", \"Device type (mobile|desktop)\", \"mobile\")\n .option(\"-o, --output <format>\", \"Output format (json|table|file)\", \"table\")\n .option(\"-f, --file <path>\", \"Output file path (when using file output)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.generateMyArmyReport(options);\n });\n\n// Keyword research and optimization\nprogram\n .command(\"keyword-research\")\n .description(\"Research keywords across all platforms\")\n .requiredOption(\"-k, --keywords <keywords...>\", \"Keywords to research\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-c, --country <country>\", \"Country code (e.g., CH, US)\", \"CH\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.keywordResearch(options);\n });\n\n// Traffic analysis\nprogram\n .command(\"traffic-analysis\")\n .description(\"Analyze traffic patterns and optimization opportunities\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-u, --url <url>\", \"Site URL to analyze\", \"https://myarmy.ch\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.trafficAnalysis(options);\n });\n\n// Error handling\nprogram.configureHelp({\n sortSubcommands: true,\n subcommandTerm: (cmd) => `${cmd.name()} ${cmd.usage()}`,\n});\n\nprogram.exitOverride();\n\ntry {\n await program.parseAsync(process.argv);\n} catch (error) {\n if (error.code === \"commander.help\") {\n process.exit(0);\n }\n console.error(chalk.red(\"Error:\"), error.message);\n process.exit(1);\n}\n\nexport { program };\n","/**\n * Analytics Manager\n *\n * Unified manager class for all analytics operations\n */\n\nimport crypto from \"node:crypto\";\nimport fs from \"node:fs/promises\";\nimport {\n GoogleAdsClient,\n HistoricalAnalyzer,\n SwissMarketAnalyzer,\n loadGoogleAdsConfig,\n} from \"@akson/cortex-google-ads\";\nimport { GSCClient, loadGSCConfig } from \"@akson/cortex-gsc\";\nimport {\n ConfigParser,\n GTMClient,\n GTMApiTransformer,\n type GTMTag,\n type GTMTrigger,\n type GTMVariable,\n type GTMWorkspace,\n loadGTMConfig,\n Planner,\n StateManager,\n} from \"@akson/cortex-gtm\";\nimport { loadPostHogConfig, PostHogClient } from \"@akson/cortex-posthog\";\nimport {\n ECOMMERCE_EVENTS,\n LEAD_GENERATION_EVENTS,\n LEAD_SCORES,\n PLATFORM_MAPPINGS,\n} from \"@akson/cortex-utilities\";\nimport chalk from \"chalk\";\nimport inquirer from \"inquirer\";\nimport yaml from \"js-yaml\";\nimport ora from \"ora\";\n\n// Type definitions for lead scoring\ninterface LeadEvent {\n event_name: string;\n calculated_lead_score?: number;\n qualification_level?: string;\n [key: string]: unknown;\n}\n\ninterface ScoredLead extends LeadEvent {\n calculated_lead_score: number;\n qualification_level: string;\n}\n\nimport { table } from \"table\";\n\ninterface HealthStatus {\n platform: string;\n status: \"healthy\" | \"error\" | \"unavailable\";\n message?: string;\n lastCheck?: string;\n}\n\nexport class AnalyticsManager {\n private clients: {\n gtm?: GTMClient;\n googleAds?: GoogleAdsClient;\n postHog?: PostHogClient;\n gsc?: GSCClient;\n } = {};\n\n private gtmTransformer = new GTMApiTransformer();\n\n async healthCheck(verbose = false): Promise<void> {\n const spinner = ora(\"Checking platform health...\").start();\n const health: HealthStatus[] = [];\n\n // GTM Health Check\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (authResult.success) {\n const workspacesResult = await this.clients.gtm.listWorkspaces();\n health.push({\n platform: \"GTM\",\n status: workspacesResult.success ? \"healthy\" : \"error\",\n message: workspacesResult.success\n ? \"Connected\"\n : workspacesResult.error,\n lastCheck: new Date().toISOString(),\n });\n } else {\n health.push({\n platform: \"GTM\",\n status: \"error\",\n message: authResult.error,\n });\n }\n } catch (error) {\n health.push({\n platform: \"GTM\",\n status: \"error\",\n message: error instanceof Error ? error.message : String(error),\n });\n }\n\n // PostHog Health Check\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const authResult = await this.clients.postHog.authenticate();\n if (authResult.success) {\n const queryResult = await this.clients.postHog.query({\n query: \"SELECT 1\",\n });\n health.push({\n platform: \"PostHog\",\n status: queryResult.success ? \"healthy\" : \"error\",\n message: queryResult.success ? \"Connected\" : queryResult.error,\n lastCheck: new Date().toISOString(),\n });\n } else {\n health.push({\n platform: \"PostHog\",\n status: \"error\",\n message: authResult.error,\n });\n }\n } catch (error) {\n health.push({\n platform: \"PostHog\",\n status: \"error\",\n message: error instanceof Error ? error.message : String(error),\n });\n }\n\n // Google Ads Health Check\n try {\n if (!this.clients.googleAds) {\n const config = loadGoogleAdsConfig();\n this.clients.googleAds = new GoogleAdsClient({ config });\n }\n\n const authResult = await this.clients.googleAds.authenticate();\n if (authResult.success) {\n const accountResult = await this.clients.googleAds.getAccount();\n health.push({\n platform: \"Google Ads\",\n status: accountResult.success ? \"healthy\" : \"error\",\n message: accountResult.success ? \"Connected\" : accountResult.error,\n lastCheck: new Date().toISOString(),\n });\n } else {\n health.push({\n platform: \"Google Ads\",\n status: \"error\",\n message: authResult.error,\n });\n }\n } catch (error) {\n health.push({\n platform: \"Google Ads\",\n status: \"error\",\n message: error instanceof Error ? error.message : String(error),\n });\n }\n\n // GSC Health Check\n try {\n if (!this.clients.gsc) {\n const config = loadGSCConfig();\n this.clients.gsc = new GSCClient({ config });\n }\n\n const authResult = await this.clients.gsc.authenticate();\n if (authResult.success) {\n const analyticsResult = await this.clients.gsc.getSearchAnalytics({\n dimensions: [\"query\"],\n startDate: \"2024-01-01\",\n endDate: \"2024-01-01\",\n filters: [],\n rowLimit: 1,\n startRow: 0,\n });\n health.push({\n platform: \"GSC\",\n status: analyticsResult.success ? \"healthy\" : \"error\",\n message: analyticsResult.success\n ? \"Connected\"\n : analyticsResult.error,\n lastCheck: new Date().toISOString(),\n });\n } else {\n health.push({\n platform: \"GSC\",\n status: \"error\",\n message: authResult.error,\n });\n }\n } catch (error) {\n health.push({\n platform: \"GSC\",\n status: \"error\",\n message: error instanceof Error ? error.message : String(error),\n });\n }\n\n spinner.stop();\n\n // Display results\n console.log(chalk.bold(\"\\n🏥 Platform Health Status\\n\"));\n\n const tableData = [\n [\"Platform\", \"Status\", verbose ? \"Message\" : \"\"].filter(Boolean),\n ];\n\n for (const platform of health) {\n const statusColor =\n platform.status === \"healthy\" ? chalk.green : chalk.red;\n const statusText =\n platform.status === \"healthy\" ? \"✅ Healthy\" : \"❌ Error\";\n\n const row = [\n platform.platform,\n statusColor(statusText),\n verbose ? platform.message || \"\" : \"\",\n ].filter(Boolean);\n\n tableData.push(row);\n }\n\n console.log(\n table(tableData, {\n border: {\n topBody: \"─\",\n topJoin: \"┬\",\n topLeft: \"┌\",\n topRight: \"┐\",\n bottomBody: \"─\",\n bottomJoin: \"┴\",\n bottomLeft: \"└\",\n bottomRight: \"┘\",\n bodyLeft: \"│\",\n bodyRight: \"│\",\n bodyJoin: \"│\",\n joinBody: \"─\",\n joinLeft: \"├\",\n joinRight: \"┤\",\n joinJoin: \"┼\",\n },\n })\n );\n\n const healthyCount = health.filter((h) => h.status === \"healthy\").length;\n const totalCount = health.length;\n\n if (healthyCount === totalCount) {\n console.log(\n chalk.green(`\\n✅ All ${totalCount} platforms are healthy\\n`)\n );\n } else {\n console.log(\n chalk.yellow(\n `\\n⚠️ ${healthyCount}/${totalCount} platforms are healthy\\n`\n )\n );\n }\n }\n\n async gtmQuery(options: {\n type: \"variables\" | \"tags\" | \"triggers\" | \"workspaces\" | \"versions\" | \"all\";\n workspace?: string;\n filter?: string;\n }): Promise<void> {\n const spinner = ora(\"Querying GTM configuration...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n // Authenticate\n spinner.text = \"Authenticating with GTM API...\";\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // Select workspace\n const workspaceResult = await this.clients.gtm.selectWorkspace(\n options.workspace // Pass workspace ID if provided\n );\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n const results: Record<string, unknown> = {};\n\n if (options.type === \"all\" || options.type === \"workspaces\") {\n spinner.text = \"Fetching workspaces...\";\n const workspacesResult = await this.clients.gtm.listWorkspaces();\n if (workspacesResult.success) {\n results.workspaces = workspacesResult.data;\n }\n }\n\n if (options.type === \"all\" || options.type === \"variables\") {\n spinner.text = \"Fetching variables...\";\n const variablesResult = await this.clients.gtm.listVariables();\n if (variablesResult.success) {\n results.variables = options.filter\n ? variablesResult.data.filter(\n (v: GTMVariable) =>\n v.name\n ?.toLowerCase()\n .includes(options.filter?.toLowerCase()) ||\n v.type?.toLowerCase().includes(options.filter?.toLowerCase())\n )\n : variablesResult.data;\n }\n }\n\n if (options.type === \"all\" || options.type === \"tags\") {\n spinner.text = \"Fetching tags...\";\n const tagsResult = await this.clients.gtm.listTags();\n if (tagsResult.success) {\n results.tags = options.filter\n ? tagsResult.data.filter(\n (t: GTMTag) =>\n t.name\n ?.toLowerCase()\n .includes(options.filter?.toLowerCase()) ||\n t.type?.toLowerCase().includes(options.filter?.toLowerCase())\n )\n : tagsResult.data;\n }\n }\n\n if (options.type === \"all\" || options.type === \"triggers\") {\n spinner.text = \"Fetching triggers...\";\n const triggersResult = await this.clients.gtm.listTriggers();\n if (triggersResult.success) {\n results.triggers = options.filter\n ? triggersResult.data.filter(\n (tr: GTMTrigger) =>\n tr.name\n ?.toLowerCase()\n .includes(options.filter?.toLowerCase()) ||\n tr.type?.toLowerCase().includes(options.filter?.toLowerCase())\n )\n : triggersResult.data;\n }\n }\n\n if (options.type === \"all\" || options.type === \"versions\") {\n spinner.text = \"Fetching versions...\";\n const versionsResult = await this.clients.gtm.listVersions();\n if (versionsResult.success) {\n results.versions = versionsResult.data;\n }\n }\n\n spinner.stop();\n\n console.log(chalk.bold(`\\n📊 GTM Configuration Query Results\\n`));\n console.log(chalk.cyan(`Container: GTM-T8WRBMWV`));\n\n if (results.workspaces) {\n console.log(\n chalk.yellow(`\\n🏠 Workspaces (${results.workspaces.length}):`)\n );\n (results.workspaces as GTMWorkspace[]).forEach((ws) => {\n console.log(` - ${ws.name} (ID: ${ws.workspaceId})`);\n });\n }\n\n if (results.variables) {\n console.log(\n chalk.yellow(`\\n📝 Variables (${results.variables.length}):`)\n );\n (results.variables as GTMVariable[]).forEach((variable) => {\n const value =\n variable.parameter?.find((p) => p.key === \"value\")?.value || \"N/A\";\n console.log(` - ${variable.name} (${variable.type}): ${value}`);\n });\n }\n\n if (results.tags) {\n console.log(chalk.yellow(`\\n🏷️ Tags (${results.tags.length}):`));\n (results.tags as GTMTag[]).forEach((tag) => {\n console.log(` - ${tag.name} (${tag.type})`);\n });\n }\n\n if (results.triggers) {\n console.log(\n chalk.yellow(`\\n⚡ Triggers (${results.triggers.length}):`)\n );\n (results.triggers as GTMTrigger[]).forEach((trigger) => {\n console.log(` - ${trigger.name} (${trigger.type})`);\n });\n }\n\n if (results.versions) {\n console.log(\n chalk.yellow(`\\n📋 Versions (${results.versions.length}):`)\n );\n (results.versions as any[]).forEach((version) => {\n const publishedAt = version.publishedContainerVersionId\n ? \" (Published)\"\n : \"\";\n console.log(\n ` - Version ${version.containerVersionId}: ${version.name}${publishedAt}`\n );\n });\n }\n\n // Output raw JSON if requested\n if (options.type !== \"all\") {\n console.log(chalk.dim(\"\\n📄 Raw JSON:\"));\n console.log(JSON.stringify(results, null, 2));\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async standardizeEvents(options: {\n events: string[];\n source?: string;\n target?: string;\n }): Promise<void> {\n console.log(chalk.bold(\"\\n🔄 Event Standardization\\n\"));\n\n const mappings: Record<string, any> = {};\n\n for (const event of options.events) {\n const isLeadEvent = Object.values(LEAD_GENERATION_EVENTS).includes(\n event as any\n );\n const isEcommerceEvent = Object.values(ECOMMERCE_EVENTS).includes(\n event as any\n );\n\n if (isLeadEvent) {\n mappings[event] = {\n category: \"lead_generation\",\n lead_score: LEAD_SCORES[event as keyof typeof LEAD_SCORES] || 0,\n platform_mappings: options.target\n ? {\n [options.target]:\n PLATFORM_MAPPINGS[\n options.target.toUpperCase() as keyof typeof PLATFORM_MAPPINGS\n ]?.LEAD_GENERATION,\n }\n : Object.fromEntries(\n Object.entries(PLATFORM_MAPPINGS).map(([platform, mapping]) => [\n platform.toLowerCase(),\n mapping.LEAD_GENERATION,\n ])\n ),\n };\n } else if (isEcommerceEvent) {\n mappings[event] = {\n category: \"ecommerce\",\n platform_mappings: options.target\n ? {\n [options.target]:\n PLATFORM_MAPPINGS[\n options.target.toUpperCase() as keyof typeof PLATFORM_MAPPINGS\n ]?.ECOMMERCE,\n }\n : Object.fromEntries(\n Object.entries(PLATFORM_MAPPINGS).map(([platform, mapping]) => [\n platform.toLowerCase(),\n mapping.ECOMMERCE,\n ])\n ),\n };\n } else {\n mappings[event] = {\n category: \"custom\",\n note: \"Event not in standardized schema, requires manual mapping\",\n };\n }\n }\n\n console.log(JSON.stringify(mappings, null, 2));\n }\n\n async scoreLeads(options: { file: string; method: string }): Promise<void> {\n const spinner = ora(\"Loading events file...\").start();\n\n try {\n const fileContent = await fs.readFile(options.file, \"utf-8\");\n const events = JSON.parse(fileContent);\n\n spinner.text = \"Calculating lead scores...\";\n\n const scoredLeads = (events as LeadEvent[]).map((event): ScoredLead => {\n const leadScore =\n options.method === \"default\"\n ? LEAD_SCORES[event.event_name as keyof typeof LEAD_SCORES] || 0\n : this.calculateCustomLeadScore(event);\n\n return {\n ...event,\n calculated_lead_score: leadScore,\n qualification_level: this.getQualificationLevel(leadScore),\n };\n });\n\n const summary = {\n total_leads: scoredLeads.length,\n high_quality_leads: scoredLeads.filter(\n (l) => l.calculated_lead_score >= 70\n ).length,\n medium_quality_leads: scoredLeads.filter(\n (l) => l.calculated_lead_score >= 40 && l.calculated_lead_score < 70\n ).length,\n low_quality_leads: scoredLeads.filter(\n (l) => l.calculated_lead_score < 40\n ).length,\n average_score: Math.round(\n scoredLeads.reduce(\n (sum: number, l) => sum + l.calculated_lead_score,\n 0\n ) / scoredLeads.length\n ),\n };\n\n spinner.stop();\n\n console.log(chalk.bold(\"\\n📊 Lead Scoring Results\\n\"));\n console.log(\n JSON.stringify({ summary, scored_leads: scoredLeads }, null, 2)\n );\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmSync(): Promise<void> {\n const spinner = ora(\"Syncing GTM configuration...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // Select workspace\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n // Read current YAML config\n spinner.text = \"Reading current configuration...\";\n let yamlContent: string;\n try {\n yamlContent = await fs.readFile(\"gtm.config.yaml\", \"utf-8\");\n } catch (_error) {\n throw new Error(\n \"gtm.config.yaml not found. Please create the configuration file first.\"\n );\n }\n\n // Parse YAML\n const config = yaml.load(yamlContent) as any;\n\n // Query current GTM variables to get actual Google Ads ID\n spinner.text = \"Querying current GTM state...\";\n const variablesResult = await this.clients.gtm.listVariables();\n if (variablesResult.success && variablesResult.data) {\n // Find Google Ads Conversion ID variable\n const googleAdsVar = variablesResult.data.find(\n (v: GTMVariable) =>\n v.name === \"Google Ads Conversion ID\" ||\n v.name === \"Google Ads - Conversion ID\"\n );\n\n if (googleAdsVar?.parameter) {\n const valueParam = googleAdsVar.parameter?.find(\n (p) => p.key === \"value\"\n );\n if (valueParam) {\n const currentGoogleAdsId = valueParam.value.replace(\"AW-\", \"\");\n if (\n config.variables &&\n config.variables.google_ads_id !== currentGoogleAdsId\n ) {\n config.variables.google_ads_id = currentGoogleAdsId;\n spinner.text = `Updated Google Ads ID to ${currentGoogleAdsId}`;\n }\n }\n }\n }\n\n // Write updated YAML back to file\n spinner.text = \"Writing updated configuration...\";\n const updatedYaml = yaml.dump(config, {\n indent: 2,\n lineWidth: -1,\n quotingType: '\"',\n forceQuotes: false,\n });\n await fs.writeFile(\"gtm.config.yaml\", updatedYaml, \"utf-8\");\n\n spinner.stop();\n console.log(chalk.green(\"✅ GTM configuration synced successfully\"));\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmUpdateGoogleAdsId(): Promise<void> {\n const spinner = ora(\"Updating Google Ads ID in GTM...\").start();\n\n const OLD_GOOGLE_ADS_ID = \"659644670\";\n const NEW_GOOGLE_ADS_ID = \"8847935674\";\n\n try {\n // Force a fresh GTM client for this operation to ensure latest methods\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, debug: true, failFast: true });\n\n // Authenticate\n spinner.text = \"Authenticating with GTM API...\";\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // Select workspace\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n // List all variables\n spinner.text = \"Finding Google Ads variables...\";\n const variablesResult = await this.clients.gtm.listVariables();\n if (!variablesResult.success) {\n throw new Error(`Failed to list variables: ${variablesResult.error}`);\n }\n\n // Find Google Ads related variables\n const googleAdsVariables = variablesResult.data.filter((variable) => {\n const nameMatch =\n variable.name?.toLowerCase().includes(\"google ads\") ||\n variable.name?.toLowerCase().includes(\"conversion id\");\n\n const valueMatch = variable.parameter?.some(\n (param) =>\n param.value?.includes(OLD_GOOGLE_ADS_ID) ||\n param.value?.includes(`AW-${OLD_GOOGLE_ADS_ID}`)\n );\n\n return nameMatch || valueMatch;\n });\n\n spinner.stop();\n console.log(\n chalk.cyan(\n `Found ${googleAdsVariables.length} Google Ads related variables:`\n )\n );\n googleAdsVariables.forEach((v) => {\n const value =\n v.parameter?.find((p) => p.key === \"value\")?.value || \"No value\";\n console.log(` - ${v.name} (ID: ${v.variableId}): ${value}`);\n });\n\n // Update each variable\n if (googleAdsVariables.length > 0) {\n console.log(chalk.yellow(\"🔄 Updating variables...\"));\n\n for (const variable of googleAdsVariables) {\n const currentValue = variable.parameter?.find(\n (p) => p.key === \"value\"\n )?.value;\n\n if (!currentValue) {\n console.log(\n chalk.gray(` ⏭️ Skipping ${variable.name} - no value found`)\n );\n continue;\n }\n\n // Determine new value\n let newValue = currentValue;\n if (currentValue === OLD_GOOGLE_ADS_ID) {\n newValue = NEW_GOOGLE_ADS_ID;\n } else if (currentValue === `AW-${OLD_GOOGLE_ADS_ID}`) {\n newValue = `AW-${NEW_GOOGLE_ADS_ID}`;\n } else if (currentValue.includes(OLD_GOOGLE_ADS_ID)) {\n newValue = currentValue.replace(\n OLD_GOOGLE_ADS_ID,\n NEW_GOOGLE_ADS_ID\n );\n } else {\n console.log(\n chalk.gray(\n ` ⏭️ Skipping ${variable.name} - doesn't contain old ID`\n )\n );\n continue;\n }\n\n console.log(chalk.blue(` 📝 Updating ${variable.name}:`));\n console.log(chalk.gray(` From: ${currentValue}`));\n console.log(chalk.green(` To: ${newValue}`));\n\n // Update the variable\n const updateResult = await this.clients.gtm.updateVariable(\n variable.variableId,\n {\n value: newValue,\n }\n );\n\n if (updateResult.success) {\n console.log(chalk.green(\" ✅ Updated successfully\"));\n } else {\n console.log(\n chalk.red(` ❌ Failed to update: ${updateResult.error}`)\n );\n }\n }\n } else {\n console.log(chalk.yellow(\"ℹ️ No variables need updating\"));\n }\n\n // Now update tags that may contain the old ID\n const tagsSpinner = ora(\"Finding tags with old Google Ads ID...\").start();\n\n const tagsResult = await this.clients.gtm.listTags();\n if (!tagsResult.success) {\n tagsSpinner.stop();\n throw new Error(`Failed to list tags: ${tagsResult.error}`);\n }\n\n // Find tags that contain the old Google Ads ID\n const tagsToUpdate = tagsResult.data.filter((tag) => {\n // Check all parameters for the old ID\n return tag.parameter?.some((param) => {\n const value = param.value || \"\";\n return (\n value.includes(OLD_GOOGLE_ADS_ID) ||\n value.includes(`AW-${OLD_GOOGLE_ADS_ID}`)\n );\n });\n });\n\n tagsSpinner.stop();\n\n if (tagsToUpdate.length > 0) {\n console.log(\n chalk.cyan(\n `\\nFound ${tagsToUpdate.length} tags with old Google Ads ID:`\n )\n );\n tagsToUpdate.forEach((tag) => {\n console.log(` - ${tag.name} (ID: ${tag.tagId})`);\n });\n\n console.log(chalk.yellow(\"\\n🔄 Updating tags...\"));\n\n for (const tag of tagsToUpdate) {\n console.log(chalk.blue(` 📝 Updating ${tag.name}:`));\n\n // Update parameters that contain the old ID\n const updatedParameters = tag.parameter?.map((param) => {\n if (param.value?.includes(OLD_GOOGLE_ADS_ID)) {\n const newValue = param.value.replace(\n OLD_GOOGLE_ADS_ID,\n NEW_GOOGLE_ADS_ID\n );\n console.log(\n chalk.gray(\n ` Parameter ${param.key}: ${param.value} → ${newValue}`\n )\n );\n return { ...param, value: newValue };\n } else if (param.value?.includes(`AW-${OLD_GOOGLE_ADS_ID}`)) {\n const newValue = param.value.replace(\n `AW-${OLD_GOOGLE_ADS_ID}`,\n `AW-${NEW_GOOGLE_ADS_ID}`\n );\n console.log(\n chalk.gray(\n ` Parameter ${param.key}: ${param.value} → ${newValue}`\n )\n );\n return { ...param, value: newValue };\n }\n return param;\n });\n\n // Update the tag directly via GTM API using the same pattern as updateConversionLabels\n const tagPath = `accounts/${\n (this.clients.gtm as any).config.accountId\n }/containers/${\n (this.clients.gtm as any).config.containerId\n }/workspaces/${(this.clients.gtm as any).workspaceId}/tags/${\n tag.tagId\n }`;\n\n try {\n await (\n this.clients.gtm as any\n ).tagmanager.accounts.containers.workspaces.tags.update({\n path: tagPath,\n requestBody: {\n ...tag,\n parameter: updatedParameters,\n },\n });\n console.log(chalk.green(\" ✅ Updated successfully\"));\n } catch (error) {\n console.log(\n chalk.red(\n ` ❌ Failed to update: ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n );\n }\n }\n } else {\n console.log(\n chalk.green(\n \"\\n✅ No tags need updating - all tags already use the new ID\"\n )\n );\n }\n\n console.log(\"\");\n console.log(chalk.cyan(\"🎯 Next Steps:\"));\n console.log(\"1. Review the changes in GTM workspace\");\n console.log(\"2. Test the configuration in Preview mode\");\n console.log(\"3. Use GTM UI to publish workspace to production\");\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmUpdateEventNames(): Promise<void> {\n const spinner = ora(\"Updating event names in GTM triggers...\").start();\n\n try {\n // Force a fresh GTM client\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, debug: true, failFast: true });\n\n // Authenticate\n spinner.text = \"Authenticating with GTM API...\";\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // Select workspace\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n spinner.text = \"Finding triggers with old event names...\";\n const triggersResult = await this.clients.gtm.listTriggers();\n if (!triggersResult.success) {\n throw new Error(`Failed to list triggers: ${triggersResult.error}`);\n }\n\n // Find triggers that need updating from enhanced_funnel_stage to lead_funnel_stage\n const triggersToUpdate = triggersResult.data.filter((trigger) => {\n return trigger.customEventFilter?.some((filter) => {\n return filter.parameter?.some((param) => {\n return param.value === \"enhanced_funnel_stage\";\n });\n });\n });\n\n spinner.stop();\n\n if (triggersToUpdate.length > 0) {\n console.log(\n chalk.cyan(`\\nFound ${triggersToUpdate.length} triggers to update:`)\n );\n triggersToUpdate.forEach((trigger) => {\n console.log(` - ${trigger.name} (ID: ${trigger.triggerId})`);\n });\n\n console.log(chalk.yellow(\"\\n🔄 Updating triggers...\"));\n\n for (const trigger of triggersToUpdate) {\n console.log(chalk.blue(` 📝 Updating ${trigger.name}:`));\n\n // Update the custom event filter to use lead_funnel_stage\n const updatedFilters = trigger.customEventFilter?.map((filter) => ({\n ...filter,\n parameter: filter.parameter?.map((param) => {\n if (param.value === \"enhanced_funnel_stage\") {\n console.log(\n chalk.gray(\n ` Event name: enhanced_funnel_stage → lead_funnel_stage`\n )\n );\n return { ...param, value: \"lead_funnel_stage\" };\n }\n return param;\n }),\n }));\n\n // Update the trigger directly via GTM API\n const triggerPath = `accounts/${\n (this.clients.gtm as any).config.accountId\n }/containers/${\n (this.clients.gtm as any).config.containerId\n }/workspaces/${(this.clients.gtm as any).workspaceId}/triggers/${\n trigger.triggerId\n }`;\n\n try {\n await (\n this.clients.gtm as any\n ).tagmanager.accounts.containers.workspaces.triggers.update({\n path: triggerPath,\n requestBody: {\n ...trigger,\n customEventFilter: updatedFilters,\n },\n });\n console.log(chalk.green(\" ✅ Updated successfully\"));\n } catch (error) {\n console.log(\n chalk.red(\n ` ❌ Failed to update: ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n );\n }\n }\n } else {\n console.log(\n chalk.green(\n \"\\n✅ No triggers need updating - all already use lead_funnel_stage\"\n )\n );\n }\n\n console.log(\"\");\n console.log(chalk.cyan(\"🎯 Next Steps:\"));\n console.log(\"1. Review the changes in GTM workspace\");\n console.log(\"2. Test the configuration in Preview mode\");\n console.log(\"3. Use GTM UI to publish workspace to production\");\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n // GTM publish functionality removed - use GTM UI for production publishing\n // Publishing via API has limitations and is not recommended for production use\n\n async posthogQuery(options: { query: string; limit: string }): Promise<void> {\n const spinner = ora(\"Executing PostHog query...\").start();\n\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const result = await this.clients.postHog.query({\n query: `${options.query} LIMIT ${options.limit}`,\n });\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.bold(\"\\n📊 PostHog Query Results\\n\"));\n console.log(JSON.stringify(result.data, null, 2));\n } else {\n console.error(chalk.red(\"Query failed:\"), result.error);\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async posthogFunnel(options: {\n events: string[];\n start: string;\n end: string;\n }): Promise<void> {\n const spinner = ora(\"Analyzing funnel...\").start();\n\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const funnelQuery = `\n\t\t\t\tSELECT \n\t\t\t\t\tfunnel_step,\n\t\t\t\t\tcount() as users,\n\t\t\t\t\tround(conversion_rate * 100, 2) as conversion_percentage\n\t\t\t\tFROM (\n\t\t\t\t\tSELECT \n\t\t\t\t\t\twindowFunnel(86400)([${options.events.map((e) => `'${e}'`).join(\", \")}])\n\t\t\t\t\t\t(timestamp, event) as funnel_steps,\n\t\t\t\t\t\tdistinct_id\n\t\t\t\t\tFROM events \n\t\t\t\t\tWHERE \n\t\t\t\t\t\tdate >= '${options.start}' \n\t\t\t\t\t\tAND date <= '${options.end}'\n\t\t\t\t\t\tAND event IN [${options.events.map((e) => `'${e}'`).join(\", \")}]\n\t\t\t\t\tGROUP BY distinct_id\n\t\t\t\t)\n\t\t\t\tCROSS JOIN ARRAY[${options.events\n .map((_, i) => i + 1)\n .join(\", \")}] as funnel_step\n\t\t\t\tWHERE funnel_steps >= funnel_step\n\t\t\t\tGROUP BY funnel_step\n\t\t\t\tORDER BY funnel_step\n\t\t\t`;\n\n const result = await this.clients.postHog.query({ query: funnelQuery });\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.bold(\"\\n🔄 Funnel Analysis Results\\n\"));\n console.log(JSON.stringify(result.data, null, 2));\n } else {\n console.error(chalk.red(\"Funnel analysis failed:\"), result.error);\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n // PostHog Feature Flags & Experiments\n async posthogListFlags(options: { project?: string }): Promise<void> {\n const spinner = ora(\"Fetching feature flags...\").start();\n\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const projectId = options.project\n ? parseInt(options.project, 10)\n : undefined;\n const result = await this.clients.postHog.getFeatureFlags(projectId);\n\n spinner.stop();\n\n if (result.success && result.data) {\n console.log(chalk.bold(\"\\n🏁 Feature Flags\\n\"));\n\n const tableData = [\n [\"ID\", \"Key\", \"Name\", \"Active\", \"Rollout\", \"Type\"],\n ...result.data.map((flag) => [\n flag.id.toString(),\n flag.key,\n flag.name,\n flag.active ? \"✅\" : \"❌\",\n flag.rollout_percentage ? `${flag.rollout_percentage}%` : \"100%\",\n flag.filters?.multivariate ? \"Experiment\" : \"Boolean\",\n ]),\n ];\n\n console.log(table(tableData));\n console.log(chalk.gray(`\\nTotal: ${result.data.length} flags`));\n } else {\n console.error(\n chalk.red(\"Failed to fetch feature flags:\"),\n result.error\n );\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async posthogGetFlag(options: {\n id: string;\n project?: string;\n }): Promise<void> {\n const spinner = ora(\"Fetching feature flag details...\").start();\n\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const flagId = parseInt(options.id, 10);\n const projectId = options.project\n ? parseInt(options.project, 10)\n : undefined;\n const result = await this.clients.postHog.getFeatureFlag(\n flagId,\n projectId\n );\n\n spinner.stop();\n\n if (result.success && result.data) {\n const flag = result.data;\n console.log(chalk.bold(\"\\n🏁 Feature Flag Details\\n\"));\n console.log(`${chalk.bold(\"ID:\")} ${flag.id}`);\n console.log(`${chalk.bold(\"Key:\")} ${flag.key}`);\n console.log(`${chalk.bold(\"Name:\")} ${flag.name}`);\n console.log(\n `${chalk.bold(\"Active:\")} ${flag.active ? \"✅ Yes\" : \"❌ No\"}`\n );\n console.log(\n `${chalk.bold(\"Rollout:\")} ${flag.rollout_percentage || 100}%`\n );\n console.log(\n `${chalk.bold(\"Continuity:\")} ${\n flag.ensure_experience_continuity ? \"✅ Yes\" : \"❌ No\"\n }`\n );\n\n if (flag.filters?.multivariate?.variants) {\n console.log(chalk.bold(\"\\nVariants:\"));\n flag.filters.multivariate.variants.forEach((variant: any) => {\n console.log(` • ${variant.key}: ${variant.rollout_percentage}%`);\n });\n }\n\n console.log(\n `${chalk.bold(\"Created:\")} ${new Date(\n flag.created_at\n ).toLocaleDateString()}`\n );\n } else {\n console.error(chalk.red(\"Failed to fetch feature flag:\"), result.error);\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async posthogCreateFlag(options: {\n key: string;\n name: string;\n description?: string;\n active: boolean;\n rollout: string;\n project?: string;\n }): Promise<void> {\n const spinner = ora(\"Creating feature flag...\").start();\n\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const projectId = options.project\n ? parseInt(options.project, 10)\n : undefined;\n const rolloutPercent = parseInt(options.rollout, 10);\n\n const flagPayload = {\n key: options.key,\n name: options.name,\n description: options.description,\n active: options.active,\n deleted: false,\n rollout_percentage: rolloutPercent,\n ensure_experience_continuity: true,\n };\n\n const result = await this.clients.postHog.createFeatureFlag(\n flagPayload,\n projectId\n );\n\n spinner.stop();\n\n if (result.success && result.data) {\n console.log(chalk.green(\"✅ Feature flag created successfully!\"));\n console.log(`${chalk.bold(\"ID:\")} ${result.data.id}`);\n console.log(`${chalk.bold(\"Key:\")} ${result.data.key}`);\n console.log(`${chalk.bold(\"Name:\")} ${result.data.name}`);\n } else {\n console.error(\n chalk.red(\"Failed to create feature flag:\"),\n result.error\n );\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async posthogCreateExperiment(options: {\n key: string;\n name: string;\n variants: string;\n description?: string;\n equalSplit: boolean;\n rollout: string;\n continuity: boolean;\n project?: string;\n }): Promise<void> {\n const spinner = ora(\"Creating multivariate experiment...\").start();\n\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const projectId = options.project\n ? parseInt(options.project, 10)\n : undefined;\n const rolloutPercent = parseInt(options.rollout, 10);\n const variantKeys = options.variants.split(\",\").map((v) => v.trim());\n\n // Calculate equal split percentages\n const percentagePerVariant = options.equalSplit\n ? Math.round((100 / variantKeys.length) * 100) / 100 // Round to 2 decimal places\n : 100 / variantKeys.length;\n\n const variants = variantKeys.map((key) => ({\n key,\n name: key.charAt(0).toUpperCase() + key.slice(1),\n rollout_percentage: percentagePerVariant,\n }));\n\n const experimentConfig = {\n key: options.key,\n name: options.name,\n description: options.description,\n variants,\n rollout_percentage: rolloutPercent,\n ensure_experience_continuity: options.continuity,\n };\n\n const result = await this.clients.postHog.createMultivariateExperiment(\n experimentConfig,\n projectId\n );\n\n spinner.stop();\n\n if (result.success && result.data) {\n console.log(\n chalk.green(\"✅ Multivariate experiment created successfully!\")\n );\n console.log(`${chalk.bold(\"ID:\")} ${result.data.id}`);\n console.log(`${chalk.bold(\"Key:\")} ${result.data.key}`);\n console.log(`${chalk.bold(\"Name:\")} ${result.data.name}`);\n console.log(`${chalk.bold(\"Variants:\")} ${variantKeys.join(\", \")}`);\n console.log(`${chalk.bold(\"Split:\")} ${percentagePerVariant}% each`);\n } else {\n console.error(chalk.red(\"Failed to create experiment:\"), result.error);\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async posthogUpdateFlag(options: {\n id: string;\n name?: string;\n description?: string;\n active?: string;\n rollout?: string;\n project?: string;\n }): Promise<void> {\n const spinner = ora(\"Updating feature flag...\").start();\n\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const flagId = parseInt(options.id, 10);\n const projectId = options.project\n ? parseInt(options.project, 10)\n : undefined;\n\n const updates: any = {};\n if (options.name) updates.name = options.name;\n if (options.description) updates.description = options.description;\n if (options.active) updates.active = options.active === \"true\";\n if (options.rollout)\n updates.rollout_percentage = parseInt(options.rollout, 10);\n\n const result = await this.clients.postHog.updateFeatureFlag(\n flagId,\n updates,\n projectId\n );\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green(\"✅ Feature flag updated successfully!\"));\n } else {\n console.error(\n chalk.red(\"Failed to update feature flag:\"),\n result.error\n );\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async posthogDeleteFlag(options: {\n id: string;\n project?: string;\n yes?: boolean;\n }): Promise<void> {\n try {\n if (!options.yes) {\n const answers = await inquirer.prompt([\n {\n type: \"confirm\",\n name: \"confirm\",\n message: `Are you sure you want to delete feature flag ${options.id}?`,\n default: false,\n },\n ]);\n\n if (!answers.confirm) {\n console.log(chalk.yellow(\"Operation cancelled.\"));\n return;\n }\n }\n\n const spinner = ora(\"Deleting feature flag...\").start();\n\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const flagId = parseInt(options.id, 10);\n const projectId = options.project\n ? parseInt(options.project, 10)\n : undefined;\n\n const result = await this.clients.postHog.deleteFeatureFlag(\n flagId,\n projectId\n );\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green(\"✅ Feature flag deleted successfully!\"));\n } else {\n console.error(\n chalk.red(\"Failed to delete feature flag:\"),\n result.error\n );\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async posthogEvaluateFlags(options: {\n user: string;\n groups?: string;\n personProps?: string;\n }): Promise<void> {\n const spinner = ora(\"Evaluating feature flags...\").start();\n\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const payload: any = {\n distinctId: options.user,\n };\n\n if (options.groups) {\n payload.groups = JSON.parse(options.groups);\n }\n\n if (options.personProps) {\n payload.personProperties = JSON.parse(options.personProps);\n }\n\n const result = await this.clients.postHog.evaluateFeatureFlags(payload);\n\n spinner.stop();\n\n if (result.success && result.data) {\n console.log(chalk.bold(\"\\n🏁 Feature Flag Evaluation\\n\"));\n console.log(`${chalk.bold(\"User:\")} ${options.user}`);\n\n const flags = result.data.flags;\n if (Object.keys(flags).length === 0) {\n console.log(chalk.yellow(\"No feature flags matched for this user.\"));\n } else {\n console.log(chalk.bold(\"\\nActive Flags:\"));\n Object.entries(flags).forEach(([key, value]) => {\n const status =\n value === true ? \"✅\" : value === false ? \"❌\" : `🎯 ${value}`;\n console.log(` ${key}: ${status}`);\n });\n }\n\n const payloads = result.data.flagPayloads;\n if (Object.keys(payloads).length > 0) {\n console.log(chalk.bold(\"\\nFlag Payloads:\"));\n Object.entries(payloads).forEach(([key, payload]) => {\n console.log(` ${key}: ${JSON.stringify(payload)}`);\n });\n }\n } else {\n console.error(chalk.red(\"Failed to evaluate flags:\"), result.error);\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async googleAdsConversions(options: {\n start: string;\n end: string;\n }): Promise<void> {\n const spinner = ora(\"Fetching Google Ads conversions...\").start();\n\n try {\n if (!this.clients.googleAds) {\n const config = loadGoogleAdsConfig();\n this.clients.googleAds = new GoogleAdsClient({ config });\n }\n\n await this.clients.googleAds.authenticate();\n\n const result = await this.clients.googleAds.getConversions({\n startDate: options.start,\n endDate: options.end,\n });\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.bold(\"\\n💰 Google Ads Conversions\\n\"));\n console.log(JSON.stringify(result.data, null, 2));\n } else {\n console.error(chalk.red(\"Conversions fetch failed:\"), result.error);\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gscRankings(options: {\n keywords: string[];\n start: string;\n end: string;\n }): Promise<void> {\n const spinner = ora(\"Checking GSC keyword rankings...\").start();\n\n try {\n if (!this.clients.gsc) {\n const config = loadGSCConfig();\n this.clients.gsc = new GSCClient({ config });\n }\n\n await this.clients.gsc.authenticate();\n\n const keywordFilters = options.keywords.map((keyword) => ({\n dimension: \"query\",\n operator: \"contains\" as const,\n expression: keyword,\n }));\n\n const result = await this.clients.gsc.getSearchAnalytics({\n dimensions: [\"query\"],\n startDate: options.start,\n endDate: options.end,\n filters: keywordFilters,\n rowLimit: 1000,\n startRow: 0,\n });\n\n spinner.stop();\n\n if (result.success) {\n const rankings =\n result.data?.rows?.map((row) => ({\n keyword: row.keys?.[0],\n clicks: row.clicks,\n impressions: row.impressions,\n ctr: Math.round((row.ctr || 0) * 100 * 100) / 100,\n position: Math.round((row.position || 0) * 10) / 10,\n })) || [];\n\n console.log(chalk.bold(\"\\n🔍 GSC Keyword Rankings\\n\"));\n console.log(JSON.stringify(rankings, null, 2));\n } else {\n console.error(chalk.red(\"Rankings fetch failed:\"), result.error);\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async crossPlatformAnalysis(options: {\n start: string;\n end: string;\n platforms: string[];\n events?: string[];\n }): Promise<void> {\n const spinner = ora(\"Running cross-platform analysis...\").start();\n\n try {\n const results: Record<string, any> = {};\n\n for (const platform of options.platforms) {\n spinner.text = `Analyzing ${platform}...`;\n\n switch (platform) {\n case \"posthog\": {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const eventsQuery = options.events?.length\n ? `SELECT event, count() as event_count FROM events WHERE event IN [${options.events\n .map((e) => `'${e}'`)\n .join(\", \")}] AND date >= '${options.start}' AND date <= '${\n options.end\n }' GROUP BY event`\n : `SELECT event, count() as event_count FROM events WHERE date >= '${options.start}' AND date <= '${options.end}' GROUP BY event LIMIT 100`;\n\n const phResult = await this.clients.postHog.query({\n query: eventsQuery,\n });\n if (phResult.success) {\n results.posthog = phResult.data;\n }\n break;\n }\n\n case \"gsc\": {\n if (!this.clients.gsc) {\n const config = loadGSCConfig();\n this.clients.gsc = new GSCClient({ config });\n await this.clients.gsc.authenticate();\n }\n\n const gscResult = await this.clients.gsc.getSearchAnalytics({\n dimensions: [\"query\"],\n startDate: options.start,\n endDate: options.end,\n filters: [],\n rowLimit: 100,\n startRow: 0,\n });\n if (gscResult.success) {\n results.gsc = gscResult.data;\n }\n break;\n }\n\n case \"google-ads\": {\n if (!this.clients.googleAds) {\n const config = loadGoogleAdsConfig();\n this.clients.googleAds = new GoogleAdsClient({ config });\n await this.clients.googleAds.authenticate();\n }\n\n const gadsResult = await this.clients.googleAds.getConversions({\n startDate: options.start,\n endDate: options.end,\n });\n if (gadsResult.success) {\n results[\"google-ads\"] = gadsResult.data;\n }\n break;\n }\n }\n }\n\n spinner.stop();\n\n console.log(chalk.bold(\"\\n🔄 Cross-Platform Analysis\\n\"));\n console.log(JSON.stringify(results, null, 2));\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async interactiveSetup(): Promise<void> {\n console.log(chalk.bold(\"🚀 Interactive Analytics Setup\\n\"));\n\n const answers = await inquirer.prompt([\n {\n type: \"checkbox\",\n name: \"platforms\",\n message: \"Which platforms would you like to configure?\",\n choices: [\n { name: \"Google Tag Manager\", value: \"gtm\" },\n { name: \"Google Ads\", value: \"google-ads\" },\n { name: \"PostHog\", value: \"posthog\" },\n { name: \"Google Search Console\", value: \"gsc\" },\n ],\n },\n {\n type: \"confirm\",\n name: \"testConnections\",\n message: \"Would you like to test connections after setup?\",\n default: true,\n },\n ]);\n\n console.log(chalk.green(\"\\n✅ Setup configuration saved\"));\n console.log(\"Platform configurations:\", answers.platforms);\n\n if (answers.testConnections) {\n await this.healthCheck();\n }\n }\n\n async generateDashboard(options: {\n start: string;\n end: string;\n output: string;\n }): Promise<void> {\n const spinner = ora(\"Generating unified dashboard...\").start();\n\n try {\n const dashboardData = {\n date_range: { start: options.start, end: options.end },\n generated_at: new Date().toISOString(),\n summary: {\n platforms_analyzed: 0,\n total_events: 0,\n lead_score_average: 0,\n },\n platform_data: {} as Record<string, any>,\n };\n\n // Collect data from available platforms\n if (this.clients.postHog) {\n const leadEventsQuery = `\n\t\t\t\t\tSELECT \n\t\t\t\t\t\tevent,\n\t\t\t\t\t\tcount() as event_count,\n\t\t\t\t\t\tuniq(distinct_id) as unique_users\n\t\t\t\t\tFROM events \n\t\t\t\t\tWHERE date >= '${options.start}' \n\t\t\t\t\t\tAND date <= '${options.end}'\n\t\t\t\t\tGROUP BY event\n\t\t\t\t\tLIMIT 20\n\t\t\t\t`;\n\n const result = await this.clients.postHog.query({\n query: leadEventsQuery,\n });\n if (result.success) {\n dashboardData.platform_data.posthog = result.data;\n dashboardData.summary.platforms_analyzed++;\n }\n }\n\n spinner.stop();\n\n if (options.output === \"table\") {\n console.log(chalk.bold(\"\\n📊 Unified Analytics Dashboard\\n\"));\n\n const tableData = [[\"Metric\", \"Value\"]];\n tableData.push([\"Date Range\", `${options.start} to ${options.end}`]);\n tableData.push([\n \"Platforms Analyzed\",\n dashboardData.summary.platforms_analyzed.toString(),\n ]);\n tableData.push([\"Generated At\", dashboardData.generated_at]);\n\n console.log(table(tableData));\n } else {\n console.log(JSON.stringify(dashboardData, null, 2));\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n private calculateCustomLeadScore(event: LeadEvent): number {\n let score = LEAD_SCORES[event.event_name as keyof typeof LEAD_SCORES] || 0;\n\n if (event.properties) {\n if (event.properties.form_completion > 50) score += 10;\n if (event.properties.page_depth > 3) score += 5;\n if (event.properties.session_duration > 300) score += 5;\n if (event.properties.return_visitor) score += 10;\n }\n\n return Math.min(score, 100);\n }\n\n private getQualificationLevel(score: number): string {\n if (score >= 80) return \"hot\";\n if (score >= 60) return \"warm\";\n if (score >= 40) return \"cold\";\n return \"unqualified\";\n }\n\n // GTM Terraform Methods\n async gtmTerraformInit(options: { config: string }): Promise<void> {\n const spinner = ora(\"Initializing GTM Terraform workspace...\").start();\n\n try {\n const stateManager = new StateManager();\n await stateManager.initialize();\n\n const configParser = new ConfigParser();\n const config = await configParser.loadConfig(options.config);\n const validationResult = configParser.validateConfig(config);\n\n if (!validationResult.valid) {\n spinner.fail(\"Configuration validation failed\");\n console.error(chalk.red(\"Validation errors:\"));\n for (const error of validationResult.errors) {\n console.error(chalk.red(` - ${error}`));\n }\n return;\n }\n\n spinner.succeed(\"GTM Terraform workspace initialized\");\n console.log(chalk.green(`Configuration loaded from: ${options.config}`));\n console.log(chalk.green(`State directory: .gtm-state/`));\n } catch (error) {\n spinner.fail(\"Initialization failed\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmTerraformPlan(options: {\n config: string;\n out?: string;\n workspace?: string;\n }): Promise<void> {\n const spinner = ora(\"Generating GTM plan...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n // Select workspace\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace(\n options.workspace // Pass workspace ID if provided\n );\n if (!workspaceResult.success) {\n throw new Error(\n `Failed to select workspace: ${workspaceResult.error}`\n );\n }\n }\n\n const stateManager = new StateManager();\n const configParser = new ConfigParser();\n const planner = new Planner(this.clients.gtm, configParser);\n\n const config = await configParser.loadConfig(options.config);\n const currentState = (await stateManager.load()) || {\n version: \"1.0.0\",\n terraform_version: \"0.1.0\",\n serial: 1,\n lineage: crypto.randomUUID(),\n outputs: {},\n resources: [],\n check_results: [],\n };\n\n const planResult = await planner.plan(config, currentState);\n\n spinner.stop();\n\n if (planResult.success && planResult.data) {\n const formattedPlan = planner.formatPlan(planResult.data);\n console.log(formattedPlan);\n\n if (options.out) {\n await fs.writeFile(\n options.out,\n JSON.stringify(planResult.data, null, 2)\n );\n console.log(chalk.green(`Plan saved to: ${options.out}`));\n }\n\n console.log(\n chalk.blue(`\\nPlan: ${planResult.resource_changes} changes`)\n );\n } else {\n console.error(chalk.red(\"Plan generation failed:\"), planResult.error);\n }\n } catch (error) {\n spinner.fail(\"Plan generation failed\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmTerraformApply(options: {\n config: string;\n plan?: string;\n workspace?: string;\n yes?: boolean;\n verbose?: boolean;\n }): Promise<void> {\n const spinner = ora(\"Applying GTM configuration changes...\").start();\n\n // Verbose logging helper\n const verboseLog = (message: string, data?: any) => {\n if (options.verbose) {\n spinner.stop();\n console.log(chalk.cyan(`[VERBOSE] ${message}`));\n if (data) {\n console.log(chalk.dim(JSON.stringify(data, null, 2)));\n }\n spinner.start();\n }\n };\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n // Select workspace\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace(\n options.workspace // Pass workspace ID if provided\n );\n if (!workspaceResult.success) {\n throw new Error(\n `Failed to select workspace: ${workspaceResult.error}`\n );\n }\n }\n\n const stateManager = new StateManager();\n const configParser = new ConfigParser();\n const planner = new Planner(this.clients.gtm, configParser);\n\n // Load configuration\n spinner.text = \"Loading configuration...\";\n const config = await configParser.loadConfig(options.config);\n this.currentConfig = config; // Store config for variable resolution\n const currentState = (await stateManager.load()) || {\n version: \"1.0.0\",\n terraform_version: \"0.1.0\",\n serial: 1,\n lineage: crypto.randomUUID(),\n outputs: {},\n resources: [],\n check_results: [],\n };\n\n // Generate plan\n spinner.text = \"Generating execution plan...\";\n const planResult = await planner.plan(config, currentState);\n\n if (!planResult.success || !planResult.data) {\n throw new Error(`Plan generation failed: ${planResult.error}`);\n }\n\n const plan = planResult.data;\n console.log(\n chalk.blue(`\\nApplying changes: ${plan.changes.length} operations\\n`)\n );\n\n // Verbose logging for plan analysis\n verboseLog(`Plan generated with ${plan.changes.length} changes`);\n if (options.verbose) {\n for (const change of plan.changes) {\n verboseLog(\n `Change: ${change.address} (${change.change.actions.join(\", \")})`,\n {\n type: change.type,\n name: change.name,\n actions: change.change.actions,\n hasAfter: !!change.change.after,\n hasBefore: !!change.change.before,\n }\n );\n }\n }\n\n // Separate changes by action type\n const deleteChanges = plan.changes.filter((c) =>\n c.change.actions.includes(\"delete\")\n );\n const createChanges = plan.changes.filter((c) =>\n c.change.actions.includes(\"create\")\n );\n const updateChanges = plan.changes.filter((c) =>\n c.change.actions.includes(\"update\")\n );\n\n verboseLog(\n `Changes breakdown: ${deleteChanges.length} deletes, ${createChanges.length} creates, ${updateChanges.length} updates`\n );\n\n // Execute destroys first (remove unwanted resources)\n if (deleteChanges.length > 0) {\n spinner.text = `Removing ${deleteChanges.length} legacy resources...`;\n verboseLog(`Starting deletion of ${deleteChanges.length} resources`);\n\n for (const change of deleteChanges) {\n await this.smartDelay(); // GTM API rate limiting\n verboseLog(\n `Processing deletion for ${change.address} (${change.name})`\n );\n\n if (options.verbose) {\n console.log(\n chalk.magenta(\n `\\n=== VERBOSE DELETE: ${change.type\n .replace(\"gtm_\", \"\")\n .toUpperCase()} ===`\n )\n );\n console.log(\n chalk.cyan(\n `Resource Name: ${change.change?.before?.name || change.name}`\n )\n );\n console.log(\n chalk.cyan(\n `Resource ID: ${\n change.change?.before?.tagId ||\n change.change?.before?.triggerId ||\n change.change?.before?.variableId\n }`\n )\n );\n console.log(chalk.yellow(`Before state (to be deleted):`));\n console.log(JSON.stringify(change.change?.before, null, 2));\n }\n\n try {\n // Check and handle dependencies before deletion\n const canDelete = await this.handleDependenciesBeforeDeletion(\n change\n );\n if (!canDelete) {\n console.warn(\n chalk.yellow(\n `Skipping deletion of ${change.name} due to dependency issues`\n )\n );\n verboseLog(`Skipped deletion due to dependencies`, {\n resource: change.name,\n });\n continue;\n }\n\n // Extract resource type from the type field (e.g., 'gtm_tag' -> 'tag')\n const resourceType = change.type.replace(\"gtm_\", \"\");\n verboseLog(`Deleting ${resourceType}: ${change.name}`);\n\n if (resourceType === \"tag\" && change.change?.before?.tagId) {\n const deleteResult = await this.clients.gtm.deleteTag(\n change.change.before.tagId\n );\n\n if (options.verbose) {\n console.log(chalk.blue(`Delete API response:`));\n console.log(JSON.stringify(deleteResult, null, 2));\n }\n\n if (deleteResult.success) {\n console.log(\n chalk.red(\n `- Removed tag: ${change.change.before.name || change.name}`\n )\n );\n verboseLog(`Successfully deleted tag`, {\n id: change.change.before.tagId,\n });\n } else {\n // Fail fast on delete errors\n console.error(\n chalk.red(\n `[ERROR] Failed to delete tag \"${\n change.change.before.name || change.name\n }\" (ID: ${change.change.before.tagId}): ${\n deleteResult.error\n }`\n )\n );\n throw new Error(`Tag deletion failed: ${deleteResult.error}`);\n }\n } else if (\n resourceType === \"trigger\" &&\n change.change?.before?.triggerId\n ) {\n const deleteResult = await this.clients.gtm.deleteTrigger(\n change.change.before.triggerId\n );\n\n if (options.verbose) {\n console.log(chalk.blue(`Delete API response:`));\n console.log(JSON.stringify(deleteResult, null, 2));\n }\n\n if (deleteResult.success) {\n console.log(\n chalk.red(\n `- Removed trigger: ${\n change.change.before.name || change.name\n }`\n )\n );\n verboseLog(`Successfully deleted trigger`, {\n id: change.change.before.triggerId,\n });\n } else {\n // Fail fast on delete errors\n console.error(\n chalk.red(\n `[ERROR] Failed to delete trigger \"${\n change.change.before.name || change.name\n }\" (ID: ${change.change.before.triggerId}): ${\n deleteResult.error\n }`\n )\n );\n throw new Error(\n `Trigger deletion failed: ${deleteResult.error}`\n );\n }\n } else if (\n resourceType === \"variable\" &&\n change.change?.before?.variableId\n ) {\n const deleteResult = await this.clients.gtm.deleteVariable(\n change.change.before.variableId\n );\n\n if (options.verbose) {\n console.log(chalk.blue(`Delete API response:`));\n console.log(JSON.stringify(deleteResult, null, 2));\n }\n\n if (deleteResult.success) {\n console.log(\n chalk.red(\n `- Removed variable: ${\n change.change.before.name || change.name\n }`\n )\n );\n verboseLog(`Successfully deleted variable`, {\n id: change.change.before.variableId,\n });\n } else {\n // Fail fast on delete errors\n console.error(\n chalk.red(\n `[ERROR] Failed to delete variable \"${\n change.change.before.name || change.name\n }\" (ID: ${change.change.before.variableId}): ${\n deleteResult.error\n }`\n )\n );\n throw new Error(\n `Variable deletion failed: ${deleteResult.error}`\n );\n }\n }\n\n if (options.verbose) {\n console.log(chalk.magenta(`=== END VERBOSE DELETE ===\\n`));\n }\n } catch (error) {\n // Log the error and fail fast\n console.error(\n chalk.red(\n `Failed to delete ${change.type} ${change.name}: ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n );\n\n if (options.verbose) {\n console.log(\n chalk.red(\n `Error Stack: ${error instanceof Error ? error.stack : \"N/A\"}`\n )\n );\n }\n\n spinner.fail(\"Apply failed during deletion phase\");\n throw error;\n }\n }\n verboseLog(`Completed deletion of ${deleteChanges.length} resources`);\n }\n\n // Execute creates (add new resources) using batch processing\n if (createChanges.length > 0) {\n spinner.text = `Creating ${createChanges.length} new resources in batches...`;\n\n // Group changes by resource type for better batch processing\n const variableChanges = createChanges.filter(\n (c) => c.type === \"gtm_variable\"\n );\n const triggerChanges = createChanges.filter(\n (c) => c.type === \"gtm_trigger\"\n );\n const tagChanges = createChanges.filter((c) => c.type === \"gtm_tag\");\n\n // Process variables first (they're often used by other resources)\n if (variableChanges.length > 0) {\n const variableOps = variableChanges.map((change) => ({\n fn: async () => {\n if (!change.change?.after) return null;\n const variableConfig =\n this.transformVariableConfigWithWorkingTransformer(\n change.change.after\n );\n const result = await this.clients.gtm.createVariable(\n variableConfig\n );\n if (result.success) {\n console.log(\n chalk.green(\n `+ Created variable: ${\n change.change.after.name || change.name\n }`\n )\n );\n } else {\n // Fail fast if enabled\n const error = new Error(\n `Failed to create variable \"${\n change.change.after.name || change.name\n }\": ${result.error}`\n );\n console.error(\n chalk.red(\n `[ERROR] Failed to create variable \"${\n change.change.after.name || change.name\n }\" { error: '${result.error}' }`\n )\n );\n throw error;\n }\n return result;\n },\n context: `variable ${change.name}`,\n }));\n\n spinner.text = `Creating ${variableChanges.length} variables...`;\n await this.clients.gtm.rateLimiter.executeBatch(variableOps, 3); // Smaller batches for variables\n }\n\n // Process triggers second (they're used by tags)\n if (triggerChanges.length > 0) {\n const triggerOps = triggerChanges.map((change) => ({\n fn: async () => {\n if (!change.change?.after) return null;\n const triggerConfig = this.transformTriggerConfig(\n change.change.after\n );\n const result = await this.clients.gtm.createTrigger(\n triggerConfig\n );\n if (result.success) {\n console.log(\n chalk.green(\n `+ Created trigger: ${\n change.change.after.name || change.name\n }`\n )\n );\n } else {\n // Fail fast if enabled\n const error = new Error(\n `Failed to create trigger \"${\n change.change.after.name || change.name\n }\": ${result.error}`\n );\n console.error(\n chalk.red(\n `[ERROR] Failed to create trigger \"${\n change.change.after.name || change.name\n }\" { error: '${result.error}' }`\n )\n );\n throw error;\n }\n return result;\n },\n context: `trigger ${change.name}`,\n }));\n\n spinner.text = `Creating ${triggerChanges.length} triggers...`;\n await this.clients.gtm.rateLimiter.executeBatch(triggerOps, 4); // Medium batches for triggers\n }\n\n // Process tags last (they depend on variables and triggers)\n if (tagChanges.length > 0) {\n const tagOps = tagChanges.map((change) => ({\n fn: async () => {\n if (!change.change?.after) return null;\n const tagConfig = this.transformTagConfig(change.change.after);\n\n // Resolve trigger names to IDs if needed\n if (tagConfig.firingTriggerName) {\n const triggerIds = await this.resolveTriggerNames(\n tagConfig.firingTriggerName\n );\n tagConfig.firingTriggerId = triggerIds;\n delete tagConfig.firingTriggerName;\n }\n\n const result = await this.clients.gtm.createTag(tagConfig);\n if (result.success) {\n console.log(\n chalk.green(\n `+ Created tag: ${change.change.after.name || change.name}`\n )\n );\n } else {\n // Fail fast if enabled\n const error = new Error(\n `Failed to create tag \"${\n change.change.after.name || change.name\n }\": ${result.error}`\n );\n console.error(\n chalk.red(\n `[ERROR] Failed to create tag \"${\n change.change.after.name || change.name\n }\" { error: '${result.error}' }`\n )\n );\n throw error;\n }\n return result;\n },\n context: `tag ${change.name}`,\n }));\n\n spinner.text = `Creating ${tagChanges.length} tags...`;\n await this.clients.gtm.rateLimiter.executeBatch(tagOps, 3); // Smaller batches for tags\n }\n }\n\n // Execute updates using the enhanced executeUpdate function\n if (updateChanges.length > 0) {\n spinner.text = `Updating ${updateChanges.length} resources...`;\n verboseLog(`Processing ${updateChanges.length} update operations`);\n\n const updateResults = {\n updated: 0,\n errors: [] as string[],\n };\n\n for (const change of updateChanges) {\n verboseLog(\n `Processing update for ${change.address} (${change.name})`\n );\n await this.smartDelay(); // GTM API rate limiting\n\n // Use the enhanced executeUpdate function with verbose logging\n await this.executeUpdate(change, updateResults, options.verbose);\n }\n\n // Report any errors from the update process\n if (updateResults.errors.length > 0) {\n console.error(chalk.red(`\\n❌ Update errors occurred:`));\n updateResults.errors.forEach((error) => {\n console.error(chalk.red(` • ${error}`));\n });\n throw new Error(\n `Failed to update ${updateResults.errors.length} resources`\n );\n }\n\n verboseLog(`Successfully updated ${updateResults.updated} resources`);\n }\n\n // Update state file\n spinner.text = \"Updating state file...\";\n const newState = {\n ...currentState,\n serial: currentState.serial + 1,\n resources: plan.final_state || currentState.resources,\n };\n await stateManager.save(newState);\n\n spinner.stop();\n console.log(chalk.green(\"\\n✅ GTM configuration applied successfully!\"));\n console.log(chalk.blue(\"\\n📋 Summary:\"));\n console.log(chalk.blue(` Resources removed: ${deleteChanges.length}`));\n console.log(chalk.blue(` Resources created: ${createChanges.length}`));\n console.log(chalk.blue(` Resources updated: ${updateChanges.length}`));\n console.log(chalk.yellow(\"\\n🚀 Next steps:\"));\n console.log(\n chalk.yellow(\" 1. Test the configuration in GTM Preview mode\")\n );\n console.log(\n chalk.yellow(\" 2. Use GTM UI to publish workspace to production\")\n );\n } catch (error) {\n spinner.fail(\"Apply failed\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n /**\n * Enhanced incremental sync with validation and proper error handling\n */\n async gtmIncrementalSync(options: {\n config: string;\n dryRun?: boolean;\n }): Promise<void> {\n const spinner = ora(\"Starting incremental GTM sync...\").start();\n const results = {\n validated: 0,\n created: 0,\n updated: 0,\n deleted: 0,\n errors: [] as string[],\n warnings: [] as string[],\n };\n\n try {\n // 1. Load and validate configuration\n spinner.text = \"Loading and validating configuration...\";\n const configParser = new ConfigParser();\n let config = await configParser.loadConfig(options.config);\n\n // Resolve variable references in the config\n config = configParser.resolveVariables(config);\n\n const validation = configParser.validateConfig(config);\n if (!validation.valid) {\n throw new Error(\n `Configuration validation failed:\\n${validation.errors.join(\"\\n\")}`\n );\n }\n results.validated = validation.errors.length === 0 ? 1 : 0;\n\n // 2. Setup GTM client with authentication\n if (!this.clients.gtm) {\n const gtmConfig = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config: gtmConfig });\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`GTM authentication failed: ${authResult.error}`);\n }\n\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(\n `Workspace selection failed: ${workspaceResult.error}`\n );\n }\n }\n\n // 3. Generate incremental plan\n spinner.text = \"Analyzing changes and generating plan...\";\n const planner = new Planner(this.clients.gtm, configParser);\n const stateManager = new StateManager();\n\n let currentState = await stateManager.load();\n if (!currentState) {\n // Initialize empty state if none exists\n currentState = {\n version: \"1.0.0\",\n terraform_version: \"0.1.0\",\n serial: 0,\n lineage: crypto.randomUUID(),\n outputs: {},\n resources: [],\n check_results: [],\n };\n }\n\n const planResult = await planner.plan(config, currentState);\n if (!planResult.success) {\n throw new Error(`Plan generation failed: ${planResult.error}`);\n }\n\n const plan = planResult.data!;\n console.log(chalk.blue(\"\\n📋 Planned Changes:\"));\n console.log(planner.formatPlan(plan));\n\n if (plan.changes.length === 0) {\n spinner.succeed(\"No changes needed - configuration is up to date\");\n return;\n }\n\n if (options.dryRun) {\n spinner.succeed(\n `Dry run completed - ${plan.changes.length} changes planned`\n );\n return;\n }\n\n // 4. Execute changes incrementally with rate limiting\n spinner.text = \"Applying changes incrementally...\";\n // GTM API limit: 0.25 QPS = 1 request every 4 seconds\n // Use 5 seconds to be safe: 5000ms between API calls\n const delayMs = 5000;\n\n // Group changes by operation type\n const creates = plan.changes.filter((c) =>\n c.change.actions.includes(\"create\")\n );\n const updates = plan.changes.filter((c) =>\n c.change.actions.includes(\"update\")\n );\n const deletes = plan.changes.filter((c) =>\n c.change.actions.includes(\"delete\")\n );\n\n // Execute deletions first (cleanup)\n for (const change of deletes) {\n await this.smartDelay(); // Intelligent rate limiting\n await this.executeDelete(change, results);\n }\n\n // Then execute creates\n for (const change of creates) {\n await this.smartDelay(); // Intelligent rate limiting\n await this.executeCreate(change, results);\n }\n\n // Finally execute updates\n for (const change of updates) {\n await this.smartDelay(); // Intelligent rate limiting\n await this.executeUpdate(change, results);\n }\n\n // 5. Update state with successful changes\n spinner.text = \"Updating state file...\";\n const newState = {\n ...currentState,\n serial: currentState.serial + 1,\n resources:\n plan.planned_values?.root_module?.resources?.map((r) => ({\n mode: \"managed\" as const,\n type: r.type,\n name: r.name,\n provider: 'provider[\"gtm\"]',\n instances: [\n {\n schema_version: 1,\n attributes: r.values,\n sensitive_attributes: [],\n private: \"\",\n dependencies: [],\n },\n ],\n })) || currentState.resources,\n };\n await stateManager.save(newState);\n\n // 6. Report results\n spinner.succeed(\"Incremental sync completed successfully\");\n console.log(chalk.green(\"\\n✅ Sync Results:\"));\n console.log(\n chalk.blue(\n ` Configuration validated: ${results.validated ? \"Yes\" : \"No\"}`\n )\n );\n console.log(chalk.blue(` Resources created: ${results.created}`));\n console.log(chalk.blue(` Resources updated: ${results.updated}`));\n console.log(chalk.blue(` Resources deleted: ${results.deleted}`));\n\n if (results.warnings.length > 0) {\n console.log(chalk.yellow(` Warnings: ${results.warnings.length}`));\n results.warnings.forEach((w) =>\n console.log(chalk.yellow(` - ${w}`))\n );\n }\n\n if (results.errors.length > 0) {\n console.log(chalk.red(` Errors: ${results.errors.length}`));\n results.errors.forEach((e) => console.log(chalk.red(` - ${e}`)));\n }\n } catch (error) {\n spinner.fail(\"Incremental sync failed\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n throw error;\n }\n }\n\n private async executeDelete(change: any, results: any): Promise<void> {\n try {\n const resourceType = change.type.replace(\"gtm_\", \"\");\n const resourceData = change.change.before;\n\n let deleteResult: any;\n switch (resourceType) {\n case \"tag\":\n deleteResult = await this.clients.gtm.deleteTag(resourceData.tagId);\n break;\n case \"trigger\":\n deleteResult = await this.clients.gtm.deleteTrigger(\n resourceData.triggerId\n );\n break;\n case \"variable\":\n deleteResult = await this.clients.gtm.deleteVariable(\n resourceData.variableId\n );\n break;\n }\n\n if (deleteResult?.success) {\n results.deleted++;\n console.log(\n chalk.red(`- Deleted ${resourceType}: ${resourceData.name}`)\n );\n } else {\n results.errors.push(\n `Failed to delete ${resourceType}: ${resourceData.name}`\n );\n }\n } catch (error) {\n results.errors.push(\n `Delete error: ${\n error instanceof Error ? error.message : String(error)\n }`\n );\n }\n }\n\n private async executeCreate(change: any, results: any): Promise<void> {\n try {\n const resourceType = change.type.replace(\"gtm_\", \"\");\n const resourceData = change.change.after;\n\n // Transform YAML config to GTM API format\n const transformedData = this.transformResourceForGTM(\n resourceType,\n resourceData\n );\n\n let createResult: any;\n switch (resourceType) {\n case \"tag\":\n createResult = await this.clients.gtm.createTag(transformedData);\n break;\n case \"trigger\":\n createResult = await this.clients.gtm.createTrigger(transformedData);\n break;\n case \"variable\":\n createResult = await this.clients.gtm.createVariable(transformedData);\n break;\n }\n\n if (createResult?.success) {\n results.created++;\n console.log(\n chalk.green(`+ Created ${resourceType}: ${resourceData.name}`)\n );\n } else {\n results.errors.push(\n `Failed to create ${resourceType}: ${resourceData.name}`\n );\n }\n } catch (error) {\n results.errors.push(\n `Create error: ${\n error instanceof Error ? error.message : String(error)\n }`\n );\n }\n }\n\n private async executeUpdate(\n change: any,\n results: any,\n verbose: boolean = false\n ): Promise<void> {\n try {\n const resourceType = change.type.replace(\"gtm_\", \"\");\n const beforeData = change.change.before;\n const afterData = change.change.after;\n\n // Check if resource has a valid ID - if not, it needs to be created not updated\n const resourceId =\n beforeData?.tagId || beforeData?.triggerId || beforeData?.variableId;\n if (!resourceId || resourceId === \"undefined\") {\n console.log(\n chalk.yellow(\n `[WARN] Resource \"${afterData.name}\" has no ID - treating as create instead of update`\n )\n );\n\n // Transform to a create operation\n let createResult: any;\n switch (resourceType) {\n case \"tag\":\n const tagConfig = this.transformTagConfig(afterData);\n createResult = await this.clients.gtm.createTag(tagConfig);\n break;\n case \"trigger\":\n const triggerConfig = this.transformTriggerConfig(afterData);\n createResult = await this.clients.gtm.createTrigger(triggerConfig);\n break;\n case \"variable\":\n createResult = await this.clients.gtm.createVariable(afterData);\n break;\n default:\n throw new Error(`Unknown resource type: ${resourceType}`);\n }\n\n if (createResult.success) {\n console.log(\n chalk.green(`+ Created ${resourceType}: ${afterData.name}`)\n );\n results.created = (results.created || 0) + 1;\n } else {\n console.log(\n chalk.red(\n `[ERROR] Failed to create ${resourceType}: ${afterData.name}`\n ),\n createResult.error\n );\n results.errors.push(\n `Failed to create ${resourceType}: ${afterData.name} - ${createResult.error}`\n );\n }\n return;\n }\n\n if (verbose) {\n console.log(\n chalk.magenta(\n `\\n=== VERBOSE UPDATE: ${resourceType.toUpperCase()} ===`\n )\n );\n console.log(\n chalk.cyan(`Resource Name: ${afterData.name || beforeData.name}`)\n );\n console.log(\n chalk.cyan(\n `Resource ID: ${\n beforeData.tagId || beforeData.triggerId || beforeData.variableId\n }`\n )\n );\n console.log(chalk.yellow(`Before state:`));\n console.log(JSON.stringify(beforeData, null, 2));\n console.log(chalk.green(`After state (config):`));\n console.log(JSON.stringify(afterData, null, 2));\n }\n\n let updateResult: any;\n let transformedConfig: any;\n\n switch (resourceType) {\n case \"tag\": {\n // Transform the tag config and resolve triggers\n transformedConfig = this.transformTagConfig(afterData);\n\n if (verbose) {\n console.log(chalk.blue(`Transformed config for GTM API:`));\n console.log(JSON.stringify(transformedConfig, null, 2));\n }\n\n // CRITICAL: Preserve existing trigger associations\n // If current tag has no firingTriggerId but config specifies triggers, add them\n // If current tag has firingTriggerId, merge with config (don't replace)\n if (\n transformedConfig.firingTriggerName &&\n Array.isArray(transformedConfig.firingTriggerName)\n ) {\n console.log(\n chalk.cyan(\n `[INFO] Adding missing triggers to tag: ${afterData.name}`\n )\n );\n console.log(\n chalk.cyan(\n `[INFO] Triggers to add: ${transformedConfig.firingTriggerName.join(\n \", \"\n )}`\n )\n );\n\n const triggerIds = await this.resolveTriggerNames(\n transformedConfig.firingTriggerName\n );\n if (triggerIds.length > 0) {\n // Preserve existing triggers if they exist\n const existingTriggers = beforeData.firingTriggerId || [];\n const allTriggers = [\n ...new Set([...existingTriggers, ...triggerIds]),\n ];\n\n transformedConfig.firingTriggerId = allTriggers;\n delete transformedConfig.firingTriggerName;\n\n console.log(\n chalk.green(\n `[INFO] Final trigger IDs: ${allTriggers.join(\", \")}`\n )\n );\n\n if (verbose) {\n console.log(chalk.magenta(`Trigger resolution details:`));\n console.log(\n chalk.cyan(\n ` Original trigger names: ${\n transformedConfig.firingTriggerName || \"none\"\n }`\n )\n );\n console.log(\n chalk.cyan(` Resolved trigger IDs: ${triggerIds.join(\", \")}`)\n );\n console.log(\n chalk.cyan(\n ` Existing trigger IDs: ${existingTriggers.join(\", \")}`\n )\n );\n console.log(\n chalk.cyan(` Merged trigger IDs: ${allTriggers.join(\", \")}`)\n );\n }\n } else {\n console.log(\n chalk.yellow(\n `[WARN] Could not resolve any trigger names for ${afterData.name}`\n )\n );\n // Don't update if we can't resolve triggers - preserve current state\n delete transformedConfig.firingTriggerName;\n }\n }\n\n // Apply filtering to match GTM update patterns\n const filteredConfig = this.filterTagUpdateFields(transformedConfig);\n\n if (verbose) {\n console.log(chalk.blue(`Final filtered config sent to GTM:`));\n console.log(JSON.stringify(filteredConfig, null, 2));\n }\n\n updateResult = await this.clients.gtm.updateTag(\n beforeData.tagId,\n filteredConfig\n );\n break;\n }\n case \"trigger\": {\n // Apply filtering to match GTM update patterns\n transformedConfig = this.filterTriggerUpdateFields(afterData);\n\n if (verbose) {\n console.log(chalk.blue(`Filtered trigger config sent to GTM:`));\n console.log(JSON.stringify(transformedConfig, null, 2));\n }\n\n updateResult = await this.clients.gtm.updateTrigger(\n beforeData.triggerId,\n transformedConfig\n );\n break;\n }\n case \"variable\": {\n // Apply filtering to match GTM update patterns\n transformedConfig = this.filterVariableUpdateFields(afterData);\n\n if (verbose) {\n console.log(chalk.blue(`Filtered variable config sent to GTM:`));\n console.log(JSON.stringify(transformedConfig, null, 2));\n }\n\n updateResult = await this.clients.gtm.updateVariable(\n beforeData.variableId,\n transformedConfig\n );\n break;\n }\n }\n\n if (verbose && updateResult) {\n console.log(chalk.magenta(`GTM API Response:`));\n console.log(JSON.stringify(updateResult, null, 2));\n console.log(chalk.magenta(`=== END VERBOSE UPDATE ===\\n`));\n }\n\n if (updateResult?.success) {\n results.updated++;\n console.log(chalk.blue(`~ Updated ${resourceType}: ${afterData.name}`));\n } else {\n results.errors.push(\n `Failed to update ${resourceType}: ${afterData.name}`\n );\n console.log(\n chalk.red(\n `[ERROR] Failed to update ${resourceType}: ${afterData.name}`\n )\n );\n if (verbose && updateResult?.error) {\n console.log(chalk.red(`API Error Details: ${updateResult.error}`));\n }\n }\n } catch (error) {\n results.errors.push(\n `Update error: ${\n error instanceof Error ? error.message : String(error)\n }`\n );\n console.log(\n chalk.red(\n `[ERROR] Update error: ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n );\n\n if (verbose) {\n console.log(\n chalk.red(\n `Error Stack: ${error instanceof Error ? error.stack : \"N/A\"}`\n )\n );\n }\n }\n }\n\n /**\n * Fix variable references in all GTM tags\n * Updates tags with incorrect variable references to use the correct GTM variable names\n */\n async gtmFixVariableReferences(\n options: { dryRun?: boolean } = {}\n ): Promise<void> {\n const spinner = ora(\"Fixing variable references in GTM tags...\").start();\n\n try {\n // Initialize GTM client\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(\n `Failed to select workspace: ${workspaceResult.error}`\n );\n }\n }\n\n // Get all tags\n spinner.text = \"Fetching tags from GTM...\";\n const tagsResult = await this.clients.gtm.listTags();\n if (!tagsResult.success || !tagsResult.data) {\n throw new Error(\"Failed to fetch tags\");\n }\n\n // Find tags that need fixing\n const tagsToFix: Array<{\n tag: any;\n fixes: Array<{ param: any; oldValue: string; newValue: string }>;\n }> = [];\n\n for (const tag of tagsResult.data) {\n const fixes: Array<{ param: any; oldValue: string; newValue: string }> =\n [];\n\n // Check each parameter for variable references that need fixing\n if (tag.parameter && Array.isArray(tag.parameter)) {\n for (const param of tag.parameter) {\n if (param.value && typeof param.value === \"string\") {\n const newValue = this.resolveVariableReferences(param.value);\n if (newValue !== param.value) {\n fixes.push({ param, oldValue: param.value, newValue });\n }\n }\n }\n }\n\n if (fixes.length > 0) {\n tagsToFix.push({ tag, fixes });\n }\n }\n\n if (tagsToFix.length === 0) {\n spinner.succeed(\"No tags need variable reference fixes\");\n return;\n }\n\n // Display what will be fixed\n spinner.stop();\n console.log(\n chalk.cyan(\n `\\n📋 Found ${tagsToFix.length} tags with incorrect variable references:\\n`\n )\n );\n\n for (const { tag, fixes } of tagsToFix) {\n console.log(chalk.yellow(`\\n🏷️ ${tag.name} (ID: ${tag.tagId})`));\n for (const { param, oldValue, newValue } of fixes) {\n console.log(` ${chalk.red(\"- \" + param.key + \": \" + oldValue)}`);\n console.log(` ${chalk.green(\"+ \" + param.key + \": \" + newValue)}`);\n }\n }\n\n if (options.dryRun) {\n console.log(chalk.blue(\"\\n✨ Dry run mode - no changes were made\"));\n return;\n }\n\n // Apply fixes\n console.log(chalk.cyan(\"\\n🔧 Applying fixes...\\n\"));\n const updateSpinner = ora(\"Updating tags...\").start();\n\n let successCount = 0;\n let failCount = 0;\n\n for (const { tag, fixes } of tagsToFix) {\n try {\n // Create updated parameters array\n const updatedParameters = tag.parameter.map((param: any) => {\n const fix = fixes.find((f) => f.param === param);\n if (fix) {\n return { ...param, value: fix.newValue };\n }\n return param;\n });\n\n // Update the tag\n updateSpinner.text = `Updating ${tag.name}...`;\n const updateResult = await this.clients.gtm.updateTag(tag.tagId, {\n parameter: updatedParameters,\n });\n\n if (updateResult.success) {\n successCount++;\n console.log(chalk.green(`✅ Fixed: ${tag.name}`));\n } else {\n failCount++;\n console.log(\n chalk.red(`❌ Failed to fix ${tag.name}: ${updateResult.error}`)\n );\n }\n } catch (error) {\n failCount++;\n console.log(\n chalk.red(\n `❌ Error fixing ${tag.name}: ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n );\n }\n }\n\n updateSpinner.stop();\n\n // Summary\n console.log(chalk.cyan(\"\\n📊 Summary:\"));\n console.log(chalk.green(` ✅ Successfully fixed: ${successCount} tags`));\n if (failCount > 0) {\n console.log(chalk.red(` ❌ Failed: ${failCount} tags`));\n }\n\n if (successCount > 0) {\n console.log(\n chalk.yellow(\n \"\\n⚠️ Remember to publish the workspace to apply changes to production\"\n )\n );\n }\n } catch (error) {\n spinner.fail(\"Failed to fix variable references\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n private currentConfig: any = null;\n\n private getConfigVariables(): any {\n if (!this.currentConfig) {\n console.warn(\"No current config loaded for variable resolution\");\n return {};\n }\n\n const vars = this.currentConfig?.variables || {};\n console.log(\"Available config variables:\", Object.keys(vars));\n return vars;\n }\n\n /**\n * Resolve variable references in tag parameter values\n * Maps old variable references to new GTM variable names\n */\n private resolveVariableReferences(value: string): string {\n if (typeof value !== \"string\") return value;\n\n // Define variable reference mappings\n const variableMap: Record<string, string> = {\n \"{{ecommerce.value}}\": \"{{Ecommerce Value}}\",\n \"{{lead_score}}\": \"{{Lead Score}}\",\n \"{{google_ads_id}}\": \"{{Google Ads ID}}\",\n \"AW-{{google_ads_id}}\": \"AW-{{Google Ads ID}}\",\n // Add more mappings as needed\n };\n\n let resolvedValue = value;\n\n // First handle ${var.variable} syntax - resolve from YAML variables\n // This handles config variables like ${var.google_ads_id}, ${var.conversion_labels.form_submission}\n resolvedValue = resolvedValue.replace(\n /\\$\\{var\\.([^}]+)\\}/g,\n (match, varPath) => {\n console.log(\n `Attempting to resolve variable: ${match} (path: ${varPath})`\n );\n\n // Handle nested variable references like var.conversion_labels.form_submission\n const pathParts = varPath.split(\".\");\n let currentValue: any = this.getConfigVariables();\n\n console.log(`Starting resolution with:`, currentValue);\n\n for (const part of pathParts) {\n console.log(`Looking for part: ${part} in:`, currentValue);\n if (\n currentValue &&\n typeof currentValue === \"object\" &&\n part in currentValue\n ) {\n currentValue = currentValue[part];\n console.log(`Found value: ${currentValue}`);\n } else {\n // Variable not found, return original match\n console.warn(\n `Variable not found: ${match} (missing part: ${part})`\n );\n return match;\n }\n }\n\n const result = String(currentValue);\n console.log(`Resolved ${match} to: ${result}`);\n return result;\n }\n );\n\n // Then handle {{variable}} GTM variable references\n for (const [oldRef, newRef] of Object.entries(variableMap)) {\n resolvedValue = resolvedValue.replace(\n new RegExp(oldRef.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\"), \"g\"),\n newRef\n );\n }\n\n return resolvedValue;\n }\n\n /**\n * Normalize parameter list structures for GTM API (convert lowercase types to uppercase)\n */\n private normalizeParameterList(list: any[]): any[] {\n return list.map((item: any) => ({\n ...item,\n type: item.type?.toUpperCase() || \"TEMPLATE\",\n ...(item.map && { map: this.normalizeParameterMap(item.map) }),\n ...(item.list && { list: this.normalizeParameterList(item.list) }),\n }));\n }\n\n /**\n * Normalize parameter map structures for GTM API (convert lowercase types to uppercase)\n */\n private normalizeParameterMap(map: any[]): any[] {\n return map.map((item: any) => ({\n ...item,\n type: item.type?.toUpperCase() || \"TEMPLATE\",\n ...(item.map && { map: this.normalizeParameterMap(item.map) }),\n ...(item.list && { list: this.normalizeParameterList(item.list) }),\n }));\n }\n\n /**\n * Process GA4 event tag parameters to ensure they match GTM API expectations\n * For gaawe tags, converts tagId to measurementIdOverride and properly structures eventParameters\n */\n private processGA4EventParameters(parameters: any[]): any[] {\n return parameters.map((param: any) => {\n // For gaawe (GA4 Event) tags, the API expects 'measurementIdOverride'\n // Handle both 'tagId' and 'measurementId' fields from YAML\n if (param.key === \"tagId\" || param.key === \"measurementId\") {\n return {\n ...param,\n key: \"measurementIdOverride\",\n type: \"TEMPLATE\", // GA4 event tags use TEMPLATE type for measurementIdOverride\n };\n }\n\n // Convert eventParameters to eventSettingsTable format for GA4 event tags\n if (param.key === \"eventParameters\" && param.list) {\n const eventSettingsList = param.list.map((item: any) => {\n if (item.type === \"map\" && item.map) {\n const nameField = item.map.find(\n (field: any) => field.key === \"name\"\n );\n const valueField = item.map.find(\n (field: any) => field.key === \"value\"\n );\n\n if (nameField && valueField) {\n // Debug logging to see what we're converting\n console.log(\n `[DEBUG] Converting eventParameters: ${nameField.value} -> ${valueField.value}`\n );\n return {\n type: \"map\",\n map: [\n {\n key: \"parameter\",\n type: \"TEMPLATE\",\n value: nameField.value,\n },\n {\n key: \"parameterValue\",\n type: \"TEMPLATE\",\n value: valueField.value,\n },\n ],\n };\n }\n }\n return item;\n });\n\n return {\n key: \"eventSettingsTable\",\n type: \"LIST\",\n list: eventSettingsList,\n };\n }\n\n return param;\n });\n }\n\n /**\n * Process Google Ads conversion tag parameters to ensure they match GTM API expectations\n * Properly structures enhancedConversionData and ensures correct parameter types\n */\n private processGoogleAdsParameters(parameters: any[]): any[] {\n console.log(\n `[DEBUG] Processing Google Ads parameters:`,\n JSON.stringify(parameters, null, 2)\n );\n\n return parameters.map((param: any) => {\n // Handle enhancedConversionData special structure (similar to GA4 eventParameters)\n if (param.key === \"enhancedConversionData\" && param.list) {\n console.log(\n `[DEBUG] Processing enhancedConversionData with ${param.list.length} items`\n );\n return {\n ...param,\n type: \"LIST\",\n list: this.normalizeParameterList(param.list), // Use the recursive normalizer\n };\n }\n\n // Handle eventParameters for Google Ads tags (similar structure to GA4)\n if (param.key === \"eventParameters\" && param.list) {\n console.log(\n `[DEBUG] Processing Google Ads eventParameters with ${param.list.length} items`\n );\n return {\n ...param,\n type: \"LIST\",\n list: this.normalizeParameterList(param.list), // Use the recursive normalizer\n };\n }\n\n // Ensure boolean parameters have correct type\n if (\n param.key === \"enableEnhancedConversions\" ||\n param.key === \"enableNewCustomerReporting\"\n ) {\n console.log(`[DEBUG] Processing boolean parameter: ${param.key}`);\n return {\n ...param,\n type: \"BOOLEAN\",\n };\n }\n\n return param;\n });\n }\n\n /**\n * Transform tag config from YAML format to GTM API format\n */\n private transformTagConfig(yamlConfig: any): any {\n // Check if already in GTM API format (has parameter array)\n if (yamlConfig.parameter && Array.isArray(yamlConfig.parameter)) {\n // Already transformed, but resolve variable references and normalize types\n // Important: Preserve GTM's expected parameter order (type first, then key)\n const resolvedParameters = yamlConfig.parameter.map((param: any) => ({\n type: param.type?.toUpperCase() || \"TEMPLATE\", // GTM API expects uppercase types\n key: param.key,\n value: this.resolveVariableReferences(param.value),\n // Include other fields if present, recursively processing nested structures\n ...(param.list && { list: this.normalizeParameterList(param.list) }),\n ...(param.map && { map: this.normalizeParameterMap(param.map) }),\n }));\n\n // Special processing for GA4 event tags (googtag or gaawe with eventName)\n let processedParameters = resolvedParameters;\n if (\n (yamlConfig.type === \"googtag\" || yamlConfig.type === \"gaawe\") &&\n resolvedParameters.some((p: any) => p.key === \"eventName\")\n ) {\n processedParameters =\n this.processGA4EventParameters(resolvedParameters);\n }\n\n // Special processing for Google Ads conversion tags (awct with enhancedConversionData)\n if (\n yamlConfig.type === \"awct\" &&\n resolvedParameters.some((p: any) => p.key === \"enhancedConversionData\")\n ) {\n processedParameters =\n this.processGoogleAdsParameters(processedParameters);\n }\n\n const transformed: any = {\n name: yamlConfig.name,\n type: this.mapTagType(yamlConfig.type, yamlConfig), // Pass yamlConfig for auto-correction\n parameter: processedParameters, // GTM API expects 'parameter' (singular)\n };\n\n // Also extract common parameters for client methods (use processed parameters)\n for (const param of processedParameters) {\n if (param.key === \"html\") {\n transformed.html = param.value;\n } else if (param.key === \"tagId\" || param.key === \"measurementId\") {\n // GA4 Configuration uses tagId in YAML but measurementId in API\n transformed.measurementId = param.value;\n } else if (param.key === \"conversionId\") {\n transformed.conversionId = param.value;\n } else if (param.key === \"conversionLabel\") {\n transformed.conversionLabel = param.value;\n } else if (param.key === \"eventName\") {\n // Extract eventName for GA4 event tags\n transformed.eventName = param.value;\n }\n }\n\n // Handle trigger references from various fields\n // CRITICAL FIX: Keep firingTriggerId for proper trigger name resolution\n if (\n yamlConfig.firingTriggerId &&\n Array.isArray(yamlConfig.firingTriggerId)\n ) {\n // These are trigger names that need to be resolved to IDs by the client\n transformed.firingTriggerId = yamlConfig.firingTriggerId;\n } else if (\n yamlConfig.firing_triggers &&\n Array.isArray(yamlConfig.firing_triggers)\n ) {\n transformed.firingTriggerId = yamlConfig.firing_triggers;\n } else if (yamlConfig.triggers && Array.isArray(yamlConfig.triggers)) {\n transformed.firingTriggerId = yamlConfig.triggers;\n }\n\n // Add description if present\n if (yamlConfig.description) {\n transformed.notes = yamlConfig.description;\n }\n\n return transformed;\n }\n\n // Handle YAML format with parameters object\n const transformed: any = {\n name: yamlConfig.name,\n type: this.mapTagType(yamlConfig.type, yamlConfig), // Pass yamlConfig for auto-correction\n };\n\n // Handle tag parameters - special handling for GA4 tags\n if (yamlConfig.parameters) {\n transformed.parameter = [];\n\n // Special handling for GA4 tags\n if (yamlConfig.type === \"gaawc\") {\n // GA4 Configuration Tag\n if (yamlConfig.parameters.measurementId) {\n const resolvedMeasurementId = this.resolveVariableReferences(\n yamlConfig.parameters.measurementId\n );\n transformed.parameter.push({\n type: \"template\",\n key: \"measurementId\",\n value: resolvedMeasurementId,\n });\n transformed.measurementId = resolvedMeasurementId;\n }\n\n if (yamlConfig.parameters.sendPageView !== undefined) {\n transformed.parameter.push({\n type: \"boolean\",\n key: \"sendPageView\",\n value: String(yamlConfig.parameters.sendPageView),\n });\n }\n } else if (yamlConfig.type === \"gaawe\") {\n // GA4 Event Tag\n if (yamlConfig.parameters.measurementId) {\n transformed.parameter.push({\n type: \"template\",\n key: \"measurementIdOverride\",\n value: yamlConfig.parameters.measurementId,\n });\n transformed.measurementId = yamlConfig.parameters.measurementId;\n }\n\n if (yamlConfig.parameters.eventName) {\n transformed.parameter.push({\n type: \"template\",\n key: \"eventName\",\n value: yamlConfig.parameters.eventName,\n });\n transformed.eventName = yamlConfig.parameters.eventName;\n }\n\n if (yamlConfig.parameters.eventParameters) {\n transformed.parameter.push({\n type: \"list\",\n key: \"eventSettingsTable\",\n value: yamlConfig.parameters.eventParameters,\n });\n }\n } else if (yamlConfig.type === \"html\") {\n // HTML tags need special handling\n if (yamlConfig.parameters.html) {\n const resolvedHtml = this.resolveVariableReferences(\n yamlConfig.parameters.html\n );\n transformed.parameter.push({\n type: \"template\",\n key: \"html\",\n value: resolvedHtml,\n });\n transformed.html = resolvedHtml;\n }\n } else {\n // Default parameter handling for other tag types\n for (const [key, value] of Object.entries(yamlConfig.parameters)) {\n const resolvedValue = this.resolveVariableReferences(String(value));\n transformed.parameter.push({\n type: this.getTagParameterType(yamlConfig.type, key, value),\n key,\n value: resolvedValue,\n });\n }\n }\n }\n\n // Handle trigger references (convert trigger names to IDs later)\n // CRITICAL FIX: Use firingTriggerId so the client can resolve names to IDs\n if (\n yamlConfig.firingTriggerId &&\n Array.isArray(yamlConfig.firingTriggerId)\n ) {\n // Use firingTriggerId field if present\n transformed.firingTriggerId = yamlConfig.firingTriggerId;\n } else if (\n yamlConfig.firing_triggers &&\n Array.isArray(yamlConfig.firing_triggers)\n ) {\n // Use firing_triggers field (alternative format)\n transformed.firingTriggerId = yamlConfig.firing_triggers;\n } else if (yamlConfig.triggers && Array.isArray(yamlConfig.triggers)) {\n // Fall back to triggers field for backward compatibility\n transformed.firingTriggerId = yamlConfig.triggers;\n }\n\n // Add description if present\n if (yamlConfig.description) {\n transformed.notes = yamlConfig.description;\n }\n\n return transformed;\n }\n\n /**\n * Detect if a tag configuration represents a GA4 event tag\n * (has eventName or eventParameters)\n */\n private isGA4EventTag(yamlConfig: any): boolean {\n // Check if tag has event-specific parameters\n if (yamlConfig.parameter && Array.isArray(yamlConfig.parameter)) {\n return yamlConfig.parameter.some(\n (p: any) => p.key === \"eventName\" || p.key === \"eventParameters\"\n );\n }\n\n // Check if tag has parameters object with event fields\n if (yamlConfig.parameters) {\n return (\n yamlConfig.parameters.eventName || yamlConfig.parameters.eventParameters\n );\n }\n\n return false;\n }\n\n /**\n * Map tag type codes to full GTM API type names\n * CRITICAL: Auto-corrects googtag to gaawe for GA4 event tags\n */\n private mapTagType(type: string, yamlConfig?: any): string {\n const typeMap: Record<string, string> = {\n googtag: \"googtag\", // Google Tag (basic config only - NOT for events)\n gaawe: \"gaawe\", // GA4 Event Tag (supports eventName, eventParameters)\n gaawc: \"gaawc\", // GA4 Configuration Tag\n ua: \"ua\", // Universal Analytics\n html: \"html\", // Custom HTML\n img: \"img\", // Custom Image\n gclidw: \"gclidw\", // Google Ads Conversion Linker\n awct: \"awct\", // Google Ads Conversion Tracking\n sp: \"sp\", // Salesforce Pardot\n flc: \"flc\", // Floodlight Counter\n fls: \"fls\", // Floodlight Sales\n };\n\n // CRITICAL FIX: Auto-detect and correct GA4 event tags\n if (type === \"googtag\" && yamlConfig && this.isGA4EventTag(yamlConfig)) {\n console.log(\n `[AUTO-CORRECT] Converting tag \"${yamlConfig.name}\" from type \"googtag\" to \"gaawe\" (GA4 Event Tag)`\n );\n return \"gaawe\";\n }\n\n return typeMap[type] || type;\n }\n\n /**\n * Get parameter type for tag parameters\n */\n private getTagParameterType(\n tagType: string,\n key: string,\n value: any\n ): string {\n // Most tag parameters are templates\n if (typeof value === \"boolean\") {\n return \"boolean\";\n } else if (typeof value === \"number\") {\n return \"integer\";\n } else {\n return \"template\";\n }\n }\n\n /**\n * Resolve trigger names or IDs to trigger IDs\n * Handles both trigger names (e.g., \"All Pages\") and IDs (e.g., \"225\")\n */\n private async resolveTriggerNames(\n triggerNamesOrIds: string[]\n ): Promise<string[]> {\n try {\n const triggersResult = await this.clients.gtm.listTriggers();\n if (!triggersResult.success || !triggersResult.data) {\n console.warn(`Warning: Could not list triggers to resolve names`);\n return [];\n }\n\n const triggerIds: string[] = [];\n for (const triggerNameOrId of triggerNamesOrIds) {\n // Check if it's already a numeric ID\n if (/^\\d+$/.test(triggerNameOrId)) {\n // It's an ID - verify it exists\n const triggerExists = triggersResult.data.some(\n (t) => t.triggerId === triggerNameOrId\n );\n if (triggerExists) {\n triggerIds.push(triggerNameOrId);\n } else {\n console.warn(\n `Warning: Trigger ID \"${triggerNameOrId}\" not found in GTM`\n );\n }\n } else {\n // It's a name - resolve to ID\n const trigger = triggersResult.data.find(\n (t) => t.name === triggerNameOrId\n );\n if (trigger && trigger.triggerId) {\n triggerIds.push(trigger.triggerId);\n } else {\n console.warn(\n `Warning: Could not find trigger with name \"${triggerNameOrId}\"`\n );\n }\n }\n }\n\n return triggerIds;\n } catch (error) {\n console.warn(`Warning: Error resolving trigger names:`, error);\n return [];\n }\n }\n\n /**\n * Transform trigger config from YAML format to GTM API format\n */\n private transformTriggerConfig(yamlConfig: any): any {\n const transformed: any = {\n name: yamlConfig.name,\n type: this.mapTriggerType(yamlConfig.type),\n };\n\n // Handle custom event filters - GTM expects specific format for customEvent\n if (yamlConfig.type === \"customEvent\") {\n if (yamlConfig.custom_event_filter || yamlConfig.customEventFilter) {\n const filters =\n yamlConfig.custom_event_filter || yamlConfig.customEventFilter;\n\n // Transform filter to GTM API format\n if (Array.isArray(filters) && filters.length > 0) {\n const filter = filters[0];\n // Extract event name from filter parameters\n let eventName = \"\";\n if (filter.parameter && Array.isArray(filter.parameter)) {\n const eventParam = filter.parameter.find(\n (p: any) => p.key === \"event\" || p.key === \"arg1\"\n );\n if (eventParam) {\n eventName = eventParam.value;\n }\n }\n\n // Build proper custom event filter for GTM API - must be exactly one filter\n transformed.customEventFilter = [\n {\n type: \"equals\",\n parameter: [\n {\n type: \"template\",\n key: \"arg0\",\n value: \"{{_event}}\",\n },\n {\n type: \"template\",\n key: \"arg1\",\n value: eventName,\n },\n ],\n },\n ];\n }\n }\n }\n\n // Handle event name for custom triggers\n if (yamlConfig.eventName) {\n transformed.eventName = yamlConfig.eventName;\n }\n\n // Add description if present\n if (yamlConfig.description) {\n transformed.notes = yamlConfig.description;\n }\n\n return transformed;\n }\n\n /**\n * Map trigger type codes to full GTM API type names\n */\n private mapTriggerType(type: string): string {\n const typeMap: Record<string, string> = {\n pageview: \"pageview\",\n domReady: \"domReady\",\n windowLoaded: \"windowLoaded\",\n customEvent: \"customEvent\",\n click: \"click\",\n linkClick: \"linkClick\",\n formSubmission: \"formSubmission\",\n historyChange: \"historyChange\",\n timer: \"timer\",\n scrollDepth: \"scrollDepth\",\n youtubeVideo: \"youtubeVideo\",\n };\n return typeMap[type] || type;\n }\n\n /**\n * Filter trigger fields for update operations\n * Only include fields that can be updated via the GTM API\n */\n private filterTriggerUpdateFields(triggerConfig: any): any {\n // Include all essential trigger fields for updates\n const filtered: any = {\n name: triggerConfig.name,\n type: triggerConfig.type,\n };\n\n // Include all configuration fields that might be present\n const configFields = [\n \"customEventFilter\",\n \"filter\",\n \"autoEventFilter\",\n \"waitForTags\",\n \"checkValidation\",\n \"waitForTagsTimeout\",\n \"uniqueTriggerId\",\n \"eventName\",\n \"interval\",\n \"intervalSeconds\",\n \"limit\",\n \"maxTimerLengthSeconds\",\n \"parameter\",\n \"notes\",\n ];\n\n for (const field of configFields) {\n if (triggerConfig[field] !== undefined) {\n filtered[field] = triggerConfig[field];\n }\n }\n\n // Always include notes field - essential for proper sync\n filtered.notes = triggerConfig.notes || triggerConfig.description || \"\";\n\n return filtered;\n }\n\n /**\n * Filter variable fields for update operations\n * Only include fields that can be updated via the GTM API\n */\n private filterVariableUpdateFields(variableConfig: any): any {\n // For variables, we need to include the parameter array which contains the actual configuration\n // GTM expects the parameter array format for updates\n const filtered: any = {\n name: variableConfig.name,\n type: variableConfig.type,\n };\n\n // Always include parameter if present (this is the main configuration)\n if (variableConfig.parameter) {\n filtered.parameter = variableConfig.parameter;\n }\n\n // Always include notes field - essential for proper sync\n filtered.notes = variableConfig.notes || variableConfig.description || \"\";\n\n // Include formatValue if present (for certain variable types)\n if (variableConfig.formatValue) {\n filtered.formatValue = variableConfig.formatValue;\n }\n\n return filtered;\n }\n\n /**\n * Filter tag fields for update operations\n * Only include fields that can be updated via the GTM API\n */\n private filterTagUpdateFields(tagConfig: any): any {\n // Include all essential tag fields for updates\n // NOTE: Do NOT include 'type' - GTM doesn't allow changing tag type after creation\n const filtered: any = {\n name: tagConfig.name,\n };\n\n // Include all configuration fields that might be present\n const configFields = [\n \"parameter\",\n \"parameters\",\n \"firingTriggerId\",\n \"blockingTriggerId\",\n \"liveOnly\",\n \"priority\",\n \"scheduleStartMs\",\n \"scheduleEndMs\",\n \"notes\",\n \"tagFiringOption\",\n \"monitoringMetadata\",\n \"monitoringMetadataTagNameKey\",\n ];\n\n for (const field of configFields) {\n if (tagConfig[field] !== undefined) {\n filtered[field] = tagConfig[field];\n }\n }\n\n // Always include notes field - essential for proper sync\n // Check various possible note field names from the config\n const notesValue =\n tagConfig.notes || tagConfig.description || tagConfig.desc || \"\";\n if (notesValue) {\n filtered.notes = notesValue;\n }\n\n // Don't send undefined monitoringMetadata - GTM keeps it as {\"type\":\"map\"}\n if (filtered.monitoringMetadata === undefined) {\n delete filtered.monitoringMetadata;\n }\n\n return filtered;\n }\n\n /**\n * Transform variable config from YAML format to GTM API format using the working GTMApiTransformer\n */\n private transformVariableConfig(yamlConfig: any): any {\n // Check if already in GTM API format (has parameter array)\n if (yamlConfig.parameter && Array.isArray(yamlConfig.parameter)) {\n // Already transformed, keep the full structure for GTM\n const transformed: any = {\n name: yamlConfig.name,\n type: this.mapVariableTypeForGTMApi(yamlConfig.type),\n parameter: yamlConfig.parameter, // Keep the full parameter array\n };\n\n // Add notes if present\n if (yamlConfig.notes) {\n transformed.notes = yamlConfig.notes;\n }\n\n // For AEV variables, ensure parameter format is correct\n if (yamlConfig.type === \"aev\") {\n // Make sure parameter type is uppercase\n transformed.parameter = yamlConfig.parameter.map((p: any) => ({\n ...p,\n type: p.type?.toUpperCase() || \"TEMPLATE\",\n }));\n }\n\n return transformed;\n }\n\n // Handle YAML format with parameters object - convert to GTM parameter array format\n const transformed: any = {\n name: yamlConfig.name,\n type: this.mapVariableTypeForGTMApi(yamlConfig.type),\n };\n\n // Add notes if present\n if (yamlConfig.description) {\n transformed.notes = yamlConfig.description;\n }\n\n // Convert parameters object to parameter array format that GTM expects\n if (yamlConfig.parameters) {\n const paramArray: any[] = [];\n\n // Handle different variable types\n if (yamlConfig.type === \"c\" || yamlConfig.type === \"constant\") {\n // Constant variable\n if (yamlConfig.parameters.value !== undefined) {\n paramArray.push({\n type: \"TEMPLATE\",\n key: \"value\",\n value: yamlConfig.parameters.value,\n });\n }\n } else if (yamlConfig.type === \"v\" || yamlConfig.type === \"dataLayer\") {\n // Data Layer Variable - add required parameters\n if (yamlConfig.parameters.name !== undefined) {\n paramArray.push({\n type: \"TEMPLATE\",\n key: \"name\",\n value: yamlConfig.parameters.name,\n });\n }\n // Always add dataLayerVersion (required)\n paramArray.push({\n type: \"INTEGER\",\n key: \"dataLayerVersion\",\n value: yamlConfig.parameters.dataLayerVersion || \"2\",\n });\n // Always add setDefaultValue (required)\n paramArray.push({\n type: \"BOOLEAN\",\n key: \"setDefaultValue\",\n value:\n yamlConfig.parameters.setDefaultValue !== undefined\n ? String(yamlConfig.parameters.setDefaultValue)\n : \"false\",\n });\n // Optional defaultValue\n if (yamlConfig.parameters.defaultValue !== undefined) {\n paramArray.push({\n type: \"TEMPLATE\",\n key: \"defaultValue\",\n value: yamlConfig.parameters.defaultValue,\n });\n }\n } else if (yamlConfig.type === \"u\" || yamlConfig.type === \"url\") {\n // URL variable\n if (yamlConfig.parameters.component !== undefined) {\n paramArray.push({\n type: \"TEMPLATE\",\n key: \"component\",\n value: yamlConfig.parameters.component,\n });\n }\n } else if (yamlConfig.type === \"aev\" || yamlConfig.type === \"autoEvent\") {\n // Auto Event Variable - this is the key fix for Click URL/ID\n if (yamlConfig.parameters.varType !== undefined) {\n paramArray.push({\n type: \"TEMPLATE\",\n key: \"varType\",\n value: yamlConfig.parameters.varType.toString().toUpperCase(), // Ensure uppercase\n });\n }\n } else if (\n yamlConfig.type === \"jsm\" ||\n yamlConfig.type === \"customJavascript\"\n ) {\n // Custom JavaScript variable\n if (yamlConfig.parameters.javascript !== undefined) {\n paramArray.push({\n type: \"TEMPLATE\",\n key: \"javascript\",\n value: yamlConfig.parameters.javascript,\n });\n }\n }\n\n // Set the parameter array\n if (paramArray.length > 0) {\n transformed.parameter = paramArray;\n }\n }\n\n return transformed;\n }\n\n /**\n * Transform variable config using the proven working GTMApiTransformer (NEW - replaces manual logic)\n */\n private transformVariableConfigWithWorkingTransformer(yamlConfig: any): any {\n // Use the proven working transformer instead of manual parameter building\n return this.gtmTransformer.transformVariable(yamlConfig);\n }\n\n /**\n * Map short variable type codes to full GTM API type names (LEGACY - for display purposes)\n */\n private mapVariableType(type: string): string {\n const typeMap: Record<string, string> = {\n c: \"Constant\",\n constant: \"Constant\",\n v: \"Data Layer Variable\",\n dataLayer: \"Data Layer Variable\",\n u: \"URL\",\n url: \"URL\",\n jsm: \"Custom JavaScript\",\n customJavascript: \"Custom JavaScript\",\n aev: \"Auto-Event Variable\",\n e: \"Environment Name\",\n j: \"JavaScript Variable\",\n k: \"Cookie\",\n r: \"Referrer\",\n gas: \"Google Analytics Settings\",\n };\n return typeMap[type] || type;\n }\n\n /**\n * Map variable type codes to GTM API format (keep short codes, normalize long names to short codes)\n */\n private mapVariableTypeForGTMApi(type: string): string {\n // GTM API expects short codes, not human-readable names\n const typeMap: Record<string, string> = {\n // Short codes remain as-is (these are what GTM API wants)\n c: \"c\",\n v: \"v\",\n u: \"u\",\n jsm: \"jsm\",\n aev: \"aev\",\n e: \"e\",\n j: \"j\",\n k: \"k\",\n r: \"r\",\n gas: \"gas\",\n // Human-readable names get converted to short codes\n Constant: \"c\",\n \"Data Layer Variable\": \"v\",\n URL: \"u\",\n \"Custom JavaScript\": \"jsm\",\n \"Auto-Event Variable\": \"aev\",\n \"Environment Name\": \"e\",\n \"JavaScript Variable\": \"j\",\n Cookie: \"k\",\n Referrer: \"r\",\n \"Google Analytics Settings\": \"gas\",\n // Additional common alternatives\n constant: \"c\",\n dataLayer: \"v\",\n dataLayerVariable: \"v\",\n customJavascript: \"jsm\",\n autoEvent: \"aev\",\n autoEventVariable: \"aev\",\n };\n return typeMap[type] || type;\n }\n\n /**\n * GTM API rate limiter: 0.25 QPS (1 request every 4 seconds)\n * Uses 5 seconds delay to stay well within limits\n */\n private async delay(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\n }\n\n /**\n * Intelligent rate limiter that tracks request timing\n * Ensures we never exceed GTM API limits of 0.25 QPS\n */\n private lastRequestTime: number = 0;\n private async smartDelay(context?: string): Promise<void> {\n const now = Date.now();\n const timeSinceLastRequest = now - this.lastRequestTime;\n const minInterval = 5000; // 5 seconds between requests for GTM API\n\n if (timeSinceLastRequest < minInterval) {\n const delayNeeded = minInterval - timeSinceLastRequest;\n if (context) {\n console.log(\n chalk.dim(\n `⏳ Rate limiting: waiting ${Math.round(\n delayNeeded / 1000\n )}s before ${context}...`\n )\n );\n }\n await this.delay(delayNeeded);\n }\n\n this.lastRequestTime = Date.now();\n }\n\n /**\n * Find tags that are linked to a specific trigger and unlink them\n */\n private async unlinkTagsFromTrigger(\n triggerId: string,\n triggerName: string\n ): Promise<void> {\n try {\n // Get all tags to find which ones use this trigger\n const tagsResult = await this.clients.gtm.listTags();\n if (!tagsResult.success || !tagsResult.data) {\n console.warn(\n chalk.yellow(\n `Could not list tags to check for trigger dependencies: ${tagsResult.error}`\n )\n );\n return;\n }\n\n const linkedTags = tagsResult.data.filter(\n (tag) => tag.firingTriggerId && tag.firingTriggerId.includes(triggerId)\n );\n\n if (linkedTags.length === 0) {\n console.log(chalk.dim(` No tags linked to trigger: ${triggerName}`));\n return;\n }\n\n console.log(\n chalk.yellow(\n ` 🔗 Found ${linkedTags.length} tags linked to trigger \"${triggerName}\"`\n )\n );\n\n for (const tag of linkedTags) {\n if (!tag.tagId || !tag.firingTriggerId) continue;\n\n await this.smartDelay(`unlinking tag ${tag.name}`);\n\n // Remove the trigger ID from the tag's firingTriggerId array\n const updatedTriggerIds = tag.firingTriggerId.filter(\n (id) => id !== triggerId\n );\n\n try {\n const updateResult = await this.clients.gtm.updateTag(tag.tagId, {\n firingTriggerId: updatedTriggerIds,\n });\n\n if (updateResult.success) {\n console.log(\n chalk.blue(\n ` ↳ Unlinked tag: ${tag.name} (${updatedTriggerIds.length} triggers remaining)`\n )\n );\n } else {\n console.warn(\n chalk.yellow(\n ` ⚠️ Failed to unlink tag \"${tag.name}\": ${updateResult.error}`\n )\n );\n }\n } catch (error) {\n console.warn(\n chalk.yellow(\n ` ⚠️ Error unlinking tag \"${tag.name}\": ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n );\n }\n }\n } catch (error) {\n console.warn(\n chalk.yellow(\n `Could not check for tag dependencies: ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n );\n }\n }\n\n /**\n * Check if a resource has dependencies and handle unlinking before deletion\n */\n private async handleDependenciesBeforeDeletion(\n change: any\n ): Promise<boolean> {\n const resourceType = change.type.replace(\"gtm_\", \"\");\n const resourceData = change.change?.before;\n\n if (!resourceData) {\n console.warn(\n chalk.yellow(`No resource data found for deletion: ${change.name}`)\n );\n return false;\n }\n\n // Handle trigger dependencies\n if (resourceType === \"trigger\" && resourceData.triggerId) {\n console.log(\n chalk.cyan(\n ` 🔍 Checking dependencies for trigger: ${\n resourceData.name || change.name\n }`\n )\n );\n await this.unlinkTagsFromTrigger(\n resourceData.triggerId,\n resourceData.name || change.name\n );\n return true;\n }\n\n // Tags and variables typically don't have dependencies that prevent deletion\n return true;\n }\n\n async gtmCreateWorkspace(options: {\n name: string;\n description?: string;\n }): Promise<void> {\n const spinner = ora(\"Creating GTM workspace...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n }\n\n spinner.text = `Creating workspace \"${options.name}\"...`;\n const createResult = await this.clients.gtm.createWorkspace(\n options.name,\n options.description\n );\n\n if (!createResult.success) {\n throw new Error(`Failed to create workspace: ${createResult.error}`);\n }\n\n spinner.succeed(`Workspace \"${options.name}\" created successfully!`);\n console.log(`Workspace ID: ${createResult.data?.workspaceId}`);\n console.log(`Workspace Name: ${createResult.data?.name}`);\n } catch (error) {\n spinner.fail(\"Failed to create workspace\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmTerraformDestroy(_options: {\n config: string;\n yes?: boolean;\n }): Promise<void> {\n console.log(chalk.yellow(\"GTM Destroy functionality coming soon...\"));\n console.log(\n chalk.blue(\"This would remove all GTM resources defined in configuration\")\n );\n }\n\n async gtmTerraformImport(options: {\n type: string;\n name: string;\n id: string;\n }): Promise<void> {\n const spinner = ora(\n `Importing GTM ${options.type} ${options.name}...`\n ).start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n // Select workspace\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(\n `Failed to select workspace: ${workspaceResult.error}`\n );\n }\n }\n\n const stateManager = new StateManager();\n let attributes: any = {};\n\n // Fetch resource details from GTM\n switch (options.type) {\n case \"tag\": {\n const tagResult = await this.clients.gtm.getTag(options.id);\n if (tagResult.success) attributes = tagResult.data;\n break;\n }\n case \"trigger\": {\n const triggerResult = await this.clients.gtm.getTrigger(options.id);\n if (triggerResult.success) attributes = triggerResult.data;\n break;\n }\n case \"variable\": {\n const variableResult = await this.clients.gtm.getVariable(options.id);\n if (variableResult.success) attributes = variableResult.data;\n break;\n }\n default:\n throw new Error(`Unsupported resource type: ${options.type}`);\n }\n\n const result = await stateManager.importResource(\n `gtm_${options.type}`,\n options.name,\n options.id,\n attributes\n );\n\n if (result.success) {\n spinner.succeed(`Imported ${options.type} ${options.name}`);\n } else {\n spinner.fail(\"Import failed\");\n console.error(chalk.red(\"Error:\"), result.error);\n }\n } catch (error) {\n spinner.fail(\"Import failed\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmTerraformShow(options: { format: string }): Promise<void> {\n const spinner = ora(\"Loading GTM state...\").start();\n\n try {\n const stateManager = new StateManager();\n const state = await stateManager.load();\n\n spinner.stop();\n\n if (!state) {\n console.log(chalk.yellow(\"No state file found. Run `gtm init` first.\"));\n return;\n }\n\n if (options.format === \"table\") {\n const tableData = [[\"Type\", \"Name\", \"Address\", \"Provider\"]];\n\n for (const resource of state.resources) {\n tableData.push([\n resource.type,\n resource.name,\n `${resource.type}.${resource.name}`,\n resource.provider,\n ]);\n }\n\n console.log(chalk.bold(\"\\n📋 GTM State Resources\\n\"));\n console.log(table(tableData));\n console.log(chalk.blue(`\\nTotal resources: ${state.resources.length}`));\n } else if (options.format === \"yaml\") {\n const configParser = new ConfigParser();\n const config = configParser.stateToConfig(state);\n console.log(yaml.dump(config));\n } else {\n console.log(JSON.stringify(state, null, 2));\n }\n } catch (error) {\n spinner.fail(\"Failed to load state\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmTerraformValidate(options: { config: string }): Promise<void> {\n const spinner = ora(\"Validating GTM configuration...\").start();\n\n try {\n const configParser = new ConfigParser();\n const config = await configParser.loadConfig(options.config);\n const validationResult = configParser.validateConfig(config);\n\n spinner.stop();\n\n if (validationResult.valid) {\n console.log(chalk.green(\"✅ Configuration is valid\"));\n console.log(\n chalk.blue(\n `Resources: ${Object.keys(config.resources || {}).length} types`\n )\n );\n if (config.resources) {\n for (const [type, resources] of Object.entries(config.resources)) {\n if (Array.isArray(resources)) {\n console.log(\n chalk.blue(` - ${type}: ${resources.length} resources`)\n );\n }\n }\n }\n } else {\n console.log(chalk.red(\"❌ Configuration has errors:\"));\n for (const error of validationResult.errors) {\n console.log(chalk.red(` - ${error}`));\n }\n }\n } catch (error) {\n spinner.fail(\"Validation failed\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmTerraformStateList(options: { type?: string }): Promise<void> {\n try {\n const stateManager = new StateManager();\n const resources = await stateManager.listResources();\n\n const filteredResources = options.type\n ? resources.filter((r) => r.type === options.type)\n : resources;\n\n if (filteredResources.length === 0) {\n console.log(chalk.yellow(\"No resources found in state\"));\n return;\n }\n\n console.log(chalk.bold(\"\\n📋 State Resources\\n\"));\n for (const resource of filteredResources) {\n console.log(`${resource.type}.${resource.name}`);\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmTerraformStateShow(options: { address: string }): Promise<void> {\n try {\n const stateManager = new StateManager();\n const [type, name] = options.address.split(\".\");\n const resource = await stateManager.getResource(type, name);\n\n if (!resource) {\n console.log(\n chalk.yellow(`Resource ${options.address} not found in state`)\n );\n return;\n }\n\n console.log(chalk.bold(`\\n📋 Resource: ${options.address}\\n`));\n console.log(JSON.stringify(resource, null, 2));\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmTerraformStateRemove(options: { address: string }): Promise<void> {\n const spinner = ora(`Removing ${options.address} from state...`).start();\n\n try {\n const stateManager = new StateManager();\n const [type, name] = options.address.split(\".\");\n const result = await stateManager.removeResource(type, name);\n\n if (result.success) {\n spinner.succeed(`Removed ${options.address} from state`);\n } else {\n spinner.fail(\"Remove failed\");\n console.error(chalk.red(\"Error:\"), result.error);\n }\n } catch (error) {\n spinner.fail(\"Remove failed\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async removeTriggers(triggerIds: string[]): Promise<void> {\n const spinner = ora(\"Removing unused triggers from GTM...\").start();\n\n try {\n // Force a fresh GTM client\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, debug: true, failFast: true });\n\n // Authenticate\n spinner.text = \"Authenticating with GTM API...\";\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // Select workspace\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n spinner.text = \"Finding triggers to remove...\";\n const triggersResult = await this.clients.gtm.listTriggers();\n if (!triggersResult.success) {\n throw new Error(`Failed to list triggers: ${triggersResult.error}`);\n }\n\n // Find triggers that match the IDs to remove\n const triggersToRemove = triggersResult.data.filter((trigger) => {\n return triggerIds.includes(trigger.triggerId || \"\");\n });\n\n spinner.stop();\n\n if (triggersToRemove.length > 0) {\n console.log(\n chalk.cyan(`\\nFound ${triggersToRemove.length} triggers to remove:`)\n );\n triggersToRemove.forEach((trigger) => {\n console.log(` - ${trigger.name} (ID: ${trigger.triggerId})`);\n });\n\n console.log(chalk.yellow(\"\\n🗑️ Removing triggers...\"));\n\n for (const trigger of triggersToRemove) {\n console.log(chalk.blue(` 🗑️ Removing ${trigger.name}:`));\n\n // Delete the trigger directly via GTM API\n const triggerPath = `accounts/${\n (this.clients.gtm as any).config.accountId\n }/containers/${\n (this.clients.gtm as any).config.containerId\n }/workspaces/${(this.clients.gtm as any).workspaceId}/triggers/${\n trigger.triggerId\n }`;\n\n try {\n await (\n this.clients.gtm as any\n ).tagmanager.accounts.containers.workspaces.triggers.delete({\n path: triggerPath,\n });\n console.log(chalk.green(\" ✅ Removed successfully\"));\n } catch (error) {\n console.log(\n chalk.red(\n ` ❌ Failed to remove: ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n );\n }\n }\n } else {\n console.log(chalk.green(\"\\n✅ No matching triggers found to remove\"));\n }\n\n console.log(\"\");\n console.log(chalk.cyan(\"🎯 Next Steps:\"));\n console.log(\"1. Review the changes in GTM workspace\");\n console.log(\"2. Test the configuration in Preview mode\");\n console.log(\"3. Use GTM UI to publish workspace to production\");\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmCreateTag(options: {\n name: string;\n type: string;\n config?: string;\n }): Promise<void> {\n const spinner = ora(\"Creating GTM tag...\").start();\n\n try {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, debug: true, failFast: true });\n\n spinner.text = \"Authenticating with GTM API...\";\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n spinner.text = \"Creating tag...\";\n const tagConfig = {\n name: options.name,\n type: options.type as any,\n ...(options.config && JSON.parse(options.config)),\n };\n\n const result = await this.clients.gtm.createTag(tagConfig);\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green(`✅ Tag created successfully:`));\n console.log(` - Name: ${result.data?.name}`);\n console.log(` - ID: ${result.data?.tagId}`);\n console.log(` - Type: ${result.data?.type}`);\n } else {\n console.error(chalk.red(`❌ Failed to create tag: ${result.error}`));\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmDeleteTag(tagId: string): Promise<void> {\n const spinner = ora(\"Deleting GTM tag...\").start();\n\n try {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, debug: true, failFast: true });\n\n spinner.text = \"Authenticating with GTM API...\";\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n spinner.text = \"Deleting tag...\";\n const result = await this.clients.gtm.deleteTag(tagId);\n\n spinner.stop();\n\n if (result.success) {\n console.log(\n chalk.green(`✅ Tag deleted successfully: ${result.message}`)\n );\n } else {\n console.error(chalk.red(`❌ Failed to delete tag: ${result.error}`));\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmCreateTrigger(options: {\n name: string;\n type: string;\n config?: string;\n }): Promise<void> {\n const spinner = ora(\"Creating GTM trigger...\").start();\n\n try {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, debug: true, failFast: true });\n\n spinner.text = \"Authenticating with GTM API...\";\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n spinner.text = \"Creating trigger...\";\n const triggerConfig = {\n name: options.name,\n type: options.type as any,\n ...(options.config && JSON.parse(options.config)),\n };\n\n const result = await this.clients.gtm.createTrigger(triggerConfig);\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green(`✅ Trigger created successfully:`));\n console.log(` - Name: ${result.data?.name}`);\n console.log(` - ID: ${result.data?.triggerId}`);\n console.log(` - Type: ${result.data?.type}`);\n } else {\n console.error(\n chalk.red(`❌ Failed to create trigger: ${result.error}`)\n );\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmDeleteTrigger(triggerId: string): Promise<void> {\n const spinner = ora(\"Deleting GTM trigger...\").start();\n\n try {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, debug: true, failFast: true });\n\n spinner.text = \"Authenticating with GTM API...\";\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n spinner.text = \"Deleting trigger...\";\n const result = await this.clients.gtm.deleteTrigger(triggerId);\n\n spinner.stop();\n\n if (result.success) {\n console.log(\n chalk.green(`✅ Trigger deleted successfully: ${result.message}`)\n );\n } else {\n console.error(\n chalk.red(`❌ Failed to delete trigger: ${result.error}`)\n );\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n /**\n * Transform YAML configuration format to GTM API format\n */\n private transformResourceForGTM(\n resourceType: string,\n resourceData: any\n ): any {\n switch (resourceType) {\n case \"variable\":\n return this.transformVariableForGTM(resourceData);\n case \"trigger\":\n return this.transformTriggerForGTM(resourceData);\n case \"tag\":\n return this.transformTagForGTM(resourceData);\n default:\n return resourceData;\n }\n }\n\n private transformVariableForGTM(yamlVariable: any): any {\n const config: any = {\n name: yamlVariable.name,\n type: yamlVariable.type,\n };\n\n // Map YAML types to GTM client expected format\n if (yamlVariable.type === \"c\") {\n // Constant variable\n config.type = \"Constant\";\n if (yamlVariable.parameter) {\n const valueParam = yamlVariable.parameter.find(\n (p: any) => p.key === \"value\"\n );\n if (valueParam) {\n config.value = valueParam.value;\n }\n }\n } else if (yamlVariable.type === \"v\") {\n // Data Layer Variable\n config.type = \"Data Layer Variable\";\n if (yamlVariable.parameter) {\n const nameParam = yamlVariable.parameter.find(\n (p: any) => p.key === \"name\"\n );\n if (nameParam) {\n config.dataLayerVariableName = nameParam.value;\n }\n }\n } else if (yamlVariable.type === \"aev\" || yamlVariable.type === \"u\") {\n // Keep raw for other types and pass parameters directly\n config.parameters = yamlVariable.parameter;\n }\n\n // Add notes if present\n if (yamlVariable.notes) {\n config.notes = yamlVariable.notes;\n }\n\n return config;\n }\n\n private transformTriggerForGTM(yamlTrigger: any): any {\n const config: any = {\n name: yamlTrigger.name,\n type: yamlTrigger.type,\n };\n\n // For custom event triggers, we need to properly format the filter\n if (yamlTrigger.type === \"customEvent\" && yamlTrigger.customEventFilter) {\n // The filter is already in array format from YAML, just pass it through\n config.customEventFilter = yamlTrigger.customEventFilter;\n // Also extract the event name for the simplified config\n if (yamlTrigger.customEventFilter[0]?.parameter) {\n const eventParam = yamlTrigger.customEventFilter[0].parameter.find(\n (p: any) => p.key === \"arg1\"\n );\n if (eventParam) {\n config.eventName = eventParam.value;\n }\n }\n }\n\n if (yamlTrigger.notes) {\n config.notes = yamlTrigger.notes;\n }\n\n return config;\n }\n\n private transformTagForGTM(yamlTag: any): any {\n const config: any = {\n name: yamlTag.name,\n type: yamlTag.type,\n };\n\n // For tags, pass parameters directly\n if (yamlTag.parameter) {\n config.parameters = yamlTag.parameter;\n\n // Extract specific values for known tag types\n if (yamlTag.type === \"awct\") {\n // Google Ads Conversion\n const conversionId = yamlTag.parameter.find(\n (p: any) => p.key === \"conversionId\"\n );\n const conversionLabel = yamlTag.parameter.find(\n (p: any) => p.key === \"conversionLabel\"\n );\n if (conversionId) config.conversionId = conversionId.value;\n if (conversionLabel) config.conversionLabel = conversionLabel.value;\n } else if (yamlTag.type === \"gaawc\") {\n // GA4 Configuration\n const measurementId = yamlTag.parameter.find(\n (p: any) => p.key === \"tagId\"\n );\n if (measurementId) config.measurementId = measurementId.value;\n }\n }\n\n if (yamlTag.firingTriggerId) {\n config.triggerIds = yamlTag.firingTriggerId;\n }\n\n if (yamlTag.notes) {\n config.notes = yamlTag.notes;\n }\n\n return config;\n }\n\n // Version Management Methods\n async gtmListVersions(options: { limit?: string }): Promise<void> {\n const spinner = ora(\"Fetching GTM versions...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n const versionsResult = await this.clients.gtm.listVersions();\n if (!versionsResult.success) {\n throw new Error(`Failed to fetch versions: ${versionsResult.error}`);\n }\n\n spinner.stop();\n\n const limit = options.limit ? parseInt(options.limit) : 10;\n const versions = versionsResult.data.slice(0, limit);\n\n console.log(\n chalk.bold(\n `\\n📋 GTM Published Versions (${versions.length}/${versionsResult.data.length})\\n`\n )\n );\n\n const tableData = [[\"Version ID\", \"Name\", \"Created\", \"Description\"]];\n versions.forEach((version: any) => {\n tableData.push([\n version.containerVersionId || \"N/A\",\n version.name || \"Unnamed\",\n version.dateCreated\n ? new Date(version.dateCreated).toLocaleDateString()\n : \"N/A\",\n (version.description || \"\").substring(0, 50) +\n (version.description?.length > 50 ? \"...\" : \"\"),\n ]);\n });\n\n console.log(table(tableData));\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmGetVersion(options: { version: string }): Promise<void> {\n const spinner = ora(`Fetching GTM version ${options.version}...`).start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n const versionResult = await this.clients.gtm.getVersion(options.version);\n if (!versionResult.success) {\n throw new Error(`Failed to fetch version: ${versionResult.error}`);\n }\n\n spinner.stop();\n\n const version = versionResult.data;\n console.log(chalk.bold(`\\n📋 GTM Version ${options.version} Details\\n`));\n\n console.log(chalk.cyan(\"Basic Info:\"));\n console.log(` Name: ${version.name || \"Unnamed\"}`);\n console.log(` Description: ${version.description || \"No description\"}`);\n console.log(\n ` Created: ${\n version.dateCreated\n ? new Date(version.dateCreated).toLocaleDateString()\n : \"Unknown\"\n }`\n );\n console.log(` Version ID: ${version.containerVersionId}`);\n\n console.log(chalk.cyan(\"\\nResources:\"));\n console.log(` Tags: ${version.tag?.length || 0}`);\n console.log(` Triggers: ${version.trigger?.length || 0}`);\n console.log(` Variables: ${version.variable?.length || 0}`);\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmGetLiveVersion(): Promise<void> {\n const spinner = ora(\"Fetching live GTM version...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n const liveVersionResult = await this.clients.gtm.getLiveVersion();\n if (!liveVersionResult.success) {\n throw new Error(\n `Failed to fetch live version: ${liveVersionResult.error}`\n );\n }\n\n spinner.stop();\n\n const version = liveVersionResult.data;\n console.log(chalk.bold(`\\n📋 Currently Published Live Version\\n`));\n\n console.log(chalk.cyan(\"Version Info:\"));\n console.log(` Version ID: ${version.containerVersionId}`);\n console.log(` Name: ${version.name || \"Unnamed\"}`);\n console.log(\n ` Published: ${\n version.dateCreated\n ? new Date(version.dateCreated).toLocaleDateString()\n : \"Unknown\"\n }`\n );\n\n console.log(chalk.cyan(\"\\nLive Configuration:\"));\n console.log(` Tags: ${version.tag?.length || 0}`);\n console.log(` Triggers: ${version.trigger?.length || 0}`);\n console.log(` Variables: ${version.variable?.length || 0}`);\n\n // Show detailed tag list\n if (version.tag && version.tag.length > 0) {\n console.log(chalk.cyan(\"\\n🏷️ TAGS:\"));\n version.tag.forEach((tag, i) => {\n console.log(\n `${(i + 1).toString().padStart(2)}. ${tag.name} (${tag.type})`\n );\n });\n }\n\n // Show detailed trigger list\n if (version.trigger && version.trigger.length > 0) {\n console.log(chalk.cyan(\"\\n⚡ TRIGGERS:\"));\n version.trigger.forEach((trigger, i) => {\n console.log(\n `${(i + 1).toString().padStart(2)}. ${trigger.name} (${\n trigger.type\n })`\n );\n });\n }\n\n // Show detailed variable list\n if (version.variable && version.variable.length > 0) {\n console.log(chalk.cyan(\"\\n📝 VARIABLES:\"));\n version.variable.forEach((variable, i) => {\n console.log(\n `${(i + 1).toString().padStart(2)}. ${variable.name} (${\n variable.type\n })`\n );\n });\n }\n\n // Save to file for reference\n const fs = await import(\"fs/promises\");\n await fs.writeFile(\n \"gtm-version-35-detailed.json\",\n JSON.stringify(version, null, 2)\n );\n console.log(\n chalk.cyan(\"\\n💾 Full details saved to gtm-version-35-detailed.json\")\n );\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmCompareVersions(options: {\n version1: string;\n version2?: string;\n output?: string;\n }): Promise<void> {\n const spinner = ora(\"Comparing versions...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // If no workspace selected but comparing with workspace, select default\n if (!options.version2) {\n await this.clients.gtm.selectWorkspace();\n }\n\n const comparisonResult = await this.clients.gtm.compareVersions(\n options.version1,\n options.version2\n );\n if (!comparisonResult.success) {\n throw new Error(\n `Failed to compare versions: ${comparisonResult.error}`\n );\n }\n\n spinner.stop();\n\n const { version1, version2, workspace, comparison } =\n comparisonResult.data;\n\n console.log(chalk.bold(`\\n🔄 Version Comparison\\n`));\n\n if (version2) {\n console.log(\n chalk.cyan(\n `Comparing Version ${options.version1} vs Version ${options.version2}`\n )\n );\n } else {\n console.log(\n chalk.cyan(\n `Comparing Version ${options.version1} vs Current Workspace`\n )\n );\n }\n\n console.log(chalk.yellow(\"\\n📊 Summary of Changes:\"));\n console.log(\n ` Tags: ${chalk.green(\n `+${comparison.tags.added.length}`\n )} ${chalk.yellow(`~${comparison.tags.modified.length}`)} ${chalk.red(\n `-${comparison.tags.removed.length}`\n )}`\n );\n console.log(\n ` Triggers: ${chalk.green(\n `+${comparison.triggers.added.length}`\n )} ${chalk.yellow(\n `~${comparison.triggers.modified.length}`\n )} ${chalk.red(`-${comparison.triggers.removed.length}`)}`\n );\n console.log(\n ` Variables: ${chalk.green(\n `+${comparison.variables.added.length}`\n )} ${chalk.yellow(\n `~${comparison.variables.modified.length}`\n )} ${chalk.red(`-${comparison.variables.removed.length}`)}`\n );\n\n if (comparison.tags.added.length > 0) {\n console.log(chalk.green(\"\\n➕ Added Tags:\"));\n comparison.tags.added.forEach((tag: string) =>\n console.log(` - ${tag}`)\n );\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmCreateVersion(options: {\n name: string;\n description?: string;\n }): Promise<void> {\n const spinner = ora(\"Creating GTM version from workspace...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n const versionResult = await this.clients.gtm.createVersionFromWorkspace(\n options.name,\n options.description\n );\n if (!versionResult.success) {\n throw new Error(`Failed to create version: ${versionResult.error}`);\n }\n\n spinner.stop();\n\n const version = versionResult.data;\n console.log(chalk.bold(`\\n✅ GTM Version Created Successfully\\n`));\n\n console.log(chalk.cyan(\"Version Details:\"));\n console.log(` Version ID: ${version.containerVersionId}`);\n console.log(` Name: ${version.name}`);\n console.log(` Description: ${version.description || \"No description\"}`);\n console.log(` Created: ${new Date().toLocaleDateString()}`);\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n // =============================================================================\n // WORKSPACE STATE MANAGEMENT\n // =============================================================================\n\n async gtmGetWorkspaceState(options: {\n workspace?: string;\n output?: string;\n }): Promise<void> {\n const spinner = ora(\"Fetching workspace state...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // Select workspace if not specified\n if (!options.workspace && !this.clients.gtm.workspaceId) {\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(\n `Failed to select workspace: ${workspaceResult.error}`\n );\n }\n }\n\n const stateResult = await this.clients.gtm.getWorkspaceState(\n options.workspace\n );\n if (!stateResult.success) {\n throw new Error(`Failed to get workspace state: ${stateResult.error}`);\n }\n\n spinner.stop();\n\n const state = stateResult.data!;\n console.log(chalk.bold(`\\n📋 Workspace State: ${state.workspaceName}\\n`));\n\n console.log(chalk.cyan(\"Workspace Info:\"));\n console.log(` Workspace ID: ${state.workspaceId}`);\n console.log(` Name: ${state.workspaceName}`);\n console.log(\n ` Snapshot Time: ${new Date(state.timestamp).toLocaleString()}`\n );\n\n console.log(chalk.cyan(\"\\nConfiguration:\"));\n console.log(` Tags: ${state.tags.length}`);\n console.log(` Triggers: ${state.triggers.length}`);\n console.log(` Variables: ${state.variables.length}`);\n\n // Show detailed lists\n if (state.tags.length > 0) {\n console.log(chalk.cyan(\"\\n🏷️ TAGS:\"));\n state.tags.forEach((tag, i) => {\n console.log(\n `${(i + 1).toString().padStart(2)}. ${tag.name} (${tag.type})`\n );\n });\n }\n\n if (state.triggers.length > 0) {\n console.log(chalk.cyan(\"\\n⚡ TRIGGERS:\"));\n state.triggers.forEach((trigger, i) => {\n console.log(\n `${(i + 1).toString().padStart(2)}. ${trigger.name} (${\n trigger.type\n })`\n );\n });\n }\n\n if (state.variables.length > 0) {\n console.log(chalk.cyan(\"\\n📝 VARIABLES:\"));\n state.variables.forEach((variable, i) => {\n console.log(\n `${(i + 1).toString().padStart(2)}. ${variable.name} (${\n variable.type\n })`\n );\n });\n }\n\n // Save to file if output specified\n if (options.output) {\n const fs = await import(\"fs/promises\");\n await fs.writeFile(options.output, JSON.stringify(state, null, 2));\n console.log(\n chalk.cyan(`\\n💾 Workspace state saved to ${options.output}`)\n );\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmSaveWorkspaceSnapshot(options: {\n file: string;\n workspace?: string;\n }): Promise<void> {\n const spinner = ora(\"Saving workspace snapshot...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // Select workspace if not specified\n if (!options.workspace && !this.clients.gtm.workspaceId) {\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(\n `Failed to select workspace: ${workspaceResult.error}`\n );\n }\n }\n\n const snapshotResult = await this.clients.gtm.saveWorkspaceSnapshot(\n options.file,\n options.workspace\n );\n if (!snapshotResult.success) {\n throw new Error(\n `Failed to save workspace snapshot: ${snapshotResult.error}`\n );\n }\n\n spinner.stop();\n\n const result = snapshotResult.data!;\n console.log(chalk.bold(`\\n✅ Workspace Snapshot Saved\\n`));\n console.log(`File: ${result.filename}`);\n console.log(\n `Workspace: ${result.state.workspaceName} (${result.state.workspaceId})`\n );\n console.log(`Tags: ${result.state.tags.length}`);\n console.log(`Triggers: ${result.state.triggers.length}`);\n console.log(`Variables: ${result.state.variables.length}`);\n console.log(\n `Timestamp: ${new Date(result.state.timestamp).toLocaleString()}`\n );\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmCompareWorkspace(options: {\n file?: string;\n withLive?: boolean;\n workspace?: string;\n output?: string;\n }): Promise<void> {\n const spinner = ora(\"Comparing workspace...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // Select workspace if not specified\n if (!options.workspace && !this.clients.gtm.workspaceId) {\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(\n `Failed to select workspace: ${workspaceResult.error}`\n );\n }\n }\n\n let compareResult;\n if (options.withLive) {\n compareResult = await this.clients.gtm.compareWorkspaceWithLive(\n options.workspace\n );\n if (!compareResult.success) {\n throw new Error(\n `Failed to compare with live version: ${compareResult.error}`\n );\n }\n } else if (options.file) {\n compareResult = await this.clients.gtm.compareWorkspaceWithSnapshot(\n options.file,\n options.workspace\n );\n if (!compareResult.success) {\n throw new Error(\n `Failed to compare with snapshot: ${compareResult.error}`\n );\n }\n } else {\n throw new Error(\"Must specify either --file <path> or --with-live\");\n }\n\n spinner.stop();\n\n const comparison = compareResult.data!;\n console.log(chalk.bold(`\\n📊 Workspace Comparison\\n`));\n\n if (options.withLive) {\n console.log(chalk.cyan(\"Current Workspace:\"));\n console.log(` Name: ${comparison.workspaceState.workspaceName}`);\n console.log(` ID: ${comparison.workspaceState.workspaceId}`);\n console.log(\n ` Snapshot: ${new Date(\n comparison.workspaceState.timestamp\n ).toLocaleString()}`\n );\n\n console.log(chalk.cyan(\"\\nLive Published Version:\"));\n console.log(\n ` Version ID: ${comparison.liveVersion.containerVersionId}`\n );\n console.log(` Name: ${comparison.liveVersion.name || \"Unnamed\"}`);\n } else {\n console.log(chalk.cyan(\"Current Workspace:\"));\n console.log(` Name: ${comparison.currentState.workspaceName}`);\n console.log(` ID: ${comparison.currentState.workspaceId}`);\n\n console.log(chalk.cyan(\"\\nSnapshot:\"));\n console.log(` Name: ${comparison.snapshotState.workspaceName}`);\n console.log(\n ` Timestamp: ${new Date(\n comparison.snapshotState.timestamp\n ).toLocaleString()}`\n );\n }\n\n const diffs = comparison.differences;\n\n console.log(chalk.bold(\"\\n📈 Changes Summary:\"));\n console.log(\n `Tags: +${diffs.tags.added.length} / -${diffs.tags.removed.length} / ~${diffs.tags.modified.length}`\n );\n console.log(\n `Triggers: +${diffs.triggers.added.length} / -${diffs.triggers.removed.length} / ~${diffs.triggers.modified.length}`\n );\n console.log(\n `Variables: +${diffs.variables.added.length} / -${diffs.variables.removed.length} / ~${diffs.variables.modified.length}`\n );\n\n // Show detailed differences\n if (diffs.tags.added.length > 0) {\n console.log(chalk.green(\"\\n➕ TAGS ADDED:\"));\n diffs.tags.added.forEach((tag, i) => {\n console.log(` ${i + 1}. ${tag.name} (${tag.type})`);\n });\n }\n\n if (diffs.tags.removed.length > 0) {\n console.log(chalk.red(\"\\n➖ TAGS REMOVED:\"));\n diffs.tags.removed.forEach((tag, i) => {\n console.log(` ${i + 1}. ${tag.name} (${tag.type})`);\n });\n }\n\n if (diffs.tags.modified.length > 0) {\n console.log(chalk.yellow(\"\\n🔄 TAGS MODIFIED:\"));\n diffs.tags.modified.forEach((tag, i) => {\n console.log(` ${i + 1}. ${tag.name} (${tag.type})`);\n });\n }\n\n if (diffs.triggers.added.length > 0) {\n console.log(chalk.green(\"\\n➕ TRIGGERS ADDED:\"));\n diffs.triggers.added.forEach((trigger, i) => {\n console.log(` ${i + 1}. ${trigger.name} (${trigger.type})`);\n });\n }\n\n if (diffs.triggers.removed.length > 0) {\n console.log(chalk.red(\"\\n➖ TRIGGERS REMOVED:\"));\n diffs.triggers.removed.forEach((trigger, i) => {\n console.log(` ${i + 1}. ${trigger.name} (${trigger.type})`);\n });\n }\n\n if (diffs.variables.added.length > 0) {\n console.log(chalk.green(\"\\n➕ VARIABLES ADDED:\"));\n diffs.variables.added.forEach((variable, i) => {\n console.log(` ${i + 1}. ${variable.name} (${variable.type})`);\n });\n }\n\n if (diffs.variables.removed.length > 0) {\n console.log(chalk.red(\"\\n➖ VARIABLES REMOVED:\"));\n diffs.variables.removed.forEach((variable, i) => {\n console.log(` ${i + 1}. ${variable.name} (${variable.type})`);\n });\n }\n\n // Save comparison to file if output specified\n if (options.output) {\n const fs = await import(\"fs/promises\");\n await fs.writeFile(options.output, JSON.stringify(comparison, null, 2));\n console.log(chalk.cyan(`\\n💾 Comparison saved to ${options.output}`));\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n // Missing GSC methods\n async gscTopKeywords(options: {\n start: string;\n end: string;\n limit?: string;\n }): Promise<void> {\n try {\n if (!this.clients.gsc) {\n const config = loadGSCConfig();\n this.clients.gsc = new GSCClient({ config });\n }\n\n const limit = parseInt(options.limit || \"50\");\n const result = await this.clients.gsc.getTopKeywords(\n options.start,\n options.end,\n limit\n );\n\n if (result.success) {\n console.log(chalk.green(\"\\n📊 Top Keywords from GSC:\"));\n console.log(\n table([\n [\"Keyword\", \"Clicks\", \"Impressions\", \"CTR (%)\", \"Position\"],\n ...result.data\n .slice(0, limit)\n .map((k) => [\n k.keyword,\n k.clicks.toString(),\n k.impressions.toString(),\n (k.ctr * 100).toFixed(2),\n k.position.toFixed(1),\n ]),\n ])\n );\n } else {\n console.error(chalk.red(\"GSC Error:\"), result.error);\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gscTopPages(options: {\n start: string;\n end: string;\n limit?: string;\n }): Promise<void> {\n try {\n if (!this.clients.gsc) {\n const config = loadGSCConfig();\n this.clients.gsc = new GSCClient({ config });\n }\n\n const result = await this.clients.gsc.getTopPages(\n options.start,\n options.end\n );\n\n if (result.success) {\n const limit = parseInt(options.limit || \"20\");\n console.log(chalk.green(\"\\n📊 Top Pages from GSC:\"));\n console.log(\n table([\n [\"Page\", \"Clicks\", \"Impressions\", \"CTR (%)\", \"Position\"],\n ...result.data\n .slice(0, limit)\n .map((p) => [\n p.page.length > 50 ? p.page.substring(0, 50) + \"...\" : p.page,\n p.clicks.toString(),\n p.impressions.toString(),\n (p.ctr * 100).toFixed(2),\n p.position.toFixed(1),\n ]),\n ])\n );\n } else {\n console.error(chalk.red(\"GSC Error:\"), result.error);\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gscComprehensiveReport(options: {\n start: string;\n end: string;\n output?: string;\n }): Promise<void> {\n try {\n if (!this.clients.gsc) {\n const config = loadGSCConfig();\n this.clients.gsc = new GSCClient({ config });\n }\n\n const authResult = await this.clients.gsc.authenticate();\n if (!authResult.success) {\n throw new Error(`GSC authentication failed: ${authResult.error}`);\n }\n\n const spinner = ora(\"Generating comprehensive GSC report...\").start();\n const result = await this.clients.gsc.getComprehensiveSEOReport(\n options.start,\n options.end\n );\n\n if (result.success && result.data) {\n spinner.succeed(\"GSC comprehensive report generated\");\n console.log(chalk.green(\"\\n📊 GSC Comprehensive Report:\"));\n console.log(chalk.blue(`Period: ${options.start} to ${options.end}`));\n\n if (result.data.summary) {\n console.log(\n chalk.blue(`Total Clicks: ${result.data.summary.totalClicks || 0}`)\n );\n console.log(\n chalk.blue(\n `Total Impressions: ${result.data.summary.totalImpressions || 0}`\n )\n );\n console.log(\n chalk.blue(\n `Average CTR: ${(\n (result.data.summary.averageCTR || 0) * 100\n ).toFixed(2)}%`\n )\n );\n console.log(\n chalk.blue(\n `Average Position: ${(\n result.data.summary.averagePosition || 0\n ).toFixed(1)}`\n )\n );\n }\n\n console.log(\n chalk.yellow(\n `\\n📈 Top Keywords: ${result.data.topKeywords?.length || 0}`\n )\n );\n console.log(\n chalk.yellow(`📄 Top Pages: ${result.data.topPages?.length || 0}`)\n );\n console.log(\n chalk.yellow(\n `🌍 Countries: ${result.data.countryPerformance?.length || 0}`\n )\n );\n console.log(\n chalk.yellow(\n `📱 Devices: ${result.data.devicePerformance?.length || 0}`\n )\n );\n console.log(\n chalk.yellow(`🗺️ Sitemaps: ${result.data.sitemaps?.length || 0}`)\n );\n console.log(\n chalk.yellow(`💬 Messages: ${result.data.messages?.length || 0}`)\n );\n\n if (options.output) {\n await fs.writeFile(\n options.output,\n JSON.stringify(result.data, null, 2)\n );\n console.log(chalk.cyan(`Report saved to ${options.output}`));\n }\n } else {\n spinner.fail(\"GSC report generation failed\");\n console.error(chalk.red(\"GSC Error:\"), result.error);\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gscEnhancedReport(options: {\n start: string;\n end: string;\n output?: string;\n includeSchema?: boolean;\n includeInspections?: boolean;\n maxKeywords?: string;\n maxPages?: string;\n maxInspections?: string;\n }): Promise<void> {\n try {\n if (!this.clients.gsc) {\n const config = loadGSCConfig();\n this.clients.gsc = new GSCClient({ config });\n }\n\n const authResult = await this.clients.gsc.authenticate();\n if (!authResult.success) {\n throw new Error(`GSC authentication failed: ${authResult.error}`);\n }\n\n const spinner = ora(\n \"Generating enhanced GSC report with schema analysis...\"\n ).start();\n\n // Prepare options for the new comprehensive report\n const reportOptions = {\n startDate: options.start,\n endDate: options.end,\n includeSchemaAnalysis: options.includeSchema !== false, // Default true\n includeUrlInspections: options.includeInspections !== false, // Default true\n maxKeywords: parseInt(options.maxKeywords || \"100\"),\n maxPages: parseInt(options.maxPages || \"50\"),\n maxUrlInspections: parseInt(options.maxInspections || \"10\"),\n };\n\n const result = await this.clients.gsc.generateComprehensiveReport(\n reportOptions\n );\n\n if (result.success && result.data) {\n spinner.succeed(\"Enhanced GSC report generated\");\n\n const report = result.data;\n\n console.log(\n chalk.green(\"\\n📊 Enhanced GSC Report with Schema Analysis\")\n );\n console.log(chalk.blue(`Site: ${report.siteUrl}`));\n console.log(\n chalk.blue(\n `Period: ${report.period.startDate} to ${report.period.endDate}`\n )\n );\n console.log(\n chalk.blue(\n `Generated: ${new Date(report.reportDate).toLocaleString()}`\n )\n );\n\n // Summary Section\n console.log(chalk.yellow(\"\\n📈 PERFORMANCE SUMMARY\"));\n console.log(` Total Clicks: ${report.summary.totalClicks}`);\n console.log(` Total Impressions: ${report.summary.totalImpressions}`);\n console.log(\n ` Average CTR: ${(report.summary.averageCTR * 100).toFixed(2)}%`\n );\n console.log(\n ` Average Position: ${report.summary.averagePosition.toFixed(1)}`\n );\n\n // Change from previous period\n if (report.summary.changeFromPrevious) {\n const change = report.summary.changeFromPrevious;\n console.log(\"\\n 📊 Changes from Previous Period:\");\n console.log(\n ` Clicks: ${change.clicks >= 0 ? \"+\" : \"\"}${change.clicks}`\n );\n console.log(\n ` Impressions: ${change.impressions >= 0 ? \"+\" : \"\"}${\n change.impressions\n }`\n );\n console.log(\n ` CTR: ${change.ctr >= 0 ? \"+\" : \"\"}${(change.ctr * 100).toFixed(\n 2\n )}%`\n );\n console.log(\n ` Position: ${\n change.position >= 0 ? \"+\" : \"\"\n }${change.position.toFixed(1)}`\n );\n }\n\n // Schema Analysis Section\n console.log(chalk.yellow(\"\\n🔍 SCHEMA ANALYSIS\"));\n console.log(` Schema Messages: ${report.schemaMessages.length}`);\n console.log(` URL Inspections: ${report.urlInspections.length}`);\n console.log(` Schema Issues: ${report.analysis.schemaIssuesCount}`);\n console.log(` Error Messages: ${report.analysis.errorMessagesCount}`);\n console.log(\n ` Warning Messages: ${report.analysis.warningMessagesCount}`\n );\n\n // Critical Issues\n if (report.analysis.criticalIssues.length > 0) {\n console.log(chalk.red(\"\\n🚨 CRITICAL ISSUES\"));\n report.analysis.criticalIssues.forEach((issue, index) => {\n console.log(` ${index + 1}. ${issue}`);\n });\n }\n\n // Schema Messages Detail\n if (report.schemaMessages.length > 0) {\n console.log(chalk.yellow(\"\\n📝 SCHEMA-RELATED MESSAGES\"));\n report.schemaMessages.slice(0, 5).forEach((msg, index) => {\n const severityColor =\n msg.severity === \"ERROR\"\n ? \"red\"\n : msg.severity === \"WARNING\"\n ? \"yellow\"\n : \"blue\";\n console.log(\n ` ${index + 1}. [${chalk[severityColor](msg.severity)}] ${\n msg.subject\n }`\n );\n console.log(` Keywords: ${msg.matchedKeywords.join(\", \")}`);\n if (msg.extractedUrls.length > 0) {\n console.log(` URLs: ${msg.extractedUrls.length} found`);\n }\n });\n\n if (report.schemaMessages.length > 5) {\n console.log(\n ` ... and ${report.schemaMessages.length - 5} more messages`\n );\n }\n }\n\n // URL Inspections Detail\n if (report.urlInspections.length > 0) {\n console.log(chalk.yellow(\"\\n🔍 URL INSPECTION RESULTS\"));\n report.urlInspections.slice(0, 5).forEach((inspection, index) => {\n console.log(` ${index + 1}. ${inspection.url}`);\n console.log(` Rich Results: ${inspection.richResultsVerdict}`);\n console.log(\n ` Mobile Usability: ${inspection.mobileUsabilityVerdict}`\n );\n console.log(` Indexing State: ${inspection.indexingState}`);\n console.log(\n ` Schema Issues: ${inspection.schemaIssues.length}`\n );\n\n if (inspection.schemaIssues.length > 0) {\n inspection.schemaIssues.slice(0, 3).forEach((issue) => {\n const severityColor =\n issue.severity === \"ERROR\" ? \"red\" : \"yellow\";\n console.log(\n ` [${chalk[severityColor](issue.severity)}] ${\n issue.message\n }`\n );\n });\n }\n });\n\n if (report.urlInspections.length > 5) {\n console.log(\n ` ... and ${\n report.urlInspections.length - 5\n } more inspections`\n );\n }\n }\n\n // Top Performance Data Summary\n console.log(chalk.yellow(\"\\n📊 TOP PERFORMANCE DATA\"));\n console.log(` Keywords: ${report.topKeywords.length}`);\n console.log(` Pages: ${report.topPages.length}`);\n console.log(` Countries: ${report.countryPerformance.length}`);\n console.log(` Devices: ${report.devicePerformance.length}`);\n console.log(` Sitemaps: ${report.sitemaps.length}`);\n console.log(` Total Messages: ${report.messages.length}`);\n\n // Recommendations\n if (report.analysis.recommendations.length > 0) {\n console.log(chalk.green(\"\\n💡 RECOMMENDATIONS\"));\n report.analysis.recommendations.forEach((rec, index) => {\n console.log(` ${index + 1}. ${rec}`);\n });\n }\n\n // Save to file if requested\n if (options.output) {\n const fs = await import(\"fs/promises\");\n await fs.writeFile(options.output, JSON.stringify(report, null, 2));\n console.log(\n chalk.cyan(`\\n💾 Enhanced report saved to ${options.output}`)\n );\n }\n\n console.log(\n chalk.green(\"\\n✅ Enhanced GSC report generation complete!\")\n );\n } else {\n spinner.fail(\"Enhanced GSC report generation failed\");\n console.error(chalk.red(\"GSC Error:\"), result.error);\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n // Missing Google Ads methods\n async googleAdsKeywords(options: {\n start: string;\n end: string;\n customerId?: string;\n }): Promise<void> {\n try {\n const config = loadGoogleAdsConfig();\n if (!this.clients.googleAds) {\n this.clients.googleAds = new GoogleAdsClient(config);\n }\n\n const result = await this.clients.googleAds.getKeywordPerformanceReport({\n startDate: options.start,\n endDate: options.end,\n customerId: options.customerId,\n });\n\n if (result.success) {\n console.log(chalk.green(\"\\n📊 Google Ads Keywords:\"));\n console.log(\n table([\n [\"Keyword\", \"Impressions\", \"Clicks\", \"CTR (%)\", \"CPC (CHF)\"],\n ...result.data\n .slice(0, 20)\n .map((k: any) => [\n k.keyword || \"N/A\",\n k.impressions?.toString() || \"0\",\n k.clicks?.toString() || \"0\",\n k.ctr ? (k.ctr * 100).toFixed(2) : \"0.00\",\n k.averageCpc ? (k.averageCpc / 1000000).toFixed(2) : \"0.00\",\n ]),\n ])\n );\n } else {\n console.error(chalk.red(\"Google Ads Error:\"), result.error);\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async googleAdsSearchTerms(options: {\n start: string;\n end: string;\n customerId?: string;\n }): Promise<void> {\n try {\n const config = loadGoogleAdsConfig();\n if (!this.clients.googleAds) {\n this.clients.googleAds = new GoogleAdsClient(config);\n }\n\n const result = await this.clients.googleAds.getSearchTermsReport({\n startDate: options.start,\n endDate: options.end,\n customerId: options.customerId,\n });\n\n if (result.success) {\n console.log(chalk.green(\"\\n📊 Google Ads Search Terms:\"));\n console.log(\n table([\n [\"Search Term\", \"Impressions\", \"Clicks\", \"CTR (%)\", \"Conversions\"],\n ...result.data\n .slice(0, 20)\n .map((t: any) => [\n t.searchTerm || \"N/A\",\n t.impressions?.toString() || \"0\",\n t.clicks?.toString() || \"0\",\n t.ctr ? (t.ctr * 100).toFixed(2) : \"0.00\",\n t.conversions?.toString() || \"0\",\n ]),\n ])\n );\n } else {\n console.error(chalk.red(\"Google Ads Error:\"), result.error);\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async googleAdsComprehensiveReport(options: {\n start: string;\n end: string;\n output?: string;\n }): Promise<void> {\n try {\n const config = loadGoogleAdsConfig();\n if (!this.clients.googleAds) {\n this.clients.googleAds = new GoogleAdsClient(config);\n }\n\n const spinner = ora(\n \"Generating comprehensive Google Ads report...\"\n ).start();\n const result = await this.clients.googleAds.getComprehensiveAdsReport(\n options.start,\n options.end\n );\n\n if (result.success) {\n spinner.succeed(\"Google Ads comprehensive report generated\");\n console.log(chalk.green(\"\\n📊 Google Ads Comprehensive Report:\"));\n console.log(chalk.blue(`Period: ${options.start} to ${options.end}`));\n console.log(\n chalk.blue(\n `Total Spend: CHF ${(result.data.totalSpend / 1000000).toFixed(2)}`\n )\n );\n console.log(chalk.blue(`Total Clicks: ${result.data.totalClicks}`));\n console.log(\n chalk.blue(`Total Impressions: ${result.data.totalImpressions}`)\n );\n console.log(\n chalk.blue(\n `Average CPC: CHF ${(result.data.averageCpc / 1000000).toFixed(2)}`\n )\n );\n console.log(\n chalk.blue(`Total Conversions: ${result.data.totalConversions}`)\n );\n\n if (options.output) {\n await fs.writeFile(\n options.output,\n JSON.stringify(result.data, null, 2)\n );\n console.log(chalk.cyan(`Report saved to ${options.output}`));\n }\n } else {\n spinner.fail(\"Google Ads report generation failed\");\n console.error(chalk.red(\"Google Ads Error:\"), result.error);\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n // Missing Meta methods (placeholder implementations)\n async metaCampaigns(options: { start: string; end: string }): Promise<void> {\n console.log(\n chalk.yellow(\n \"⚠️ Meta Ads functionality requires @akson/cortex-meta-ads package and META_ACCESS_TOKEN\"\n )\n );\n console.log(\n chalk.cyan(\n \"Configure environment variables to enable Meta Ads reporting.\"\n )\n );\n }\n\n async metaConversions(options: {\n start: string;\n end: string;\n }): Promise<void> {\n console.log(\n chalk.yellow(\n \"⚠️ Meta Ads functionality requires @akson/cortex-meta-ads package and META_ACCESS_TOKEN\"\n )\n );\n console.log(\n chalk.cyan(\n \"Configure environment variables to enable Meta Ads reporting.\"\n )\n );\n }\n\n async metaInsights(options: { start: string; end: string }): Promise<void> {\n console.log(\n chalk.yellow(\n \"⚠️ Meta Ads functionality requires @akson/cortex-meta-ads package and META_ACCESS_TOKEN\"\n )\n );\n console.log(\n chalk.cyan(\n \"Configure environment variables to enable Meta Ads reporting.\"\n )\n );\n }\n\n // Missing SEO methods (placeholder implementations)\n async seoAudit(options: { url: string; device?: string }): Promise<void> {\n console.log(\n chalk.yellow(\n \"⚠️ SEO audit functionality requires @akson/cortex-seo package with lighthouse dependencies\"\n )\n );\n console.log(\n chalk.cyan(`Would audit: ${options.url} (${options.device || \"mobile\"})`)\n );\n console.log(\n chalk.cyan(\n \"Install lighthouse and puppeteer dependencies to enable SEO auditing.\"\n )\n );\n }\n\n async seoCoreWebVitals(options: { url: string }): Promise<void> {\n console.log(\n chalk.yellow(\n \"⚠️ Core Web Vitals analysis requires @akson/cortex-seo package with lighthouse\"\n )\n );\n console.log(\n chalk.cyan(`Would analyze Core Web Vitals for: ${options.url}`)\n );\n console.log(\n chalk.cyan(\n \"Install lighthouse dependencies to enable Core Web Vitals analysis.\"\n )\n );\n }\n\n async seoSchemaValidation(options: { url: string }): Promise<void> {\n console.log(\n chalk.yellow(\"⚠️ Schema validation requires @akson/cortex-seo package\")\n );\n console.log(chalk.cyan(`Would validate schema for: ${options.url}`));\n console.log(\n chalk.cyan(\"Configure @akson/cortex-seo to enable schema validation.\")\n );\n }\n\n async seoGEOAnalysis(options: { url: string }): Promise<void> {\n console.log(\n chalk.yellow(\"⚠️ GEO analysis requires @akson/cortex-seo package\")\n );\n console.log(\n chalk.cyan(`Would analyze GEO optimization for: ${options.url}`)\n );\n console.log(\n chalk.cyan(\"Configure @akson/cortex-seo to enable GEO analysis.\")\n );\n }\n\n // Missing specialized analysis methods\n async keywordResearch(options: {\n start: string;\n end: string;\n market?: string;\n }): Promise<void> {\n console.log(chalk.blue(\"\\n🇨🇭 Swiss Military Keyword Research\"));\n console.log(\n chalk.cyan(\n \"This would combine GSC, Google Ads, and market analysis for Swiss military keywords\"\n )\n );\n console.log(chalk.cyan(`Period: ${options.start} to ${options.end}`));\n console.log(chalk.cyan(`Market: ${options.market || \"swiss-military\"}`));\n\n const swissKeywords = [\n \"militär badge\",\n \"funktionsabzeichen\",\n \"rekrutenschule souvenir\",\n \"schweizer armee\",\n \"military patches switzerland\",\n \"custom badges switzerland\",\n \"abzeichen schweizer armee\",\n \"militärische abzeichen\",\n \"truppenabzeichen\",\n ];\n\n console.log(chalk.yellow(\"\\n📊 Key Swiss Military Keywords to Track:\"));\n swissKeywords.forEach((keyword, i) => {\n console.log(` ${i + 1}. \"${keyword}\"`);\n });\n\n console.log(\n chalk.cyan(\n \"\\nConfigure GSC_SITE_URL and other env vars to get real keyword data.\"\n )\n );\n }\n\n async generateMyArmyReport(options: {\n start: string;\n end: string;\n url?: string;\n output?: string;\n }): Promise<void> {\n console.log(chalk.blue(\"\\n🎯 MyArmy.ch Comprehensive Optimization Report\"));\n console.log(chalk.cyan(`Period: ${options.start} to ${options.end}`));\n console.log(chalk.cyan(`URL: ${options.url || \"https://myarmy.ch\"}`));\n\n console.log(chalk.green(\"\\n✅ Analysis Areas:\"));\n console.log(\" 📊 Traffic Analysis - Swiss military keyword performance\");\n console.log(\" 🎯 Conversion Funnel - Lead generation optimization\");\n console.log(\" 🔍 SEO Performance - Search visibility for military terms\");\n console.log(\" 🤖 GEO Optimization - AI search engine performance\");\n console.log(\" 📱 Mobile UX - Swiss mobile market optimization\");\n console.log(\" 🇨🇭 Swiss Market Focus - Local military terminology\");\n\n console.log(\n chalk.yellow(\n \"\\n⚠️ Full report requires configured environment variables:\"\n )\n );\n console.log(\" - GSC_SITE_URL for search performance\");\n console.log(\" - GOOGLE_ADS_CUSTOMER_ID for ads analysis\");\n console.log(\" - POSTHOG_API_KEY for user behavior\");\n console.log(\" - GTM_CONTAINER_ID for conversion tracking\");\n\n if (options.output) {\n const reportData = {\n period: { start: options.start, end: options.end },\n url: options.url || \"https://myarmy.ch\",\n analysis: {\n seo: \"Requires GSC configuration\",\n ads: \"Requires Google Ads configuration\",\n analytics: \"Requires PostHog configuration\",\n conversions: \"GTM configured ✅\",\n },\n recommendations: [\n \"Configure missing environment variables\",\n \"Enable AI crawler access (already done ✅)\",\n \"Optimize for Swiss military keywords\",\n \"Improve mobile conversion funnel\",\n \"Enhance GEO for AI search engines\",\n ],\n };\n\n await fs.writeFile(options.output, JSON.stringify(reportData, null, 2));\n console.log(chalk.cyan(`\\nReport template saved to ${options.output}`));\n }\n }\n\n async trafficAnalysis(options: {\n start: string;\n end: string;\n url?: string;\n }): Promise<void> {\n console.log(chalk.blue(\"\\n📈 Traffic Analysis for MyArmy.ch\"));\n console.log(chalk.cyan(`Period: ${options.start} to ${options.end}`));\n console.log(chalk.cyan(`URL: ${options.url || \"https://myarmy.ch\"}`));\n\n console.log(chalk.green(\"\\n🔍 Analysis Focus:\"));\n console.log(\" 🇨🇭 Swiss military keyword traffic\");\n console.log(\" 📱 Mobile vs desktop performance\");\n console.log(\" 🎯 Conversion funnel efficiency\");\n console.log(\" 🤖 AI search engine referrals\");\n console.log(\" ⚡ Page load performance impact\");\n\n console.log(\n chalk.yellow(\n \"\\n⚠️ Configure analytics platforms for detailed traffic analysis.\"\n )\n );\n }\n\n async googleAdsHistorical(options: {\n start: string;\n end: string;\n customerId?: string;\n granularity?: string;\n detectAnomalies?: boolean;\n analyzeTrends?: boolean;\n analyzeSeasonality?: boolean;\n output?: string;\n outputFile?: string;\n }): Promise<void> {\n const spinner = ora(\"Performing historical Google Ads analysis...\").start();\n\n try {\n // Initialize Google Ads client if needed\n if (!this.clients.googleAds) {\n const config = loadGoogleAdsConfig();\n this.clients.googleAds = new GoogleAdsClient({ config });\n }\n\n await this.clients.googleAds.authenticate();\n\n // Create historical analyzer\n const analyzer = new HistoricalAnalyzer(this.clients.googleAds);\n\n // Perform analysis\n const result = await analyzer.analyze({\n dateRange: {\n startDate: options.start,\n endDate: options.end,\n },\n granularity:\n (options.granularity as \"daily\" | \"weekly\" | \"monthly\") || \"daily\",\n detectAnomalies: options.detectAnomalies || false,\n analyzeTrends: options.analyzeTrends || false,\n });\n\n spinner.succeed(\"Historical analysis completed\");\n\n // Display results\n console.log(chalk.blue(\"\\n📊 Historical Google Ads Analysis\"));\n console.log(chalk.cyan(`Period: ${options.start} to ${options.end}`));\n console.log(chalk.cyan(`Granularity: ${options.granularity || \"daily\"}`));\n\n if (result.success && result.data) {\n const analysis = result.data;\n\n console.log(chalk.green(\"\\n📈 Performance Summary:\"));\n console.log(` Data points: ${analysis.timeSeriesData.length}`);\n console.log(\n ` Date range: ${analysis.dateRange.startDate} to ${analysis.dateRange.endDate}`\n );\n\n if (analysis.anomalies && analysis.anomalies.length > 0) {\n console.log(\n chalk.yellow(\n `\\n⚠️ Anomalies Detected: ${analysis.anomalies.length}`\n )\n );\n analysis.anomalies.forEach((anomaly, index) => {\n console.log(\n ` ${index + 1}. ${anomaly.date}: ${anomaly.metric} = ${\n anomaly.value\n } (${anomaly.severity})`\n );\n console.log(` ${anomaly.description}`);\n });\n }\n\n if (analysis.trends) {\n console.log(chalk.blue(\"\\n📊 Trend Analysis:\"));\n Object.entries(analysis.trends).forEach(([metric, trend]) => {\n const direction =\n trend.slope > 0 ? \"📈\" : trend.slope < 0 ? \"📉\" : \"➡️\";\n console.log(\n ` ${direction} ${metric}: ${\n trend.slope > 0\n ? \"Increasing\"\n : trend.slope < 0\n ? \"Decreasing\"\n : \"Stable\"\n } (R²: ${trend.rSquared.toFixed(3)})`\n );\n });\n }\n\n // Save to file if requested\n if (options.outputFile) {\n const outputData =\n options.output === \"csv\"\n ? this.formatAsCSV(analysis.timeSeriesData)\n : JSON.stringify(analysis, null, 2);\n\n await fs.writeFile(options.outputFile, outputData);\n console.log(\n chalk.green(`\\n✅ Results saved to ${options.outputFile}`)\n );\n }\n } else {\n console.log(chalk.red(\"\\n❌ Analysis failed:\"), result.error);\n }\n } catch (error) {\n spinner.fail(\"Historical analysis failed\");\n console.error(\n chalk.red(\"\\n❌ Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async googleAdsSwissMarket(options: {\n start?: string;\n end?: string;\n customerId?: string;\n includeCompetitors?: boolean;\n analyzeSeasonality?: boolean;\n opportunityAnalysis?: boolean;\n output?: string;\n outputFile?: string;\n }): Promise<void> {\n const spinner = ora(\"Analyzing Swiss military market...\").start();\n\n try {\n // Initialize Google Ads client if needed\n if (!this.clients.googleAds) {\n const config = loadGoogleAdsConfig();\n this.clients.googleAds = new GoogleAdsClient({ config });\n }\n\n await this.clients.googleAds.authenticate();\n\n // Create Swiss market analyzer\n const analyzer = new SwissMarketAnalyzer(this.clients.googleAds);\n\n // Perform analysis - use provided dates or default to last 30 days\n const endDate = options.end || new Date().toISOString().split(\"T\")[0]; // Today\n const startDate =\n options.start ||\n new Date(Date.now() - 30 * 24 * 60 * 60 * 1000)\n .toISOString()\n .split(\"T\")[0]; // 30 days ago\n\n const result = await analyzer.analyze({\n startDate,\n endDate,\n includeCompetitors: options.includeCompetitors || false,\n analyzeSeasonality: options.analyzeSeasonality || false,\n });\n\n spinner.succeed(\"Swiss market analysis completed\");\n\n // Display results\n console.log(chalk.blue(\"\\n🇨🇭 Swiss Military Market Analysis\"));\n\n if (result.success && result.data) {\n const analysis = result.data;\n\n console.log(chalk.green(\"\\n🎯 Keyword Performance:\"));\n if (\n analysis.keywordPerformance &&\n analysis.keywordPerformance.length > 0\n ) {\n const topKeywords = analysis.keywordPerformance.slice(0, 10);\n topKeywords.forEach((keyword, index) => {\n const cost = keyword.metrics?.cpc\n ? keyword.metrics.cpc.toFixed(2)\n : \"0.00\";\n const impressions = keyword.metrics?.impressions || 0;\n const clicks = keyword.metrics?.clicks || 0;\n console.log(\n ` ${index + 1}. \"${\n keyword.keyword\n }\": ${impressions} impressions, ${clicks} clicks, CHF ${cost}`\n );\n });\n } else {\n console.log(\" No keyword performance data available\");\n }\n\n if (\n options.includeCompetitors &&\n analysis.competitorAnalysis &&\n analysis.competitorAnalysis.length > 0\n ) {\n console.log(chalk.yellow(\"\\n🏢 Competitor Analysis:\"));\n analysis.competitorAnalysis.forEach((competitor, index) => {\n const overlapScore = competitor.overlapScore || 0;\n const marketShare = competitor.marketShare || 0;\n console.log(\n ` ${index + 1}. ${\n competitor.domain\n }: Overlap Score ${overlapScore}%, Market Share ${marketShare}%`\n );\n });\n }\n\n if (\n options.opportunityAnalysis &&\n analysis.opportunities &&\n analysis.opportunities.length > 0\n ) {\n console.log(chalk.cyan(\"\\n💡 Market Opportunities:\"));\n analysis.opportunities.forEach((opportunity, index) => {\n console.log(\n ` ${index + 1}. ${opportunity.keyword}: ${\n opportunity.opportunityType\n } (Score: ${opportunity.opportunityScore})`\n );\n console.log(` ${opportunity.recommendation}`);\n });\n }\n\n // Save to file if requested\n if (options.outputFile) {\n const outputData =\n options.output === \"csv\"\n ? this.formatSwissMarketAsCSV(analysis)\n : JSON.stringify(analysis, null, 2);\n\n await fs.writeFile(options.outputFile, outputData);\n console.log(\n chalk.green(`\\n✅ Results saved to ${options.outputFile}`)\n );\n }\n } else {\n console.log(chalk.red(\"\\n❌ Analysis failed:\"), result.error);\n }\n } catch (error) {\n spinner.fail(\"Swiss market analysis failed\");\n console.error(\n chalk.red(\"\\n❌ Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n private formatAsCSV(data: any[]): string {\n if (data.length === 0) return \"\";\n\n const headers = Object.keys(data[0]);\n const rows = data.map((item) =>\n headers.map((header) => item[header] || \"\").join(\",\")\n );\n\n return [headers.join(\",\"), ...rows].join(\"\\n\");\n }\n\n private formatSwissMarketAsCSV(analysis: any): string {\n const keywordRows = analysis.keywordPerformance.map(\n (k: any) =>\n `${k.keyword},${k.impressions},${k.clicks},${k.cost},${k.ctr},${k.position}`\n );\n\n return [\n \"keyword,impressions,clicks,cost,ctr,position\",\n ...keywordRows,\n ].join(\"\\n\");\n }\n}\n","/**\n * @akson/cortex-analytics Help System\n *\n * Comprehensive help and documentation functions\n */\n\nimport chalk from \"chalk\";\nimport { table } from \"table\";\n\nexport interface CommandHelp {\n command: string;\n description: string;\n usage: string;\n examples: string[];\n options?: { flag: string; description: string; default?: string }[];\n}\n\nexport interface ModuleHelp {\n module: string;\n description: string;\n commands: CommandHelp[];\n dependencies?: string[];\n}\n\n/**\n * Get version information\n */\nexport function getVersion(): string {\n try {\n const pkg = require(\"../package.json\");\n return pkg.version;\n } catch {\n return \"0.0.0\";\n }\n}\n\n/**\n * Display comprehensive help for the entire CLI\n */\nexport function showComprehensiveHelp(): void {\n const version = getVersion();\n\n console.log(\n chalk.cyan.bold(`\n@akson/cortex-analytics v${version}\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n\n🚀 Unified CLI for MyArmy Analytics Operations\n\nQUICK START:\n npx @akson/cortex-analytics health --verbose # Check all platform health\n npx @akson/cortex-analytics setup # Interactive setup\n npx @akson/cortex-analytics myarmy-report --start 2024-01-01 --end 2024-01-31\n\nMAIN COMMANDS:\n`)\n );\n\n const mainCommands = [\n [\"health\", \"Check health of all analytics platforms\", \"health --verbose\"],\n [\"setup\", \"Interactive configuration setup\", \"setup\"],\n [\n \"dashboard\",\n \"Generate unified analytics dashboard\",\n \"dashboard -s 2024-01-01 -e 2024-01-31\",\n ],\n [\n \"analyze\",\n \"Cross-platform analytics analysis\",\n \"analyze -s 2024-01-01 -e 2024-01-31 -p posthog gsc\",\n ],\n [\n \"myarmy-report\",\n \"Comprehensive MyArmy.ch optimization report\",\n \"myarmy-report -s 2024-01-01 -e 2024-01-31\",\n ],\n ];\n\n console.log(\n table(mainCommands, {\n header: {\n alignment: \"left\",\n content: `${chalk.bold(\"Command\")} | ${chalk.bold(\n \"Description\"\n )} | ${chalk.bold(\"Example\")}`,\n },\n border: {\n topBody: `─`,\n topJoin: `┬`,\n topLeft: `┌`,\n topRight: `┐`,\n bottomBody: `─`,\n bottomJoin: `┴`,\n bottomLeft: `└`,\n bottomRight: `┘`,\n bodyLeft: `│`,\n bodyRight: `│`,\n bodyJoin: `│`,\n joinBody: `─`,\n joinLeft: `├`,\n joinRight: `┤`,\n joinJoin: `┼`,\n },\n })\n );\n\n console.log(\n chalk.cyan(`\nPLATFORM-SPECIFIC COMMANDS:\n gtm # Google Tag Manager operations\n gsc # Google Search Console operations \n gads # Google Ads operations\n posthog # PostHog analytics operations\n meta # Meta/Facebook Ads operations\n seo # SEO analysis and optimization\n\nUTILITY COMMANDS:\n events standardize # Standardize events across platforms\n keyword-research # Research keywords across platforms\n traffic-analysis # Analyze traffic patterns\n\nFor detailed help on any command: akson [command] --help\nDocumentation: https://docs.myarmy.ch/akson/cli-analytics\n`)\n );\n}\n\n/**\n * Show quick start guide\n */\nexport function showQuickStart(): void {\n console.log(\n chalk.green.bold(`\n🚀 @akson/cortex-analytics Quick Start Guide\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n\n1. Setup (First Time):\n ${chalk.cyan(\"npx @akson/cortex-analytics setup\")}\n\n2. Health Check:\n ${chalk.cyan(\"npx @akson/cortex-analytics health --verbose\")}\n\n3. Generate Dashboard:\n ${chalk.cyan(\n \"npx @akson/cortex-analytics dashboard -s 2024-01-01 -e 2024-01-31\"\n )}\n\n4. MyArmy Swiss Market Report:\n ${chalk.cyan(\n \"npx @akson/cortex-analytics myarmy-report -s 2024-01-01 -e 2024-01-31\"\n )}\n\n5. Swiss Military Keywords:\n ${chalk.cyan(\n \"npx @akson/cortex-analytics keyword-research -k 'militär badge' 'funktionsabzeichen' -s 2024-01-01 -e 2024-01-31\"\n )}\n\n6. GTM Configuration:\n ${chalk.cyan(\"npx @akson/cortex-analytics gtm validate\")}\n ${chalk.cyan(\"npx @akson/cortex-analytics gtm plan\")}\n ${chalk.cyan(\"npx @akson/cortex-analytics gtm apply\")}\n\nNeed help? Run: ${chalk.yellow(\"akson [command] --help\")}\n`)\n );\n}\n\n/**\n * Show Swiss military market specific help\n */\nexport function showSwissMarketHelp(): void {\n console.log(\n chalk.green.bold(`\n🇨🇭 Swiss Military Market Analytics - MyArmy.ch\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n\nSWISS KEYWORDS (Primary):\n • militär badge\n • funktionsabzeichen \n • rekrutenschule souvenir\n • schweizer armee\n • abzeichen schweizer armee\n\nSWISS KEYWORDS (Secondary):\n • military patches switzerland\n • custom badges switzerland\n • militärische abzeichen\n • truppenabzeichen\n • swiss army patches\n • schweizer militär merchandise\n\nSWISS MARKET ANALYSIS:\n ${chalk.cyan(\n \"akson gads swiss-market --start 2024-01-01 --end 2024-01-31 --analyze-seasonality\"\n )}\n\nGSC RANKINGS (Swiss Keywords):\n ${chalk.cyan(\n \"akson gsc rankings -k 'militär badge' 'funktionsabzeichen' 'schweizer armee' -s 2024-01-01 -e 2024-01-31\"\n )}\n\nCOMPREHENSIVE MYARMY REPORT:\n ${chalk.cyan(\n \"akson myarmy-report -s 2024-01-01 -e 2024-01-31 --output file --file myarmy-optimization.json\"\n )}\n\nSWISS TRAFFIC ANALYSIS:\n ${chalk.cyan(\n \"akson traffic-analysis -s 2024-01-01 -e 2024-01-31 -u https://myarmy.ch\"\n )}\n`)\n );\n}\n\n/**\n * Show platform status and configuration help\n */\nexport function showPlatformStatus(): void {\n console.log(\n chalk.blue.bold(`\n📊 Platform Configuration Status\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n\nPLATFORM CONFIGURATION:\n`)\n );\n\n const platforms = [\n [\"GTM\", \"✅ Connected\", \"GTM-T8WRBMWV\", \"Google Service Account\"],\n [\"GSC\", \"✅ Connected\", \"https://myarmy.ch\", \"Google Service Account\"],\n [\"Google Ads\", \"✅ Connected\", \"8847935674\", \"Google Service Account\"],\n [\"PostHog\", \"✅ Connected\", \"phc_Y8vb...\", \"API Key\"],\n [\"Meta Ads\", \"⚠️ Optional\", \"Not configured\", \"META_ACCESS_TOKEN needed\"],\n ];\n\n console.log(\n table(platforms, {\n header: {\n alignment: \"left\",\n content: `${chalk.bold(\"Platform\")} | ${chalk.bold(\n \"Status\"\n )} | ${chalk.bold(\"Config\")} | ${chalk.bold(\"Auth Method\")}`,\n },\n })\n );\n\n console.log(\n chalk.blue(`\nENVIRONMENT SETUP:\n Run: ${chalk.cyan(\"npx @akson/cortex-analytics setup\")}\n Or manually set environment variables in packages/@akson/cortex-.env\n\nHEALTH CHECK:\n Run: ${chalk.cyan(\"npx @akson/cortex-analytics health --verbose\")}\n\nFor platform-specific help:\n • GTM: akson gtm --help\n • GSC: akson gsc --help \n • Google Ads: akson gads --help\n • PostHog: akson posthog --help\n`)\n );\n}\n\n/**\n * Get all available commands and their descriptions\n */\nexport function getCommands(): ModuleHelp[] {\n return [\n {\n module: \"Core Commands\",\n description: \"Essential analytics operations\",\n commands: [\n {\n command: \"health\",\n description: \"Check health of all analytics platforms\",\n usage: \"akson health [options]\",\n examples: [\"akson health --verbose\", \"akson health\"],\n options: [\n {\n flag: \"-v, --verbose\",\n description: \"Show detailed health information\",\n },\n ],\n },\n {\n command: \"setup\",\n description: \"Interactive setup for analytics configuration\",\n usage: \"akson setup\",\n examples: [\"akson setup\"],\n },\n {\n command: \"dashboard\",\n description: \"Generate unified analytics dashboard\",\n usage: \"akson dashboard [options]\",\n examples: [\n \"akson dashboard -s 2024-01-01 -e 2024-01-31\",\n \"akson dashboard -s 2024-01-01 -e 2024-01-31 --output json\",\n ],\n options: [\n {\n flag: \"-s, --start <date>\",\n description: \"Start date (YYYY-MM-DD)\",\n },\n { flag: \"-e, --end <date>\", description: \"End date (YYYY-MM-DD)\" },\n {\n flag: \"-o, --output <format>\",\n description: \"Output format (json|table)\",\n default: \"table\",\n },\n ],\n },\n ],\n },\n {\n module: \"GTM Operations\",\n description: \"Google Tag Manager configuration and management\",\n commands: [\n {\n command: \"gtm validate\",\n description: \"Validate GTM configuration file\",\n usage: \"akson gtm validate [options]\",\n examples: [\n \"akson gtm validate\",\n \"akson gtm validate -c custom.config.yaml\",\n ],\n options: [\n {\n flag: \"-c, --config <path>\",\n description: \"Configuration file path\",\n default: \"gtm.config.yaml\",\n },\n ],\n },\n {\n command: \"gtm plan\",\n description: \"Show changes that would be applied to GTM\",\n usage: \"akson gtm plan [options]\",\n examples: [\n \"akson gtm plan\",\n \"akson gtm plan -c gtm.config.yaml -o plan.json\",\n ],\n },\n {\n command: \"gtm apply\",\n description: \"Apply GTM configuration changes\",\n usage: \"akson gtm apply [options]\",\n examples: [\"akson gtm apply\", \"akson gtm apply --yes --verbose\"],\n },\n ],\n dependencies: [\"@akson/cortex-gtm\", \"Google Service Account Key\"],\n },\n {\n module: \"Swiss Market Analytics\",\n description: \"Specialized Swiss military market analysis\",\n commands: [\n {\n command: \"myarmy-report\",\n description: \"Generate comprehensive MyArmy.ch optimization report\",\n usage: \"akson myarmy-report [options]\",\n examples: [\n \"akson myarmy-report -s 2024-01-01 -e 2024-01-31\",\n \"akson myarmy-report -s 2024-01-01 -e 2024-01-31 --output file --file report.json\",\n ],\n },\n {\n command: \"keyword-research\",\n description: \"Research Swiss military keywords across platforms\",\n usage: \"akson keyword-research [options]\",\n examples: [\n \"akson keyword-research -k 'militär badge' 'funktionsabzeichen' -s 2024-01-01 -e 2024-01-31\",\n \"akson keyword-research -k 'swiss army patches' -s 2024-01-01 -e 2024-01-31 -c CH\",\n ],\n },\n ],\n },\n ];\n}\n\n/**\n * Show examples for common use cases\n */\nexport function showExamples(): void {\n console.log(\n chalk.magenta.bold(`\n💡 Common Use Cases & Examples\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n\n🔍 DAILY MONITORING:\n ${chalk.cyan(\"akson health --verbose\")}\n ${chalk.cyan(\"akson dashboard -s 2024-01-01 -e 2024-01-31\")}\n\n🇨🇭 SWISS MARKET ANALYSIS:\n ${chalk.cyan(\n \"akson keyword-research -k 'militär badge' 'funktionsabzeichen' -s 2024-01-01 -e 2024-01-31\"\n )}\n ${chalk.cyan(\n \"akson gads swiss-market --start 2024-01-01 --end 2024-01-31 --analyze-seasonality\"\n )}\n ${chalk.cyan(\"akson myarmy-report -s 2024-01-01 -e 2024-01-31\")}\n\n🏷️ GTM MANAGEMENT:\n ${chalk.cyan(\"akson gtm validate\")}\n ${chalk.cyan(\"akson gtm plan\")}\n ${chalk.cyan(\"akson gtm apply --yes\")}\n\n📊 CROSS-PLATFORM ANALYSIS:\n ${chalk.cyan(\n \"akson analyze -s 2024-01-01 -e 2024-01-31 -p posthog gsc google-ads\"\n )}\n ${chalk.cyan(\"akson events standardize -e lead_whatsapp_contact purchase\")}\n\n🔎 SEO OPTIMIZATION:\n ${chalk.cyan(\n 'akson gsc rankings -k \"militär badge\" \"funktionsabzeichen\" -s 2024-01-01 -e 2024-01-31'\n )}\n ${chalk.cyan(\"akson seo audit -u https://myarmy.ch --device mobile\")}\n ${chalk.cyan(\n \"akson traffic-analysis -s 2024-01-01 -e 2024-01-31 -u https://myarmy.ch\"\n )}\n\n📈 POSTHOG QUERIES:\n ${chalk.cyan(\n \"akson posthog query -q \\\"SELECT event, count() FROM events WHERE timestamp > '2024-01-01' GROUP BY event\\\"\"\n )}\n ${chalk.cyan(\n \"akson posthog funnel -e lead_page_view,lead_inquiry_started,lead_form_submitted -s 2024-01-01 -e 2024-01-31\"\n )}\n`)\n );\n}\n\n/**\n * Show troubleshooting guide\n */\nexport function showTroubleshooting(): void {\n console.log(\n chalk.red.bold(`\n🔧 Troubleshooting Guide\n━━━━━━━━━━━━━━━━━━━━━━━━━━━\n\nCOMMON ISSUES:\n\n❌ Authentication Errors:\n • Check Google Service Account key: config/gtm-api-automation.json\n • Verify environment variables: cd packages/@akson && node config-loader.js validate\n • Re-run setup: akson setup\n\n❌ \"No data\" Responses:\n • Check date ranges (use YYYY-MM-DD format)\n • Verify platform access with: akson health --verbose\n • Check site URL configuration: GSC_SITE_URL=\"https://myarmy.ch\"\n\n❌ GTM Configuration Issues:\n • Validate config: akson gtm validate\n • Check workspace access: akson gtm query --type workspaces\n • Use test workspace for development, not Default (ID: 40)\n\n❌ PostHog Connection Issues:\n • Verify API key: POSTHOG_API_KEY in .env\n • Check project host: POSTHOG_HOST=\"https://us.i.posthog.com\"\n • Test connection: akson posthog query -q \"SELECT 1\"\n\n❌ Google Ads Access Issues:\n • Use correct Customer ID: 8847935674 (not 659644670)\n • Check developer token: GOOGLE_ADS_DEVELOPER_TOKEN\n • Verify service account permissions\n\nHELP COMMANDS:\n • Platform status: akson platform-status\n • Environment check: cd packages/@akson && node config-loader.js summary\n • Health check: akson health --verbose\n\nSupport: Check /packages/@akson/cortex-README.md for detailed documentation\n`)\n );\n}\n\n/**\n * Show getting started guide\n */\nexport function showGettingStarted(): void {\n console.log(\n chalk.green.bold(`\n🚀 Getting Started with @akson/cortex-analytics\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n\nSTEP 1: SETUP\n ${chalk.cyan(\"cd /Users/antoineschaller/GitHub/myarmy/packages/@akson\")}\n ${chalk.cyan(\"./setup-env.sh\")}\n\nSTEP 2: VERIFY CONFIGURATION \n ${chalk.cyan(\"node config-loader.js summary\")}\n ${chalk.cyan(\"npx @akson/cortex-analytics health --verbose\")}\n\nSTEP 3: RUN YOUR FIRST REPORTS\n ${chalk.cyan(\n \"npx @akson/cortex-analytics myarmy-report -s 2024-01-01 -e 2024-01-31\"\n )}\n ${chalk.cyan(\n \"npx @akson/cortex-analytics dashboard -s 2024-01-01 -e 2024-01-31\"\n )}\n\nSTEP 4: EXPLORE SWISS MARKET DATA\n ${chalk.cyan(\n \"npx @akson/cortex-analytics keyword-research -k 'militär badge' -s 2024-01-01 -e 2024-01-31\"\n )}\n ${chalk.cyan(\n \"npx @akson/cortex-analytics gsc rankings -k 'funktionsabzeichen' -s 2024-01-01 -e 2024-01-31\"\n )}\n\nKEY FILES:\n • Configuration: packages/@akson/cortex-analytics-config.yaml\n • Environment: packages/@akson/cortex-.env \n • Service Account: landing/config/gtm-api-automation.json\n\nNext Steps:\n • akson quick-start # Show quick start guide\n • akson examples # Show common use cases\n • akson swiss-market # Swiss-specific help\n`)\n );\n}\n"],"mappings":"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","names":["chalk","config","payload","transformed","fs","chalk","table","chalk"]}
|
|
1
|
+
{"version":3,"sources":["../package.json","../src/cli.ts","../src/analytics-manager.ts","../src/help.ts"],"sourcesContent":["{\n \"name\": \"@akson/cortex-analytics\",\n \"version\": \"0.9.1\",\n \"description\": \"Unified CLI for Cortex analytics operations across all platforms\",\n \"type\": \"module\",\n \"main\": \"dist/index.js\",\n \"bin\": {\n \"akson\": \"./dist/cli.js\",\n \"cortex-analytics\": \"./dist/cli.js\"\n },\n \"scripts\": {\n \"build\": \"tsup\",\n \"dev\": \"tsup --watch\",\n \"clean\": \"rm -rf dist\",\n \"lint\": \"eslint src --ext .ts\",\n \"test\": \"vitest\",\n \"type-check\": \"tsc --noEmit\"\n },\n \"dependencies\": {\n \"@akson/cortex-gsc\": \"^0.5.0\",\n \"@akson/cortex-gtm\": \"^3.1.0\",\n \"@akson/cortex-posthog\": \"^0.5.0\",\n \"chalk\": \"^5.5.0\",\n \"commander\": \"^14.0.0\",\n \"inquirer\": \"^13.1.0\",\n \"js-yaml\": \"^4.1.0\",\n \"ora\": \"^8.1.1\",\n \"table\": \"^6.9.0\"\n },\n \"devDependencies\": {\n \"@types/inquirer\": \"^9.0.7\",\n \"@types/js-yaml\": \"^4.0.9\",\n \"@types/node\": \"^22\",\n \"eslint\": \"^8\",\n \"tsup\": \"^8.5.0\",\n \"typescript\": \"^5.9.2\",\n \"vitest\": \"^3.2.4\"\n },\n \"engines\": {\n \"node\": \">=18.0.0\"\n },\n \"keywords\": [\n \"cli\",\n \"analytics\",\n \"gtm\",\n \"google-ads\",\n \"posthog\",\n \"gsc\",\n \"cortex\"\n ],\n \"author\": \"Akson <contact@akson.ch>\",\n \"license\": \"MIT\",\n \"homepage\": \"https://github.com/antoineschaller/cortex-packages/tree/main/packages/@akson/cortex-analytics\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/antoineschaller/cortex-packages.git\",\n \"directory\": \"packages/@akson/cortex-analytics\"\n },\n \"types\": \"dist/index.d.ts\",\n \"exports\": {\n \".\": {\n \"types\": \"./dist/index.d.ts\",\n \"import\": \"./dist/index.js\"\n }\n },\n \"files\": [\n \"dist\",\n \"README.md\",\n \"LICENSE\"\n ],\n \"gitHead\": \"b3a6a0832bb2fd230473076bde1bfc7810e9ac31\"\n}\n","#!/usr/bin/env node\n\n/**\n * Akson Analytics CLI\n *\n * Unified command-line interface for MyArmy analytics operations\n */\n\nimport chalk from \"chalk\";\nimport { Command } from \"commander\";\nimport { AnalyticsManager } from \"./analytics-manager.js\";\nimport {\n showComprehensiveHelp,\n showQuickStart,\n showSwissMarketHelp,\n showPlatformStatus,\n showExamples,\n showTroubleshooting,\n showGettingStarted,\n getVersion,\n getCommands,\n} from \"./help.js\";\n\nconst program = new Command();\n\nprogram\n .name(\"akson\")\n .description(\"Unified CLI for MyArmy analytics operations\")\n .version(getVersion());\n\n// ============================================================================\n// HELP COMMANDS - Enhanced documentation and guidance\n// ============================================================================\n\nprogram\n .command(\"comprehensive-help\")\n .alias(\"help-all\")\n .description(\"Show comprehensive help with all commands and examples\")\n .action(() => {\n showComprehensiveHelp();\n });\n\nprogram\n .command(\"quick-start\")\n .alias(\"start\")\n .description(\"Show quick start guide for new users\")\n .action(() => {\n showQuickStart();\n });\n\nprogram\n .command(\"swiss-market\")\n .alias(\"swiss\")\n .description(\"Show Swiss military market specific help and keywords\")\n .action(() => {\n showSwissMarketHelp();\n });\n\nprogram\n .command(\"platform-status\")\n .alias(\"status\")\n .description(\"Show platform configuration status and setup instructions\")\n .action(() => {\n showPlatformStatus();\n });\n\nprogram\n .command(\"examples\")\n .description(\"Show common use cases and examples\")\n .action(() => {\n showExamples();\n });\n\nprogram\n .command(\"troubleshooting\")\n .alias(\"troubleshoot\")\n .description(\"Show troubleshooting guide for common issues\")\n .action(() => {\n showTroubleshooting();\n });\n\nprogram\n .command(\"getting-started\")\n .alias(\"start-guide\")\n .description(\"Show complete getting started guide\")\n .action(() => {\n showGettingStarted();\n });\n\nprogram\n .command(\"version-info\")\n .description(\"Show version and dependency information\")\n .action(() => {\n const version = getVersion();\n const commands = getCommands();\n\n console.log(\n chalk.cyan.bold(`\n@akson/cortex-analytics v${version}\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n\n📦 PACKAGE DEPENDENCIES:\n • @akson/cortex-gtm: GTM operations and configuration\n • @akson/cortex-gsc: Google Search Console integration \n • @akson/cortex-google-ads: Google Ads reporting and analysis\n • @akson/cortex-posthog: PostHog analytics and experiments\n • @akson/cortex-utilities: Shared utilities and types\n\n🎯 AVAILABLE MODULES:\n • ${commands.length} command modules\n • ${commands.reduce(\n (acc, mod) => acc + mod.commands.length,\n 0\n )} total commands\n • Swiss military market specialization\n • Cross-platform analytics integration\n\n📋 COMMAND CATEGORIES:\n${commands\n .map((mod) => ` • ${mod.module}: ${mod.commands.length} commands`)\n .join(\"\\n\")}\n\nFor more information: akson comprehensive-help\n`)\n );\n });\n\n// ============================================================================\n// CORE ANALYTICS COMMANDS\n// ============================================================================\n\n// Health check command\nprogram\n .command(\"health\")\n .description(\"Check health of all analytics platforms\")\n .option(\"-v, --verbose\", \"Show detailed health information\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.healthCheck(options.verbose);\n });\n\n// Event standardization commands\nconst eventCmd = program\n .command(\"events\")\n .description(\"Event standardization and mapping operations\");\n\neventCmd\n .command(\"standardize\")\n .description(\"Standardize events across platforms\")\n .requiredOption(\"-e, --events <events...>\", \"Events to standardize\")\n .option(\n \"-s, --source <platform>\",\n \"Source platform (gtm|google-ads|posthog|gsc|meta)\"\n )\n .option(\"-t, --target <platform>\", \"Target platform (optional)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.standardizeEvents(options);\n });\n\neventCmd\n .command(\"score\")\n .description(\"Calculate lead scores for events\")\n .requiredOption(\"-f, --file <path>\", \"JSON file with events to score\")\n .option(\"-m, --method <method>\", \"Scoring method (default|custom)\", \"default\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.scoreLeads(options);\n });\n\n// Platform-specific commands\nconst gtmCmd = program\n .command(\"gtm\")\n .description(\"Google Tag Manager operations\");\n\ngtmCmd\n .command(\"sync\")\n .description(\"Sync GTM configuration\")\n .action(async () => {\n const manager = new AnalyticsManager();\n await manager.gtmSync();\n });\n\ngtmCmd\n .command(\"fix-variable-references\")\n .description(\"Fix incorrect variable references in GTM tags\")\n .option(\"-d, --dry-run\", \"Preview changes without applying them\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmFixVariableReferences(options);\n });\n\ngtmCmd\n .command(\"update-google-ads-id\")\n .description(\"Update Google Ads ID from 659644670 to 8847935674 in GTM\")\n .action(async () => {\n const manager = new AnalyticsManager();\n await manager.gtmUpdateGoogleAdsId();\n });\n\ngtmCmd\n .command(\"update-event-names\")\n .description(\n \"Update event names from enhanced_funnel_stage to lead_funnel_stage\"\n )\n .action(async () => {\n const manager = new AnalyticsManager();\n await manager.gtmUpdateEventNames();\n });\n\ngtmCmd\n .command(\"remove-triggers\")\n .description(\"Remove triggers from GTM\")\n .requiredOption(\"-i, --ids <ids...>\", \"Trigger IDs to remove\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.removeTriggers(options.ids);\n });\n\ngtmCmd\n .command(\"create-tag\")\n .description(\"Create a new GTM tag\")\n .requiredOption(\"-n, --name <name>\", \"Tag name\")\n .requiredOption(\"-t, --type <type>\", \"Tag type (e.g., gaawe, html, gclidw)\")\n .option(\"-c, --config <json>\", \"Additional configuration as JSON string\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmCreateTag(options);\n });\n\ngtmCmd\n .command(\"delete-tag\")\n .description(\"Delete a GTM tag\")\n .requiredOption(\"-i, --id <id>\", \"Tag ID to delete\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmDeleteTag(options.id);\n });\n\ngtmCmd\n .command(\"create-trigger\")\n .description(\"Create a new GTM trigger\")\n .requiredOption(\"-n, --name <name>\", \"Trigger name\")\n .requiredOption(\n \"-t, --type <type>\",\n \"Trigger type (e.g., customEvent, pageview, click)\"\n )\n .option(\"-c, --config <json>\", \"Additional configuration as JSON string\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmCreateTrigger(options);\n });\n\ngtmCmd\n .command(\"delete-trigger\")\n .description(\"Delete a GTM trigger\")\n .requiredOption(\"-i, --id <id>\", \"Trigger ID to delete\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmDeleteTrigger(options.id);\n });\n\ngtmCmd\n .command(\"query\")\n .description(\"Query GTM configuration\")\n .option(\n \"-t, --type <type>\",\n \"Query type: variables|tags|triggers|workspaces|versions|all\",\n \"all\"\n )\n .option(\"-f, --filter <filter>\", \"Filter results by name or type\")\n .option(\"-w, --workspace <id>\", \"Workspace ID (optional)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmQuery(options);\n });\n\n// Version management commands\ngtmCmd\n .command(\"versions\")\n .description(\"List all published versions\")\n .option(\"-l, --limit <number>\", \"Limit number of versions to show\", \"10\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmListVersions(options);\n });\n\ngtmCmd\n .command(\"version\")\n .description(\"Get specific version details\")\n .requiredOption(\"-v, --version <id>\", \"Version ID to retrieve\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmGetVersion(options);\n });\n\ngtmCmd\n .command(\"version-live\")\n .description(\"Get currently published live version\")\n .action(async () => {\n const manager = new AnalyticsManager();\n await manager.gtmGetLiveVersion();\n });\n\ngtmCmd\n .command(\"version-compare\")\n .description(\"Compare versions or version with workspace\")\n .requiredOption(\"--version1 <id>\", \"First version ID\")\n .option(\n \"--version2 <id>\",\n \"Second version ID (if not provided, compares with workspace)\"\n )\n .option(\"-o, --output <path>\", \"Save comparison to file\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmCompareVersions(options);\n });\n\ngtmCmd\n .command(\"version-create\")\n .description(\"Create version from current workspace\")\n .requiredOption(\"-n, --name <name>\", \"Version name\")\n .option(\"-d, --description <notes>\", \"Version description/notes\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmCreateVersion(options);\n });\n\n// =============================================================================\n// WORKSPACE STATE MANAGEMENT COMMANDS\n// =============================================================================\n\ngtmCmd\n .command(\"workspace-state\")\n .description(\"Get current workspace state (snapshot)\")\n .option(\n \"-w, --workspace <id>\",\n \"Workspace ID (defaults to current workspace)\"\n )\n .option(\"-o, --output <path>\", \"Save workspace state to file\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmGetWorkspaceState(options);\n });\n\ngtmCmd\n .command(\"workspace-snapshot\")\n .description(\"Save workspace state to snapshot file\")\n .requiredOption(\"-f, --file <path>\", \"Snapshot file path\")\n .option(\n \"-w, --workspace <id>\",\n \"Workspace ID (defaults to current workspace)\"\n )\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmSaveWorkspaceSnapshot(options);\n });\n\ngtmCmd\n .command(\"workspace-compare\")\n .description(\"Compare current workspace with snapshot or live version\")\n .option(\"-f, --file <path>\", \"Compare with snapshot file\")\n .option(\"--with-live\", \"Compare with live published version\")\n .option(\n \"-w, --workspace <id>\",\n \"Workspace ID (defaults to current workspace)\"\n )\n .option(\"-o, --output <path>\", \"Save comparison to file\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmCompareWorkspace(options);\n });\n\n// Note: GTM publishing via API has limitations and is not recommended for production use\n// Use the GTM UI for publishing workspaces to production\n\n// Terraform-style commands for GTM\ngtmCmd\n .command(\"init\")\n .description(\"Initialize GTM Terraform workspace\")\n .option(\"-c, --config <path>\", \"Configuration file path\", \"gtm.config.yaml\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformInit(options);\n });\n\ngtmCmd\n .command(\"plan\")\n .description(\"Show changes that would be applied to GTM\")\n .option(\"-c, --config <path>\", \"Configuration file path\", \"gtm.config.yaml\")\n .option(\"-o, --out <path>\", \"Save plan to file\")\n .option(\n \"-w, --workspace <id>\",\n \"Workspace ID to use (defaults to Default Workspace)\"\n )\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformPlan(options);\n });\n\ngtmCmd\n .command(\"apply\")\n .description(\"Apply GTM configuration changes\")\n .option(\"-c, --config <path>\", \"Configuration file path\", \"gtm.config.yaml\")\n .option(\"-p, --plan <path>\", \"Apply from saved plan file\")\n .option(\n \"-w, --workspace <id>\",\n \"Workspace ID to use (defaults to Default Workspace)\"\n )\n .option(\"-y, --yes\", \"Auto-approve changes\")\n .option(\"-v, --verbose\", \"Enable verbose logging for detailed debugging\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformApply(options);\n });\n\ngtmCmd\n .command(\"incremental-sync\")\n .description(\n \"Enhanced incremental sync with validation and proper error handling\"\n )\n .option(\"-c, --config <path>\", \"Configuration file path\", \"gtm.config.yaml\")\n .option(\"--dry-run\", \"Show what would be changed without applying\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmIncrementalSync(options);\n });\n\ngtmCmd\n .command(\"destroy\")\n .description(\"Destroy GTM resources\")\n .option(\"-c, --config <path>\", \"Configuration file path\", \"gtm.config.yaml\")\n .option(\"-y, --yes\", \"Auto-approve destruction\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformDestroy(options);\n });\n\ngtmCmd\n .command(\"import\")\n .description(\"Import existing GTM resources into state\")\n .requiredOption(\"-t, --type <type>\", \"Resource type (tag|trigger|variable)\")\n .requiredOption(\"-n, --name <name>\", \"Resource name\")\n .requiredOption(\"-i, --id <id>\", \"GTM resource ID\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformImport(options);\n });\n\ngtmCmd\n .command(\"show\")\n .description(\"Show current GTM state\")\n .option(\"-f, --format <format>\", \"Output format (json|yaml|table)\", \"table\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformShow(options);\n });\n\ngtmCmd\n .command(\"create-workspace\")\n .description(\"Create a new GTM workspace\")\n .requiredOption(\"-n, --name <name>\", \"Workspace name\")\n .option(\"-d, --description <description>\", \"Workspace description\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmCreateWorkspace(options);\n });\n\ngtmCmd\n .command(\"validate\")\n .description(\"Validate GTM configuration file\")\n .option(\"-c, --config <path>\", \"Configuration file path\", \"gtm.config.yaml\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformValidate(options);\n });\n\ngtmCmd\n .command(\"state\")\n .description(\"Advanced state management\")\n .addCommand(\n new Command(\"list\")\n .description(\"List resources in state\")\n .option(\"-t, --type <type>\", \"Filter by resource type\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformStateList(options);\n })\n )\n .addCommand(\n new Command(\"show\")\n .description(\"Show specific resource\")\n .requiredOption(\n \"-a, --address <address>\",\n \"Resource address (e.g., gtm_tag.example)\"\n )\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformStateShow(options);\n })\n )\n .addCommand(\n new Command(\"remove\")\n .description(\"Remove resource from state\")\n .requiredOption(\"-a, --address <address>\", \"Resource address to remove\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gtmTerraformStateRemove(options);\n })\n );\n\nconst posthogCmd = program\n .command(\"posthog\")\n .description(\"PostHog analytics operations\");\n\nposthogCmd\n .command(\"query\")\n .description(\"Execute HogQL query\")\n .requiredOption(\"-q, --query <query>\", \"HogQL query to execute\")\n .option(\"-l, --limit <number>\", \"Result limit\", \"100\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogQuery(options);\n });\n\nposthogCmd\n .command(\"funnel\")\n .description(\"Analyze conversion funnel\")\n .requiredOption(\"-e, --events <events...>\", \"Funnel events in order\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-E, --end <date>\", \"End date (YYYY-MM-DD)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogFunnel(options);\n });\n\n// PostHog Feature Flags & Experiments\nposthogCmd\n .command(\"flags\")\n .description(\"List all feature flags\")\n .option(\"-p, --project <id>\", \"Project ID (optional if configured)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogListFlags(options);\n });\n\nposthogCmd\n .command(\"flag\")\n .description(\"Get specific feature flag details\")\n .requiredOption(\"-i, --id <id>\", \"Feature flag ID\")\n .option(\"-p, --project <id>\", \"Project ID (optional if configured)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogGetFlag(options);\n });\n\nposthogCmd\n .command(\"create-flag\")\n .description(\"Create new feature flag\")\n .requiredOption(\"-k, --key <key>\", \"Feature flag key\")\n .requiredOption(\"-n, --name <name>\", \"Feature flag name\")\n .option(\"-d, --description <desc>\", \"Feature flag description\")\n .option(\"--active\", \"Set flag as active\", true)\n .option(\"-r, --rollout <percent>\", \"Rollout percentage (0-100)\", \"100\")\n .option(\"-p, --project <id>\", \"Project ID (optional if configured)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogCreateFlag(options);\n });\n\nposthogCmd\n .command(\"create-experiment\")\n .description(\"Create multivariate experiment\")\n .requiredOption(\"-k, --key <key>\", \"Experiment key\")\n .requiredOption(\"-n, --name <name>\", \"Experiment name\")\n .requiredOption(\"-v, --variants <variants>\", \"Comma-separated variant keys\")\n .option(\"-d, --description <desc>\", \"Experiment description\")\n .option(\"--equal-split\", \"Split variants equally\", true)\n .option(\"-r, --rollout <percent>\", \"Overall rollout percentage\", \"100\")\n .option(\"--continuity\", \"Ensure experience continuity\", true)\n .option(\"-p, --project <id>\", \"Project ID (optional if configured)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogCreateExperiment(options);\n });\n\nposthogCmd\n .command(\"update-flag\")\n .description(\"Update existing feature flag\")\n .requiredOption(\"-i, --id <id>\", \"Feature flag ID\")\n .option(\"-n, --name <name>\", \"New name\")\n .option(\"-d, --description <desc>\", \"New description\")\n .option(\"--active <boolean>\", \"Set active status (true/false)\")\n .option(\"-r, --rollout <percent>\", \"New rollout percentage\")\n .option(\"-p, --project <id>\", \"Project ID (optional if configured)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogUpdateFlag(options);\n });\n\nposthogCmd\n .command(\"delete-flag\")\n .description(\"Delete feature flag\")\n .requiredOption(\"-i, --id <id>\", \"Feature flag ID\")\n .option(\"-p, --project <id>\", \"Project ID (optional if configured)\")\n .option(\"-y, --yes\", \"Skip confirmation\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogDeleteFlag(options);\n });\n\nposthogCmd\n .command(\"evaluate\")\n .description(\"Evaluate feature flags for user\")\n .requiredOption(\"-u, --user <id>\", \"Distinct user ID\")\n .option(\"-g, --groups <groups>\", \"JSON string of group properties\")\n .option(\"--person-props <props>\", \"JSON string of person properties\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.posthogEvaluateFlags(options);\n });\n\nconst gadsCmd = program.command(\"gads\").description(\"Google Ads operations\");\n\ngadsCmd\n .command(\"conversions\")\n .description(\"Get conversion data\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.googleAdsConversions(options);\n });\n\ngadsCmd\n .command(\"report\")\n .description(\"Generate comprehensive Google Ads report\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\n \"-c, --customer <id>\",\n \"Customer ID (uses config default if not provided)\"\n )\n .option(\"-o, --output <format>\", \"Output format (json|table)\", \"table\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.googleAdsComprehensiveReport(options);\n });\n\ngadsCmd\n .command(\"keywords\")\n .description(\"Get keyword performance report\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\n \"-c, --customer <id>\",\n \"Customer ID (uses config default if not provided)\"\n )\n .option(\"-l, --limit <number>\", \"Number of keywords to return\", \"1000\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.googleAdsKeywords(options);\n });\n\ngadsCmd\n .command(\"search-terms\")\n .description(\"Get search terms report\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\n \"-c, --customer <id>\",\n \"Customer ID (uses config default if not provided)\"\n )\n .option(\"-l, --limit <number>\", \"Number of search terms to return\", \"1000\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.googleAdsSearchTerms(options);\n });\n\ngadsCmd\n .command(\"historical\")\n .description(\"Perform historical analysis with anomaly and trend detection\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\n \"-c, --customer <id>\",\n \"Customer ID (uses config default if not provided)\"\n )\n .option(\n \"-g, --granularity <level>\",\n \"Data granularity (daily|weekly|monthly)\",\n \"daily\"\n )\n .option(\"--detect-anomalies\", \"Enable anomaly detection\")\n .option(\"--analyze-trends\", \"Enable trend analysis\")\n .option(\"--analyze-seasonality\", \"Enable seasonality analysis\")\n .option(\n \"-o, --output <format>\",\n \"Output format (json|csv|markdown|table)\",\n \"table\"\n )\n .option(\"--output-file <path>\", \"Save output to file\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.googleAdsHistorical(options);\n });\n\ngadsCmd\n .command(\"swiss-market\")\n .description(\"Specialized Swiss military market analysis\")\n .option(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .option(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\n \"-c, --customer <id>\",\n \"Customer ID (uses config default if not provided)\"\n )\n .option(\"--include-competitors\", \"Include competitor analysis\")\n .option(\"--analyze-seasonality\", \"Analyze seasonal recruitment patterns\")\n .option(\"--opportunity-analysis\", \"Identify market opportunities\")\n .option(\n \"-o, --output <format>\",\n \"Output format (json|csv|markdown|table)\",\n \"table\"\n )\n .option(\"--output-file <path>\", \"Save output to file\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.googleAdsSwissMarket(options);\n });\n\n// Meta/Facebook Ads operations\nconst metaCmd = program\n .command(\"meta\")\n .description(\"Meta/Facebook Ads operations\");\n\nmetaCmd\n .command(\"campaigns\")\n .description(\"Get campaign performance\")\n .option(\"-l, --limit <number>\", \"Number of campaigns to return\", \"100\")\n .option(\"-o, --output <format>\", \"Output format (json|table)\", \"table\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.metaCampaigns(options);\n });\n\nmetaCmd\n .command(\"insights\")\n .description(\"Get account insights\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\n \"--level <level>\",\n \"Insight level (account|campaign|adset|ad)\",\n \"account\"\n )\n .option(\"-o, --output <format>\", \"Output format (json|table)\", \"table\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.metaInsights(options);\n });\n\nmetaCmd\n .command(\"conversions\")\n .description(\"Get conversion report\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\n \"--level <level>\",\n \"Insight level (account|campaign|adset|ad)\",\n \"account\"\n )\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.metaConversions(options);\n });\n\n// SEO analysis operations\nconst seoCmd = program\n .command(\"seo\")\n .description(\"SEO analysis and optimization\");\n\nseoCmd\n .command(\"audit\")\n .description(\"Run comprehensive SEO audit\")\n .requiredOption(\"-u, --url <url>\", \"URL to audit\")\n .option(\"-d, --device <device>\", \"Device type (mobile|desktop)\", \"mobile\")\n .option(\"-o, --output <format>\", \"Output format (json|table)\", \"table\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.seoAudit(options);\n });\n\nseoCmd\n .command(\"core-web-vitals\")\n .description(\"Analyze Core Web Vitals\")\n .requiredOption(\"-u, --url <url>\", \"URL to analyze\")\n .option(\"-d, --device <device>\", \"Device type (mobile|desktop)\", \"mobile\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.seoCoreWebVitals(options);\n });\n\nseoCmd\n .command(\"schema\")\n .description(\"Validate structured data schema\")\n .requiredOption(\"-u, --url <url>\", \"URL to validate\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.seoSchemaValidation(options);\n });\n\nseoCmd\n .command(\"geo\")\n .description(\"Analyze GEO (Generative Engine Optimization)\")\n .requiredOption(\"-u, --url <url>\", \"URL to analyze\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.seoGEOAnalysis(options);\n });\n\nconst gscCmd = program\n .command(\"gsc\")\n .description(\"Google Search Console operations\");\n\ngscCmd\n .command(\"rankings\")\n .description(\"Check keyword rankings\")\n .requiredOption(\"-k, --keywords <keywords...>\", \"Keywords to check\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gscRankings(options);\n });\n\ngscCmd\n .command(\"report\")\n .description(\"Generate comprehensive GSC SEO report\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-u, --url <url>\", \"Site URL (uses config default if not provided)\")\n .option(\"-o, --output <format>\", \"Output format (json|table)\", \"table\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gscComprehensiveReport(options);\n });\n\ngscCmd\n .command(\"enhanced-report\")\n .description(\n \"Generate enhanced GSC report with schema analysis and URL inspections\"\n )\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-o, --output <file>\", \"Output file (JSON)\")\n .option(\"--no-schema\", \"Skip schema analysis\")\n .option(\"--no-inspections\", \"Skip URL inspections\")\n .option(\n \"--max-keywords <number>\",\n \"Maximum keywords to analyze (default: 100)\"\n )\n .option(\"--max-pages <number>\", \"Maximum pages to analyze (default: 50)\")\n .option(\"--max-inspections <number>\", \"Maximum URLs to inspect (default: 10)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gscEnhancedReport(options);\n });\n\ngscCmd\n .command(\"keywords\")\n .description(\"Get top performing keywords\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-l, --limit <number>\", \"Number of keywords to return\", \"100\")\n .option(\"-u, --url <url>\", \"Site URL (uses config default if not provided)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gscTopKeywords(options);\n });\n\ngscCmd\n .command(\"pages\")\n .description(\"Get top performing pages\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-l, --limit <number>\", \"Number of pages to return\", \"100\")\n .option(\"-u, --url <url>\", \"Site URL (uses config default if not provided)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.gscTopPages(options);\n });\n\n// Cross-platform analysis\nprogram\n .command(\"analyze\")\n .description(\"Cross-platform analytics analysis\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-p, --platforms <platforms...>\", \"Platforms to analyze\", [\n \"posthog\",\n \"gsc\",\n \"google-ads\",\n ])\n .option(\"-v, --events <events...>\", \"Specific events to analyze\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.crossPlatformAnalysis(options);\n });\n\n// Interactive setup\nprogram\n .command(\"setup\")\n .description(\"Interactive setup for analytics configuration\")\n .action(async () => {\n const manager = new AnalyticsManager();\n await manager.interactiveSetup();\n });\n\n// Dashboard command\nprogram\n .command(\"dashboard\")\n .description(\"Generate unified analytics dashboard\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-o, --output <format>\", \"Output format (json|table)\", \"table\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.generateDashboard(options);\n });\n\n// Comprehensive SEO/GEO report for MyArmy\nprogram\n .command(\"myarmy-report\")\n .description(\"Generate comprehensive MyArmy.ch SEO/GEO optimization report\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-u, --url <url>\", \"URL to analyze\", \"https://myarmy.ch\")\n .option(\"-d, --device <device>\", \"Device type (mobile|desktop)\", \"mobile\")\n .option(\"-o, --output <format>\", \"Output format (json|table|file)\", \"table\")\n .option(\"-f, --file <path>\", \"Output file path (when using file output)\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.generateMyArmyReport(options);\n });\n\n// Keyword research and optimization\nprogram\n .command(\"keyword-research\")\n .description(\"Research keywords across all platforms\")\n .requiredOption(\"-k, --keywords <keywords...>\", \"Keywords to research\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-c, --country <country>\", \"Country code (e.g., CH, US)\", \"CH\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.keywordResearch(options);\n });\n\n// Traffic analysis\nprogram\n .command(\"traffic-analysis\")\n .description(\"Analyze traffic patterns and optimization opportunities\")\n .requiredOption(\"-s, --start <date>\", \"Start date (YYYY-MM-DD)\")\n .requiredOption(\"-e, --end <date>\", \"End date (YYYY-MM-DD)\")\n .option(\"-u, --url <url>\", \"Site URL to analyze\", \"https://myarmy.ch\")\n .action(async (options) => {\n const manager = new AnalyticsManager();\n await manager.trafficAnalysis(options);\n });\n\n// Error handling\nprogram.configureHelp({\n sortSubcommands: true,\n subcommandTerm: (cmd) => `${cmd.name()} ${cmd.usage()}`,\n});\n\nprogram.exitOverride();\n\ntry {\n await program.parseAsync(process.argv);\n} catch (error) {\n if (error.code === \"commander.help\") {\n process.exit(0);\n }\n console.error(chalk.red(\"Error:\"), error.message);\n process.exit(1);\n}\n\nexport { program };\n","/**\n * Analytics Manager\n *\n * Unified manager class for all analytics operations\n */\n\nimport crypto from \"node:crypto\";\nimport fs from \"node:fs/promises\";\nimport {\n GoogleAdsClient,\n HistoricalAnalyzer,\n SwissMarketAnalyzer,\n loadGoogleAdsConfig,\n} from \"@akson/cortex-google-ads\";\nimport { GSCClient, loadGSCConfig } from \"@akson/cortex-gsc\";\nimport {\n ConfigParser,\n GTMClient,\n GTMApiTransformer,\n type GTMTag,\n type GTMTrigger,\n type GTMVariable,\n type GTMWorkspace,\n loadGTMConfig,\n Planner,\n StateManager,\n} from \"@akson/cortex-gtm\";\nimport { loadPostHogConfig, PostHogClient } from \"@akson/cortex-posthog\";\nimport {\n ECOMMERCE_EVENTS,\n LEAD_GENERATION_EVENTS,\n LEAD_SCORES,\n PLATFORM_MAPPINGS,\n} from \"@akson/cortex-utilities\";\nimport chalk from \"chalk\";\nimport inquirer from \"inquirer\";\nimport yaml from \"js-yaml\";\nimport ora from \"ora\";\n\n// Type definitions for lead scoring\ninterface LeadEvent {\n event_name: string;\n calculated_lead_score?: number;\n qualification_level?: string;\n [key: string]: unknown;\n}\n\ninterface ScoredLead extends LeadEvent {\n calculated_lead_score: number;\n qualification_level: string;\n}\n\nimport { table } from \"table\";\n\ninterface HealthStatus {\n platform: string;\n status: \"healthy\" | \"error\" | \"unavailable\";\n message?: string;\n lastCheck?: string;\n}\n\nexport class AnalyticsManager {\n private clients: {\n gtm?: GTMClient;\n googleAds?: GoogleAdsClient;\n postHog?: PostHogClient;\n gsc?: GSCClient;\n } = {};\n\n private gtmTransformer = new GTMApiTransformer();\n\n async healthCheck(verbose = false): Promise<void> {\n const spinner = ora(\"Checking platform health...\").start();\n const health: HealthStatus[] = [];\n\n // GTM Health Check\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (authResult.success) {\n const workspacesResult = await this.clients.gtm.listWorkspaces();\n health.push({\n platform: \"GTM\",\n status: workspacesResult.success ? \"healthy\" : \"error\",\n message: workspacesResult.success\n ? \"Connected\"\n : workspacesResult.error,\n lastCheck: new Date().toISOString(),\n });\n } else {\n health.push({\n platform: \"GTM\",\n status: \"error\",\n message: authResult.error,\n });\n }\n } catch (error) {\n health.push({\n platform: \"GTM\",\n status: \"error\",\n message: error instanceof Error ? error.message : String(error),\n });\n }\n\n // PostHog Health Check\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const authResult = await this.clients.postHog.authenticate();\n if (authResult.success) {\n const queryResult = await this.clients.postHog.query({\n query: \"SELECT 1\",\n });\n health.push({\n platform: \"PostHog\",\n status: queryResult.success ? \"healthy\" : \"error\",\n message: queryResult.success ? \"Connected\" : queryResult.error,\n lastCheck: new Date().toISOString(),\n });\n } else {\n health.push({\n platform: \"PostHog\",\n status: \"error\",\n message: authResult.error,\n });\n }\n } catch (error) {\n health.push({\n platform: \"PostHog\",\n status: \"error\",\n message: error instanceof Error ? error.message : String(error),\n });\n }\n\n // Google Ads Health Check\n try {\n if (!this.clients.googleAds) {\n const config = loadGoogleAdsConfig();\n this.clients.googleAds = new GoogleAdsClient({ config });\n }\n\n const authResult = await this.clients.googleAds.authenticate();\n if (authResult.success) {\n const accountResult = await this.clients.googleAds.getAccount();\n health.push({\n platform: \"Google Ads\",\n status: accountResult.success ? \"healthy\" : \"error\",\n message: accountResult.success ? \"Connected\" : accountResult.error,\n lastCheck: new Date().toISOString(),\n });\n } else {\n health.push({\n platform: \"Google Ads\",\n status: \"error\",\n message: authResult.error,\n });\n }\n } catch (error) {\n health.push({\n platform: \"Google Ads\",\n status: \"error\",\n message: error instanceof Error ? error.message : String(error),\n });\n }\n\n // GSC Health Check\n try {\n if (!this.clients.gsc) {\n const config = loadGSCConfig();\n this.clients.gsc = new GSCClient({ config });\n }\n\n const authResult = await this.clients.gsc.authenticate();\n if (authResult.success) {\n const analyticsResult = await this.clients.gsc.getSearchAnalytics({\n dimensions: [\"query\"],\n startDate: \"2024-01-01\",\n endDate: \"2024-01-01\",\n filters: [],\n rowLimit: 1,\n startRow: 0,\n });\n health.push({\n platform: \"GSC\",\n status: analyticsResult.success ? \"healthy\" : \"error\",\n message: analyticsResult.success\n ? \"Connected\"\n : analyticsResult.error,\n lastCheck: new Date().toISOString(),\n });\n } else {\n health.push({\n platform: \"GSC\",\n status: \"error\",\n message: authResult.error,\n });\n }\n } catch (error) {\n health.push({\n platform: \"GSC\",\n status: \"error\",\n message: error instanceof Error ? error.message : String(error),\n });\n }\n\n spinner.stop();\n\n // Display results\n console.log(chalk.bold(\"\\n🏥 Platform Health Status\\n\"));\n\n const tableData = [\n [\"Platform\", \"Status\", verbose ? \"Message\" : \"\"].filter(Boolean),\n ];\n\n for (const platform of health) {\n const statusColor =\n platform.status === \"healthy\" ? chalk.green : chalk.red;\n const statusText =\n platform.status === \"healthy\" ? \"✅ Healthy\" : \"❌ Error\";\n\n const row = [\n platform.platform,\n statusColor(statusText),\n verbose ? platform.message || \"\" : \"\",\n ].filter(Boolean);\n\n tableData.push(row);\n }\n\n console.log(\n table(tableData, {\n border: {\n topBody: \"─\",\n topJoin: \"┬\",\n topLeft: \"┌\",\n topRight: \"┐\",\n bottomBody: \"─\",\n bottomJoin: \"┴\",\n bottomLeft: \"└\",\n bottomRight: \"┘\",\n bodyLeft: \"│\",\n bodyRight: \"│\",\n bodyJoin: \"│\",\n joinBody: \"─\",\n joinLeft: \"├\",\n joinRight: \"┤\",\n joinJoin: \"┼\",\n },\n })\n );\n\n const healthyCount = health.filter((h) => h.status === \"healthy\").length;\n const totalCount = health.length;\n\n if (healthyCount === totalCount) {\n console.log(\n chalk.green(`\\n✅ All ${totalCount} platforms are healthy\\n`)\n );\n } else {\n console.log(\n chalk.yellow(\n `\\n⚠️ ${healthyCount}/${totalCount} platforms are healthy\\n`\n )\n );\n }\n }\n\n async gtmQuery(options: {\n type: \"variables\" | \"tags\" | \"triggers\" | \"workspaces\" | \"versions\" | \"all\";\n workspace?: string;\n filter?: string;\n }): Promise<void> {\n const spinner = ora(\"Querying GTM configuration...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n // Authenticate\n spinner.text = \"Authenticating with GTM API...\";\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // Select workspace\n const workspaceResult = await this.clients.gtm.selectWorkspace(\n options.workspace // Pass workspace ID if provided\n );\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n const results: Record<string, unknown> = {};\n\n if (options.type === \"all\" || options.type === \"workspaces\") {\n spinner.text = \"Fetching workspaces...\";\n const workspacesResult = await this.clients.gtm.listWorkspaces();\n if (workspacesResult.success) {\n results.workspaces = workspacesResult.data;\n }\n }\n\n if (options.type === \"all\" || options.type === \"variables\") {\n spinner.text = \"Fetching variables...\";\n const variablesResult = await this.clients.gtm.listVariables();\n if (variablesResult.success) {\n results.variables = options.filter\n ? variablesResult.data.filter(\n (v: GTMVariable) =>\n v.name\n ?.toLowerCase()\n .includes(options.filter?.toLowerCase()) ||\n v.type?.toLowerCase().includes(options.filter?.toLowerCase())\n )\n : variablesResult.data;\n }\n }\n\n if (options.type === \"all\" || options.type === \"tags\") {\n spinner.text = \"Fetching tags...\";\n const tagsResult = await this.clients.gtm.listTags();\n if (tagsResult.success) {\n results.tags = options.filter\n ? tagsResult.data.filter(\n (t: GTMTag) =>\n t.name\n ?.toLowerCase()\n .includes(options.filter?.toLowerCase()) ||\n t.type?.toLowerCase().includes(options.filter?.toLowerCase())\n )\n : tagsResult.data;\n }\n }\n\n if (options.type === \"all\" || options.type === \"triggers\") {\n spinner.text = \"Fetching triggers...\";\n const triggersResult = await this.clients.gtm.listTriggers();\n if (triggersResult.success) {\n results.triggers = options.filter\n ? triggersResult.data.filter(\n (tr: GTMTrigger) =>\n tr.name\n ?.toLowerCase()\n .includes(options.filter?.toLowerCase()) ||\n tr.type?.toLowerCase().includes(options.filter?.toLowerCase())\n )\n : triggersResult.data;\n }\n }\n\n if (options.type === \"all\" || options.type === \"versions\") {\n spinner.text = \"Fetching versions...\";\n const versionsResult = await this.clients.gtm.listVersions();\n if (versionsResult.success) {\n results.versions = versionsResult.data;\n }\n }\n\n spinner.stop();\n\n console.log(chalk.bold(`\\n📊 GTM Configuration Query Results\\n`));\n console.log(chalk.cyan(`Container: GTM-T8WRBMWV`));\n\n if (results.workspaces) {\n console.log(\n chalk.yellow(`\\n🏠 Workspaces (${results.workspaces.length}):`)\n );\n (results.workspaces as GTMWorkspace[]).forEach((ws) => {\n console.log(` - ${ws.name} (ID: ${ws.workspaceId})`);\n });\n }\n\n if (results.variables) {\n console.log(\n chalk.yellow(`\\n📝 Variables (${results.variables.length}):`)\n );\n (results.variables as GTMVariable[]).forEach((variable) => {\n const value =\n variable.parameter?.find((p) => p.key === \"value\")?.value || \"N/A\";\n console.log(` - ${variable.name} (${variable.type}): ${value}`);\n });\n }\n\n if (results.tags) {\n console.log(chalk.yellow(`\\n🏷️ Tags (${results.tags.length}):`));\n (results.tags as GTMTag[]).forEach((tag) => {\n console.log(` - ${tag.name} (${tag.type})`);\n });\n }\n\n if (results.triggers) {\n console.log(\n chalk.yellow(`\\n⚡ Triggers (${results.triggers.length}):`)\n );\n (results.triggers as GTMTrigger[]).forEach((trigger) => {\n console.log(` - ${trigger.name} (${trigger.type})`);\n });\n }\n\n if (results.versions) {\n console.log(\n chalk.yellow(`\\n📋 Versions (${results.versions.length}):`)\n );\n (results.versions as any[]).forEach((version) => {\n const publishedAt = version.publishedContainerVersionId\n ? \" (Published)\"\n : \"\";\n console.log(\n ` - Version ${version.containerVersionId}: ${version.name}${publishedAt}`\n );\n });\n }\n\n // Output raw JSON if requested\n if (options.type !== \"all\") {\n console.log(chalk.dim(\"\\n📄 Raw JSON:\"));\n console.log(JSON.stringify(results, null, 2));\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async standardizeEvents(options: {\n events: string[];\n source?: string;\n target?: string;\n }): Promise<void> {\n console.log(chalk.bold(\"\\n🔄 Event Standardization\\n\"));\n\n const mappings: Record<string, any> = {};\n\n for (const event of options.events) {\n const isLeadEvent = Object.values(LEAD_GENERATION_EVENTS).includes(\n event as any\n );\n const isEcommerceEvent = Object.values(ECOMMERCE_EVENTS).includes(\n event as any\n );\n\n if (isLeadEvent) {\n mappings[event] = {\n category: \"lead_generation\",\n lead_score: LEAD_SCORES[event as keyof typeof LEAD_SCORES] || 0,\n platform_mappings: options.target\n ? {\n [options.target]:\n PLATFORM_MAPPINGS[\n options.target.toUpperCase() as keyof typeof PLATFORM_MAPPINGS\n ]?.LEAD_GENERATION,\n }\n : Object.fromEntries(\n Object.entries(PLATFORM_MAPPINGS).map(([platform, mapping]) => [\n platform.toLowerCase(),\n mapping.LEAD_GENERATION,\n ])\n ),\n };\n } else if (isEcommerceEvent) {\n mappings[event] = {\n category: \"ecommerce\",\n platform_mappings: options.target\n ? {\n [options.target]:\n PLATFORM_MAPPINGS[\n options.target.toUpperCase() as keyof typeof PLATFORM_MAPPINGS\n ]?.ECOMMERCE,\n }\n : Object.fromEntries(\n Object.entries(PLATFORM_MAPPINGS).map(([platform, mapping]) => [\n platform.toLowerCase(),\n mapping.ECOMMERCE,\n ])\n ),\n };\n } else {\n mappings[event] = {\n category: \"custom\",\n note: \"Event not in standardized schema, requires manual mapping\",\n };\n }\n }\n\n console.log(JSON.stringify(mappings, null, 2));\n }\n\n async scoreLeads(options: { file: string; method: string }): Promise<void> {\n const spinner = ora(\"Loading events file...\").start();\n\n try {\n const fileContent = await fs.readFile(options.file, \"utf-8\");\n const events = JSON.parse(fileContent);\n\n spinner.text = \"Calculating lead scores...\";\n\n const scoredLeads = (events as LeadEvent[]).map((event): ScoredLead => {\n const leadScore =\n options.method === \"default\"\n ? LEAD_SCORES[event.event_name as keyof typeof LEAD_SCORES] || 0\n : this.calculateCustomLeadScore(event);\n\n return {\n ...event,\n calculated_lead_score: leadScore,\n qualification_level: this.getQualificationLevel(leadScore),\n };\n });\n\n const summary = {\n total_leads: scoredLeads.length,\n high_quality_leads: scoredLeads.filter(\n (l) => l.calculated_lead_score >= 70\n ).length,\n medium_quality_leads: scoredLeads.filter(\n (l) => l.calculated_lead_score >= 40 && l.calculated_lead_score < 70\n ).length,\n low_quality_leads: scoredLeads.filter(\n (l) => l.calculated_lead_score < 40\n ).length,\n average_score: Math.round(\n scoredLeads.reduce(\n (sum: number, l) => sum + l.calculated_lead_score,\n 0\n ) / scoredLeads.length\n ),\n };\n\n spinner.stop();\n\n console.log(chalk.bold(\"\\n📊 Lead Scoring Results\\n\"));\n console.log(\n JSON.stringify({ summary, scored_leads: scoredLeads }, null, 2)\n );\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmSync(): Promise<void> {\n const spinner = ora(\"Syncing GTM configuration...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // Select workspace\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n // Read current YAML config\n spinner.text = \"Reading current configuration...\";\n let yamlContent: string;\n try {\n yamlContent = await fs.readFile(\"gtm.config.yaml\", \"utf-8\");\n } catch (_error) {\n throw new Error(\n \"gtm.config.yaml not found. Please create the configuration file first.\"\n );\n }\n\n // Parse YAML\n const config = yaml.load(yamlContent) as any;\n\n // Query current GTM variables to get actual Google Ads ID\n spinner.text = \"Querying current GTM state...\";\n const variablesResult = await this.clients.gtm.listVariables();\n if (variablesResult.success && variablesResult.data) {\n // Find Google Ads Conversion ID variable\n const googleAdsVar = variablesResult.data.find(\n (v: GTMVariable) =>\n v.name === \"Google Ads Conversion ID\" ||\n v.name === \"Google Ads - Conversion ID\"\n );\n\n if (googleAdsVar?.parameter) {\n const valueParam = googleAdsVar.parameter?.find(\n (p) => p.key === \"value\"\n );\n if (valueParam) {\n const currentGoogleAdsId = valueParam.value.replace(\"AW-\", \"\");\n if (\n config.variables &&\n config.variables.google_ads_id !== currentGoogleAdsId\n ) {\n config.variables.google_ads_id = currentGoogleAdsId;\n spinner.text = `Updated Google Ads ID to ${currentGoogleAdsId}`;\n }\n }\n }\n }\n\n // Write updated YAML back to file\n spinner.text = \"Writing updated configuration...\";\n const updatedYaml = yaml.dump(config, {\n indent: 2,\n lineWidth: -1,\n quotingType: '\"',\n forceQuotes: false,\n });\n await fs.writeFile(\"gtm.config.yaml\", updatedYaml, \"utf-8\");\n\n spinner.stop();\n console.log(chalk.green(\"✅ GTM configuration synced successfully\"));\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmUpdateGoogleAdsId(): Promise<void> {\n const spinner = ora(\"Updating Google Ads ID in GTM...\").start();\n\n const OLD_GOOGLE_ADS_ID = \"659644670\";\n const NEW_GOOGLE_ADS_ID = \"8847935674\";\n\n try {\n // Force a fresh GTM client for this operation to ensure latest methods\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, debug: true, failFast: true });\n\n // Authenticate\n spinner.text = \"Authenticating with GTM API...\";\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // Select workspace\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n // List all variables\n spinner.text = \"Finding Google Ads variables...\";\n const variablesResult = await this.clients.gtm.listVariables();\n if (!variablesResult.success) {\n throw new Error(`Failed to list variables: ${variablesResult.error}`);\n }\n\n // Find Google Ads related variables\n const googleAdsVariables = variablesResult.data.filter((variable) => {\n const nameMatch =\n variable.name?.toLowerCase().includes(\"google ads\") ||\n variable.name?.toLowerCase().includes(\"conversion id\");\n\n const valueMatch = variable.parameter?.some(\n (param) =>\n param.value?.includes(OLD_GOOGLE_ADS_ID) ||\n param.value?.includes(`AW-${OLD_GOOGLE_ADS_ID}`)\n );\n\n return nameMatch || valueMatch;\n });\n\n spinner.stop();\n console.log(\n chalk.cyan(\n `Found ${googleAdsVariables.length} Google Ads related variables:`\n )\n );\n googleAdsVariables.forEach((v) => {\n const value =\n v.parameter?.find((p) => p.key === \"value\")?.value || \"No value\";\n console.log(` - ${v.name} (ID: ${v.variableId}): ${value}`);\n });\n\n // Update each variable\n if (googleAdsVariables.length > 0) {\n console.log(chalk.yellow(\"🔄 Updating variables...\"));\n\n for (const variable of googleAdsVariables) {\n const currentValue = variable.parameter?.find(\n (p) => p.key === \"value\"\n )?.value;\n\n if (!currentValue) {\n console.log(\n chalk.gray(` ⏭️ Skipping ${variable.name} - no value found`)\n );\n continue;\n }\n\n // Determine new value\n let newValue = currentValue;\n if (currentValue === OLD_GOOGLE_ADS_ID) {\n newValue = NEW_GOOGLE_ADS_ID;\n } else if (currentValue === `AW-${OLD_GOOGLE_ADS_ID}`) {\n newValue = `AW-${NEW_GOOGLE_ADS_ID}`;\n } else if (currentValue.includes(OLD_GOOGLE_ADS_ID)) {\n newValue = currentValue.replace(\n OLD_GOOGLE_ADS_ID,\n NEW_GOOGLE_ADS_ID\n );\n } else {\n console.log(\n chalk.gray(\n ` ⏭️ Skipping ${variable.name} - doesn't contain old ID`\n )\n );\n continue;\n }\n\n console.log(chalk.blue(` 📝 Updating ${variable.name}:`));\n console.log(chalk.gray(` From: ${currentValue}`));\n console.log(chalk.green(` To: ${newValue}`));\n\n // Update the variable\n const updateResult = await this.clients.gtm.updateVariable(\n variable.variableId,\n {\n value: newValue,\n }\n );\n\n if (updateResult.success) {\n console.log(chalk.green(\" ✅ Updated successfully\"));\n } else {\n console.log(\n chalk.red(` ❌ Failed to update: ${updateResult.error}`)\n );\n }\n }\n } else {\n console.log(chalk.yellow(\"ℹ️ No variables need updating\"));\n }\n\n // Now update tags that may contain the old ID\n const tagsSpinner = ora(\"Finding tags with old Google Ads ID...\").start();\n\n const tagsResult = await this.clients.gtm.listTags();\n if (!tagsResult.success) {\n tagsSpinner.stop();\n throw new Error(`Failed to list tags: ${tagsResult.error}`);\n }\n\n // Find tags that contain the old Google Ads ID\n const tagsToUpdate = tagsResult.data.filter((tag) => {\n // Check all parameters for the old ID\n return tag.parameter?.some((param) => {\n const value = param.value || \"\";\n return (\n value.includes(OLD_GOOGLE_ADS_ID) ||\n value.includes(`AW-${OLD_GOOGLE_ADS_ID}`)\n );\n });\n });\n\n tagsSpinner.stop();\n\n if (tagsToUpdate.length > 0) {\n console.log(\n chalk.cyan(\n `\\nFound ${tagsToUpdate.length} tags with old Google Ads ID:`\n )\n );\n tagsToUpdate.forEach((tag) => {\n console.log(` - ${tag.name} (ID: ${tag.tagId})`);\n });\n\n console.log(chalk.yellow(\"\\n🔄 Updating tags...\"));\n\n for (const tag of tagsToUpdate) {\n console.log(chalk.blue(` 📝 Updating ${tag.name}:`));\n\n // Update parameters that contain the old ID\n const updatedParameters = tag.parameter?.map((param) => {\n if (param.value?.includes(OLD_GOOGLE_ADS_ID)) {\n const newValue = param.value.replace(\n OLD_GOOGLE_ADS_ID,\n NEW_GOOGLE_ADS_ID\n );\n console.log(\n chalk.gray(\n ` Parameter ${param.key}: ${param.value} → ${newValue}`\n )\n );\n return { ...param, value: newValue };\n } else if (param.value?.includes(`AW-${OLD_GOOGLE_ADS_ID}`)) {\n const newValue = param.value.replace(\n `AW-${OLD_GOOGLE_ADS_ID}`,\n `AW-${NEW_GOOGLE_ADS_ID}`\n );\n console.log(\n chalk.gray(\n ` Parameter ${param.key}: ${param.value} → ${newValue}`\n )\n );\n return { ...param, value: newValue };\n }\n return param;\n });\n\n // Update the tag directly via GTM API using the same pattern as updateConversionLabels\n const tagPath = `accounts/${\n (this.clients.gtm as any).config.accountId\n }/containers/${\n (this.clients.gtm as any).config.containerId\n }/workspaces/${(this.clients.gtm as any).workspaceId}/tags/${\n tag.tagId\n }`;\n\n try {\n await (\n this.clients.gtm as any\n ).tagmanager.accounts.containers.workspaces.tags.update({\n path: tagPath,\n requestBody: {\n ...tag,\n parameter: updatedParameters,\n },\n });\n console.log(chalk.green(\" ✅ Updated successfully\"));\n } catch (error) {\n console.log(\n chalk.red(\n ` ❌ Failed to update: ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n );\n }\n }\n } else {\n console.log(\n chalk.green(\n \"\\n✅ No tags need updating - all tags already use the new ID\"\n )\n );\n }\n\n console.log(\"\");\n console.log(chalk.cyan(\"🎯 Next Steps:\"));\n console.log(\"1. Review the changes in GTM workspace\");\n console.log(\"2. Test the configuration in Preview mode\");\n console.log(\"3. Use GTM UI to publish workspace to production\");\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmUpdateEventNames(): Promise<void> {\n const spinner = ora(\"Updating event names in GTM triggers...\").start();\n\n try {\n // Force a fresh GTM client\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, debug: true, failFast: true });\n\n // Authenticate\n spinner.text = \"Authenticating with GTM API...\";\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // Select workspace\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n spinner.text = \"Finding triggers with old event names...\";\n const triggersResult = await this.clients.gtm.listTriggers();\n if (!triggersResult.success) {\n throw new Error(`Failed to list triggers: ${triggersResult.error}`);\n }\n\n // Find triggers that need updating from enhanced_funnel_stage to lead_funnel_stage\n const triggersToUpdate = triggersResult.data.filter((trigger) => {\n return trigger.customEventFilter?.some((filter) => {\n return filter.parameter?.some((param) => {\n return param.value === \"enhanced_funnel_stage\";\n });\n });\n });\n\n spinner.stop();\n\n if (triggersToUpdate.length > 0) {\n console.log(\n chalk.cyan(`\\nFound ${triggersToUpdate.length} triggers to update:`)\n );\n triggersToUpdate.forEach((trigger) => {\n console.log(` - ${trigger.name} (ID: ${trigger.triggerId})`);\n });\n\n console.log(chalk.yellow(\"\\n🔄 Updating triggers...\"));\n\n for (const trigger of triggersToUpdate) {\n console.log(chalk.blue(` 📝 Updating ${trigger.name}:`));\n\n // Update the custom event filter to use lead_funnel_stage\n const updatedFilters = trigger.customEventFilter?.map((filter) => ({\n ...filter,\n parameter: filter.parameter?.map((param) => {\n if (param.value === \"enhanced_funnel_stage\") {\n console.log(\n chalk.gray(\n ` Event name: enhanced_funnel_stage → lead_funnel_stage`\n )\n );\n return { ...param, value: \"lead_funnel_stage\" };\n }\n return param;\n }),\n }));\n\n // Update the trigger directly via GTM API\n const triggerPath = `accounts/${\n (this.clients.gtm as any).config.accountId\n }/containers/${\n (this.clients.gtm as any).config.containerId\n }/workspaces/${(this.clients.gtm as any).workspaceId}/triggers/${\n trigger.triggerId\n }`;\n\n try {\n await (\n this.clients.gtm as any\n ).tagmanager.accounts.containers.workspaces.triggers.update({\n path: triggerPath,\n requestBody: {\n ...trigger,\n customEventFilter: updatedFilters,\n },\n });\n console.log(chalk.green(\" ✅ Updated successfully\"));\n } catch (error) {\n console.log(\n chalk.red(\n ` ❌ Failed to update: ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n );\n }\n }\n } else {\n console.log(\n chalk.green(\n \"\\n✅ No triggers need updating - all already use lead_funnel_stage\"\n )\n );\n }\n\n console.log(\"\");\n console.log(chalk.cyan(\"🎯 Next Steps:\"));\n console.log(\"1. Review the changes in GTM workspace\");\n console.log(\"2. Test the configuration in Preview mode\");\n console.log(\"3. Use GTM UI to publish workspace to production\");\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n // GTM publish functionality removed - use GTM UI for production publishing\n // Publishing via API has limitations and is not recommended for production use\n\n async posthogQuery(options: { query: string; limit: string }): Promise<void> {\n const spinner = ora(\"Executing PostHog query...\").start();\n\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const result = await this.clients.postHog.query({\n query: `${options.query} LIMIT ${options.limit}`,\n });\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.bold(\"\\n📊 PostHog Query Results\\n\"));\n console.log(JSON.stringify(result.data, null, 2));\n } else {\n console.error(chalk.red(\"Query failed:\"), result.error);\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async posthogFunnel(options: {\n events: string[];\n start: string;\n end: string;\n }): Promise<void> {\n const spinner = ora(\"Analyzing funnel...\").start();\n\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const funnelQuery = `\n\t\t\t\tSELECT \n\t\t\t\t\tfunnel_step,\n\t\t\t\t\tcount() as users,\n\t\t\t\t\tround(conversion_rate * 100, 2) as conversion_percentage\n\t\t\t\tFROM (\n\t\t\t\t\tSELECT \n\t\t\t\t\t\twindowFunnel(86400)([${options.events.map((e) => `'${e}'`).join(\", \")}])\n\t\t\t\t\t\t(timestamp, event) as funnel_steps,\n\t\t\t\t\t\tdistinct_id\n\t\t\t\t\tFROM events \n\t\t\t\t\tWHERE \n\t\t\t\t\t\tdate >= '${options.start}' \n\t\t\t\t\t\tAND date <= '${options.end}'\n\t\t\t\t\t\tAND event IN [${options.events.map((e) => `'${e}'`).join(\", \")}]\n\t\t\t\t\tGROUP BY distinct_id\n\t\t\t\t)\n\t\t\t\tCROSS JOIN ARRAY[${options.events\n .map((_, i) => i + 1)\n .join(\", \")}] as funnel_step\n\t\t\t\tWHERE funnel_steps >= funnel_step\n\t\t\t\tGROUP BY funnel_step\n\t\t\t\tORDER BY funnel_step\n\t\t\t`;\n\n const result = await this.clients.postHog.query({ query: funnelQuery });\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.bold(\"\\n🔄 Funnel Analysis Results\\n\"));\n console.log(JSON.stringify(result.data, null, 2));\n } else {\n console.error(chalk.red(\"Funnel analysis failed:\"), result.error);\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n // PostHog Feature Flags & Experiments\n async posthogListFlags(options: { project?: string }): Promise<void> {\n const spinner = ora(\"Fetching feature flags...\").start();\n\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const projectId = options.project\n ? parseInt(options.project, 10)\n : undefined;\n const result = await this.clients.postHog.getFeatureFlags(projectId);\n\n spinner.stop();\n\n if (result.success && result.data) {\n console.log(chalk.bold(\"\\n🏁 Feature Flags\\n\"));\n\n const tableData = [\n [\"ID\", \"Key\", \"Name\", \"Active\", \"Rollout\", \"Type\"],\n ...result.data.map((flag) => [\n flag.id.toString(),\n flag.key,\n flag.name,\n flag.active ? \"✅\" : \"❌\",\n flag.rollout_percentage ? `${flag.rollout_percentage}%` : \"100%\",\n flag.filters?.multivariate ? \"Experiment\" : \"Boolean\",\n ]),\n ];\n\n console.log(table(tableData));\n console.log(chalk.gray(`\\nTotal: ${result.data.length} flags`));\n } else {\n console.error(\n chalk.red(\"Failed to fetch feature flags:\"),\n result.error\n );\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async posthogGetFlag(options: {\n id: string;\n project?: string;\n }): Promise<void> {\n const spinner = ora(\"Fetching feature flag details...\").start();\n\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const flagId = parseInt(options.id, 10);\n const projectId = options.project\n ? parseInt(options.project, 10)\n : undefined;\n const result = await this.clients.postHog.getFeatureFlag(\n flagId,\n projectId\n );\n\n spinner.stop();\n\n if (result.success && result.data) {\n const flag = result.data;\n console.log(chalk.bold(\"\\n🏁 Feature Flag Details\\n\"));\n console.log(`${chalk.bold(\"ID:\")} ${flag.id}`);\n console.log(`${chalk.bold(\"Key:\")} ${flag.key}`);\n console.log(`${chalk.bold(\"Name:\")} ${flag.name}`);\n console.log(\n `${chalk.bold(\"Active:\")} ${flag.active ? \"✅ Yes\" : \"❌ No\"}`\n );\n console.log(\n `${chalk.bold(\"Rollout:\")} ${flag.rollout_percentage || 100}%`\n );\n console.log(\n `${chalk.bold(\"Continuity:\")} ${\n flag.ensure_experience_continuity ? \"✅ Yes\" : \"❌ No\"\n }`\n );\n\n if (flag.filters?.multivariate?.variants) {\n console.log(chalk.bold(\"\\nVariants:\"));\n flag.filters.multivariate.variants.forEach((variant: any) => {\n console.log(` • ${variant.key}: ${variant.rollout_percentage}%`);\n });\n }\n\n console.log(\n `${chalk.bold(\"Created:\")} ${new Date(\n flag.created_at\n ).toLocaleDateString()}`\n );\n } else {\n console.error(chalk.red(\"Failed to fetch feature flag:\"), result.error);\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async posthogCreateFlag(options: {\n key: string;\n name: string;\n description?: string;\n active: boolean;\n rollout: string;\n project?: string;\n }): Promise<void> {\n const spinner = ora(\"Creating feature flag...\").start();\n\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const projectId = options.project\n ? parseInt(options.project, 10)\n : undefined;\n const rolloutPercent = parseInt(options.rollout, 10);\n\n const flagPayload = {\n key: options.key,\n name: options.name,\n description: options.description,\n active: options.active,\n deleted: false,\n rollout_percentage: rolloutPercent,\n ensure_experience_continuity: true,\n };\n\n const result = await this.clients.postHog.createFeatureFlag(\n flagPayload,\n projectId\n );\n\n spinner.stop();\n\n if (result.success && result.data) {\n console.log(chalk.green(\"✅ Feature flag created successfully!\"));\n console.log(`${chalk.bold(\"ID:\")} ${result.data.id}`);\n console.log(`${chalk.bold(\"Key:\")} ${result.data.key}`);\n console.log(`${chalk.bold(\"Name:\")} ${result.data.name}`);\n } else {\n console.error(\n chalk.red(\"Failed to create feature flag:\"),\n result.error\n );\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async posthogCreateExperiment(options: {\n key: string;\n name: string;\n variants: string;\n description?: string;\n equalSplit: boolean;\n rollout: string;\n continuity: boolean;\n project?: string;\n }): Promise<void> {\n const spinner = ora(\"Creating multivariate experiment...\").start();\n\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const projectId = options.project\n ? parseInt(options.project, 10)\n : undefined;\n const rolloutPercent = parseInt(options.rollout, 10);\n const variantKeys = options.variants.split(\",\").map((v) => v.trim());\n\n // Calculate equal split percentages\n const percentagePerVariant = options.equalSplit\n ? Math.round((100 / variantKeys.length) * 100) / 100 // Round to 2 decimal places\n : 100 / variantKeys.length;\n\n const variants = variantKeys.map((key) => ({\n key,\n name: key.charAt(0).toUpperCase() + key.slice(1),\n rollout_percentage: percentagePerVariant,\n }));\n\n const experimentConfig = {\n key: options.key,\n name: options.name,\n description: options.description,\n variants,\n rollout_percentage: rolloutPercent,\n ensure_experience_continuity: options.continuity,\n };\n\n const result = await this.clients.postHog.createMultivariateExperiment(\n experimentConfig,\n projectId\n );\n\n spinner.stop();\n\n if (result.success && result.data) {\n console.log(\n chalk.green(\"✅ Multivariate experiment created successfully!\")\n );\n console.log(`${chalk.bold(\"ID:\")} ${result.data.id}`);\n console.log(`${chalk.bold(\"Key:\")} ${result.data.key}`);\n console.log(`${chalk.bold(\"Name:\")} ${result.data.name}`);\n console.log(`${chalk.bold(\"Variants:\")} ${variantKeys.join(\", \")}`);\n console.log(`${chalk.bold(\"Split:\")} ${percentagePerVariant}% each`);\n } else {\n console.error(chalk.red(\"Failed to create experiment:\"), result.error);\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async posthogUpdateFlag(options: {\n id: string;\n name?: string;\n description?: string;\n active?: string;\n rollout?: string;\n project?: string;\n }): Promise<void> {\n const spinner = ora(\"Updating feature flag...\").start();\n\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const flagId = parseInt(options.id, 10);\n const projectId = options.project\n ? parseInt(options.project, 10)\n : undefined;\n\n const updates: any = {};\n if (options.name) updates.name = options.name;\n if (options.description) updates.description = options.description;\n if (options.active) updates.active = options.active === \"true\";\n if (options.rollout)\n updates.rollout_percentage = parseInt(options.rollout, 10);\n\n const result = await this.clients.postHog.updateFeatureFlag(\n flagId,\n updates,\n projectId\n );\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green(\"✅ Feature flag updated successfully!\"));\n } else {\n console.error(\n chalk.red(\"Failed to update feature flag:\"),\n result.error\n );\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async posthogDeleteFlag(options: {\n id: string;\n project?: string;\n yes?: boolean;\n }): Promise<void> {\n try {\n if (!options.yes) {\n const answers = await inquirer.prompt([\n {\n type: \"confirm\",\n name: \"confirm\",\n message: `Are you sure you want to delete feature flag ${options.id}?`,\n default: false,\n },\n ]);\n\n if (!answers.confirm) {\n console.log(chalk.yellow(\"Operation cancelled.\"));\n return;\n }\n }\n\n const spinner = ora(\"Deleting feature flag...\").start();\n\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const flagId = parseInt(options.id, 10);\n const projectId = options.project\n ? parseInt(options.project, 10)\n : undefined;\n\n const result = await this.clients.postHog.deleteFeatureFlag(\n flagId,\n projectId\n );\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green(\"✅ Feature flag deleted successfully!\"));\n } else {\n console.error(\n chalk.red(\"Failed to delete feature flag:\"),\n result.error\n );\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async posthogEvaluateFlags(options: {\n user: string;\n groups?: string;\n personProps?: string;\n }): Promise<void> {\n const spinner = ora(\"Evaluating feature flags...\").start();\n\n try {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const payload: any = {\n distinctId: options.user,\n };\n\n if (options.groups) {\n payload.groups = JSON.parse(options.groups);\n }\n\n if (options.personProps) {\n payload.personProperties = JSON.parse(options.personProps);\n }\n\n const result = await this.clients.postHog.evaluateFeatureFlags(payload);\n\n spinner.stop();\n\n if (result.success && result.data) {\n console.log(chalk.bold(\"\\n🏁 Feature Flag Evaluation\\n\"));\n console.log(`${chalk.bold(\"User:\")} ${options.user}`);\n\n const flags = result.data.flags;\n if (Object.keys(flags).length === 0) {\n console.log(chalk.yellow(\"No feature flags matched for this user.\"));\n } else {\n console.log(chalk.bold(\"\\nActive Flags:\"));\n Object.entries(flags).forEach(([key, value]) => {\n const status =\n value === true ? \"✅\" : value === false ? \"❌\" : `🎯 ${value}`;\n console.log(` ${key}: ${status}`);\n });\n }\n\n const payloads = result.data.flagPayloads;\n if (Object.keys(payloads).length > 0) {\n console.log(chalk.bold(\"\\nFlag Payloads:\"));\n Object.entries(payloads).forEach(([key, payload]) => {\n console.log(` ${key}: ${JSON.stringify(payload)}`);\n });\n }\n } else {\n console.error(chalk.red(\"Failed to evaluate flags:\"), result.error);\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async googleAdsConversions(options: {\n start: string;\n end: string;\n }): Promise<void> {\n const spinner = ora(\"Fetching Google Ads conversions...\").start();\n\n try {\n if (!this.clients.googleAds) {\n const config = loadGoogleAdsConfig();\n this.clients.googleAds = new GoogleAdsClient({ config });\n }\n\n await this.clients.googleAds.authenticate();\n\n const result = await this.clients.googleAds.getConversions({\n startDate: options.start,\n endDate: options.end,\n });\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.bold(\"\\n💰 Google Ads Conversions\\n\"));\n console.log(JSON.stringify(result.data, null, 2));\n } else {\n console.error(chalk.red(\"Conversions fetch failed:\"), result.error);\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gscRankings(options: {\n keywords: string[];\n start: string;\n end: string;\n }): Promise<void> {\n const spinner = ora(\"Checking GSC keyword rankings...\").start();\n\n try {\n if (!this.clients.gsc) {\n const config = loadGSCConfig();\n this.clients.gsc = new GSCClient({ config });\n }\n\n await this.clients.gsc.authenticate();\n\n const keywordFilters = options.keywords.map((keyword) => ({\n dimension: \"query\",\n operator: \"contains\" as const,\n expression: keyword,\n }));\n\n const result = await this.clients.gsc.getSearchAnalytics({\n dimensions: [\"query\"],\n startDate: options.start,\n endDate: options.end,\n filters: keywordFilters,\n rowLimit: 1000,\n startRow: 0,\n });\n\n spinner.stop();\n\n if (result.success) {\n const rankings =\n result.data?.rows?.map((row) => ({\n keyword: row.keys?.[0],\n clicks: row.clicks,\n impressions: row.impressions,\n ctr: Math.round((row.ctr || 0) * 100 * 100) / 100,\n position: Math.round((row.position || 0) * 10) / 10,\n })) || [];\n\n console.log(chalk.bold(\"\\n🔍 GSC Keyword Rankings\\n\"));\n console.log(JSON.stringify(rankings, null, 2));\n } else {\n console.error(chalk.red(\"Rankings fetch failed:\"), result.error);\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async crossPlatformAnalysis(options: {\n start: string;\n end: string;\n platforms: string[];\n events?: string[];\n }): Promise<void> {\n const spinner = ora(\"Running cross-platform analysis...\").start();\n\n try {\n const results: Record<string, any> = {};\n\n for (const platform of options.platforms) {\n spinner.text = `Analyzing ${platform}...`;\n\n switch (platform) {\n case \"posthog\": {\n if (!this.clients.postHog) {\n const config = loadPostHogConfig();\n this.clients.postHog = new PostHogClient({ config });\n }\n\n const eventsQuery = options.events?.length\n ? `SELECT event, count() as event_count FROM events WHERE event IN [${options.events\n .map((e) => `'${e}'`)\n .join(\", \")}] AND date >= '${options.start}' AND date <= '${\n options.end\n }' GROUP BY event`\n : `SELECT event, count() as event_count FROM events WHERE date >= '${options.start}' AND date <= '${options.end}' GROUP BY event LIMIT 100`;\n\n const phResult = await this.clients.postHog.query({\n query: eventsQuery,\n });\n if (phResult.success) {\n results.posthog = phResult.data;\n }\n break;\n }\n\n case \"gsc\": {\n if (!this.clients.gsc) {\n const config = loadGSCConfig();\n this.clients.gsc = new GSCClient({ config });\n await this.clients.gsc.authenticate();\n }\n\n const gscResult = await this.clients.gsc.getSearchAnalytics({\n dimensions: [\"query\"],\n startDate: options.start,\n endDate: options.end,\n filters: [],\n rowLimit: 100,\n startRow: 0,\n });\n if (gscResult.success) {\n results.gsc = gscResult.data;\n }\n break;\n }\n\n case \"google-ads\": {\n if (!this.clients.googleAds) {\n const config = loadGoogleAdsConfig();\n this.clients.googleAds = new GoogleAdsClient({ config });\n await this.clients.googleAds.authenticate();\n }\n\n const gadsResult = await this.clients.googleAds.getConversions({\n startDate: options.start,\n endDate: options.end,\n });\n if (gadsResult.success) {\n results[\"google-ads\"] = gadsResult.data;\n }\n break;\n }\n }\n }\n\n spinner.stop();\n\n console.log(chalk.bold(\"\\n🔄 Cross-Platform Analysis\\n\"));\n console.log(JSON.stringify(results, null, 2));\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async interactiveSetup(): Promise<void> {\n console.log(chalk.bold(\"🚀 Interactive Analytics Setup\\n\"));\n\n const answers = await inquirer.prompt([\n {\n type: \"checkbox\",\n name: \"platforms\",\n message: \"Which platforms would you like to configure?\",\n choices: [\n { name: \"Google Tag Manager\", value: \"gtm\" },\n { name: \"Google Ads\", value: \"google-ads\" },\n { name: \"PostHog\", value: \"posthog\" },\n { name: \"Google Search Console\", value: \"gsc\" },\n ],\n },\n {\n type: \"confirm\",\n name: \"testConnections\",\n message: \"Would you like to test connections after setup?\",\n default: true,\n },\n ]);\n\n console.log(chalk.green(\"\\n✅ Setup configuration saved\"));\n console.log(\"Platform configurations:\", answers.platforms);\n\n if (answers.testConnections) {\n await this.healthCheck();\n }\n }\n\n async generateDashboard(options: {\n start: string;\n end: string;\n output: string;\n }): Promise<void> {\n const spinner = ora(\"Generating unified dashboard...\").start();\n\n try {\n const dashboardData = {\n date_range: { start: options.start, end: options.end },\n generated_at: new Date().toISOString(),\n summary: {\n platforms_analyzed: 0,\n total_events: 0,\n lead_score_average: 0,\n },\n platform_data: {} as Record<string, any>,\n };\n\n // Collect data from available platforms\n if (this.clients.postHog) {\n const leadEventsQuery = `\n\t\t\t\t\tSELECT \n\t\t\t\t\t\tevent,\n\t\t\t\t\t\tcount() as event_count,\n\t\t\t\t\t\tuniq(distinct_id) as unique_users\n\t\t\t\t\tFROM events \n\t\t\t\t\tWHERE date >= '${options.start}' \n\t\t\t\t\t\tAND date <= '${options.end}'\n\t\t\t\t\tGROUP BY event\n\t\t\t\t\tLIMIT 20\n\t\t\t\t`;\n\n const result = await this.clients.postHog.query({\n query: leadEventsQuery,\n });\n if (result.success) {\n dashboardData.platform_data.posthog = result.data;\n dashboardData.summary.platforms_analyzed++;\n }\n }\n\n spinner.stop();\n\n if (options.output === \"table\") {\n console.log(chalk.bold(\"\\n📊 Unified Analytics Dashboard\\n\"));\n\n const tableData = [[\"Metric\", \"Value\"]];\n tableData.push([\"Date Range\", `${options.start} to ${options.end}`]);\n tableData.push([\n \"Platforms Analyzed\",\n dashboardData.summary.platforms_analyzed.toString(),\n ]);\n tableData.push([\"Generated At\", dashboardData.generated_at]);\n\n console.log(table(tableData));\n } else {\n console.log(JSON.stringify(dashboardData, null, 2));\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n private calculateCustomLeadScore(event: LeadEvent): number {\n let score = LEAD_SCORES[event.event_name as keyof typeof LEAD_SCORES] || 0;\n\n if (event.properties) {\n if (event.properties.form_completion > 50) score += 10;\n if (event.properties.page_depth > 3) score += 5;\n if (event.properties.session_duration > 300) score += 5;\n if (event.properties.return_visitor) score += 10;\n }\n\n return Math.min(score, 100);\n }\n\n private getQualificationLevel(score: number): string {\n if (score >= 80) return \"hot\";\n if (score >= 60) return \"warm\";\n if (score >= 40) return \"cold\";\n return \"unqualified\";\n }\n\n // GTM Terraform Methods\n async gtmTerraformInit(options: { config: string }): Promise<void> {\n const spinner = ora(\"Initializing GTM Terraform workspace...\").start();\n\n try {\n const stateManager = new StateManager();\n await stateManager.initialize();\n\n const configParser = new ConfigParser();\n const config = await configParser.loadConfig(options.config);\n const validationResult = configParser.validateConfig(config);\n\n if (!validationResult.valid) {\n spinner.fail(\"Configuration validation failed\");\n console.error(chalk.red(\"Validation errors:\"));\n for (const error of validationResult.errors) {\n console.error(chalk.red(` - ${error}`));\n }\n return;\n }\n\n spinner.succeed(\"GTM Terraform workspace initialized\");\n console.log(chalk.green(`Configuration loaded from: ${options.config}`));\n console.log(chalk.green(`State directory: .gtm-state/`));\n } catch (error) {\n spinner.fail(\"Initialization failed\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmTerraformPlan(options: {\n config: string;\n out?: string;\n workspace?: string;\n }): Promise<void> {\n const spinner = ora(\"Generating GTM plan...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n // Select workspace\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace(\n options.workspace // Pass workspace ID if provided\n );\n if (!workspaceResult.success) {\n throw new Error(\n `Failed to select workspace: ${workspaceResult.error}`\n );\n }\n }\n\n const stateManager = new StateManager();\n const configParser = new ConfigParser();\n const planner = new Planner(this.clients.gtm, configParser);\n\n const config = await configParser.loadConfig(options.config);\n const currentState = (await stateManager.load()) || {\n version: \"1.0.0\",\n terraform_version: \"0.1.0\",\n serial: 1,\n lineage: crypto.randomUUID(),\n outputs: {},\n resources: [],\n check_results: [],\n };\n\n const planResult = await planner.plan(config, currentState);\n\n spinner.stop();\n\n if (planResult.success && planResult.data) {\n const formattedPlan = planner.formatPlan(planResult.data);\n console.log(formattedPlan);\n\n if (options.out) {\n await fs.writeFile(\n options.out,\n JSON.stringify(planResult.data, null, 2)\n );\n console.log(chalk.green(`Plan saved to: ${options.out}`));\n }\n\n console.log(\n chalk.blue(`\\nPlan: ${planResult.resource_changes} changes`)\n );\n } else {\n console.error(chalk.red(\"Plan generation failed:\"), planResult.error);\n }\n } catch (error) {\n spinner.fail(\"Plan generation failed\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmTerraformApply(options: {\n config: string;\n plan?: string;\n workspace?: string;\n yes?: boolean;\n verbose?: boolean;\n }): Promise<void> {\n const spinner = ora(\"Applying GTM configuration changes...\").start();\n\n // Verbose logging helper\n const verboseLog = (message: string, data?: any) => {\n if (options.verbose) {\n spinner.stop();\n console.log(chalk.cyan(`[VERBOSE] ${message}`));\n if (data) {\n console.log(chalk.dim(JSON.stringify(data, null, 2)));\n }\n spinner.start();\n }\n };\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n // Select workspace\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace(\n options.workspace // Pass workspace ID if provided\n );\n if (!workspaceResult.success) {\n throw new Error(\n `Failed to select workspace: ${workspaceResult.error}`\n );\n }\n }\n\n const stateManager = new StateManager();\n const configParser = new ConfigParser();\n const planner = new Planner(this.clients.gtm, configParser);\n\n // Load configuration\n spinner.text = \"Loading configuration...\";\n const config = await configParser.loadConfig(options.config);\n this.currentConfig = config; // Store config for variable resolution\n const currentState = (await stateManager.load()) || {\n version: \"1.0.0\",\n terraform_version: \"0.1.0\",\n serial: 1,\n lineage: crypto.randomUUID(),\n outputs: {},\n resources: [],\n check_results: [],\n };\n\n // Generate plan\n spinner.text = \"Generating execution plan...\";\n const planResult = await planner.plan(config, currentState);\n\n if (!planResult.success || !planResult.data) {\n throw new Error(`Plan generation failed: ${planResult.error}`);\n }\n\n const plan = planResult.data;\n console.log(\n chalk.blue(`\\nApplying changes: ${plan.changes.length} operations\\n`)\n );\n\n // Verbose logging for plan analysis\n verboseLog(`Plan generated with ${plan.changes.length} changes`);\n if (options.verbose) {\n for (const change of plan.changes) {\n verboseLog(\n `Change: ${change.address} (${change.change.actions.join(\", \")})`,\n {\n type: change.type,\n name: change.name,\n actions: change.change.actions,\n hasAfter: !!change.change.after,\n hasBefore: !!change.change.before,\n }\n );\n }\n }\n\n // Separate changes by action type\n const deleteChanges = plan.changes.filter((c) =>\n c.change.actions.includes(\"delete\")\n );\n const createChanges = plan.changes.filter((c) =>\n c.change.actions.includes(\"create\")\n );\n const updateChanges = plan.changes.filter((c) =>\n c.change.actions.includes(\"update\")\n );\n\n verboseLog(\n `Changes breakdown: ${deleteChanges.length} deletes, ${createChanges.length} creates, ${updateChanges.length} updates`\n );\n\n // Execute destroys first (remove unwanted resources)\n if (deleteChanges.length > 0) {\n spinner.text = `Removing ${deleteChanges.length} legacy resources...`;\n verboseLog(`Starting deletion of ${deleteChanges.length} resources`);\n\n for (const change of deleteChanges) {\n await this.smartDelay(); // GTM API rate limiting\n verboseLog(\n `Processing deletion for ${change.address} (${change.name})`\n );\n\n if (options.verbose) {\n console.log(\n chalk.magenta(\n `\\n=== VERBOSE DELETE: ${change.type\n .replace(\"gtm_\", \"\")\n .toUpperCase()} ===`\n )\n );\n console.log(\n chalk.cyan(\n `Resource Name: ${change.change?.before?.name || change.name}`\n )\n );\n console.log(\n chalk.cyan(\n `Resource ID: ${\n change.change?.before?.tagId ||\n change.change?.before?.triggerId ||\n change.change?.before?.variableId\n }`\n )\n );\n console.log(chalk.yellow(`Before state (to be deleted):`));\n console.log(JSON.stringify(change.change?.before, null, 2));\n }\n\n try {\n // Check and handle dependencies before deletion\n const canDelete = await this.handleDependenciesBeforeDeletion(\n change\n );\n if (!canDelete) {\n console.warn(\n chalk.yellow(\n `Skipping deletion of ${change.name} due to dependency issues`\n )\n );\n verboseLog(`Skipped deletion due to dependencies`, {\n resource: change.name,\n });\n continue;\n }\n\n // Extract resource type from the type field (e.g., 'gtm_tag' -> 'tag')\n const resourceType = change.type.replace(\"gtm_\", \"\");\n verboseLog(`Deleting ${resourceType}: ${change.name}`);\n\n if (resourceType === \"tag\" && change.change?.before?.tagId) {\n const deleteResult = await this.clients.gtm.deleteTag(\n change.change.before.tagId\n );\n\n if (options.verbose) {\n console.log(chalk.blue(`Delete API response:`));\n console.log(JSON.stringify(deleteResult, null, 2));\n }\n\n if (deleteResult.success) {\n console.log(\n chalk.red(\n `- Removed tag: ${change.change.before.name || change.name}`\n )\n );\n verboseLog(`Successfully deleted tag`, {\n id: change.change.before.tagId,\n });\n } else {\n // Fail fast on delete errors\n console.error(\n chalk.red(\n `[ERROR] Failed to delete tag \"${\n change.change.before.name || change.name\n }\" (ID: ${change.change.before.tagId}): ${\n deleteResult.error\n }`\n )\n );\n throw new Error(`Tag deletion failed: ${deleteResult.error}`);\n }\n } else if (\n resourceType === \"trigger\" &&\n change.change?.before?.triggerId\n ) {\n const deleteResult = await this.clients.gtm.deleteTrigger(\n change.change.before.triggerId\n );\n\n if (options.verbose) {\n console.log(chalk.blue(`Delete API response:`));\n console.log(JSON.stringify(deleteResult, null, 2));\n }\n\n if (deleteResult.success) {\n console.log(\n chalk.red(\n `- Removed trigger: ${\n change.change.before.name || change.name\n }`\n )\n );\n verboseLog(`Successfully deleted trigger`, {\n id: change.change.before.triggerId,\n });\n } else {\n // Fail fast on delete errors\n console.error(\n chalk.red(\n `[ERROR] Failed to delete trigger \"${\n change.change.before.name || change.name\n }\" (ID: ${change.change.before.triggerId}): ${\n deleteResult.error\n }`\n )\n );\n throw new Error(\n `Trigger deletion failed: ${deleteResult.error}`\n );\n }\n } else if (\n resourceType === \"variable\" &&\n change.change?.before?.variableId\n ) {\n const deleteResult = await this.clients.gtm.deleteVariable(\n change.change.before.variableId\n );\n\n if (options.verbose) {\n console.log(chalk.blue(`Delete API response:`));\n console.log(JSON.stringify(deleteResult, null, 2));\n }\n\n if (deleteResult.success) {\n console.log(\n chalk.red(\n `- Removed variable: ${\n change.change.before.name || change.name\n }`\n )\n );\n verboseLog(`Successfully deleted variable`, {\n id: change.change.before.variableId,\n });\n } else {\n // Fail fast on delete errors\n console.error(\n chalk.red(\n `[ERROR] Failed to delete variable \"${\n change.change.before.name || change.name\n }\" (ID: ${change.change.before.variableId}): ${\n deleteResult.error\n }`\n )\n );\n throw new Error(\n `Variable deletion failed: ${deleteResult.error}`\n );\n }\n }\n\n if (options.verbose) {\n console.log(chalk.magenta(`=== END VERBOSE DELETE ===\\n`));\n }\n } catch (error) {\n // Log the error and fail fast\n console.error(\n chalk.red(\n `Failed to delete ${change.type} ${change.name}: ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n );\n\n if (options.verbose) {\n console.log(\n chalk.red(\n `Error Stack: ${error instanceof Error ? error.stack : \"N/A\"}`\n )\n );\n }\n\n spinner.fail(\"Apply failed during deletion phase\");\n throw error;\n }\n }\n verboseLog(`Completed deletion of ${deleteChanges.length} resources`);\n }\n\n // Execute creates (add new resources) using batch processing\n if (createChanges.length > 0) {\n spinner.text = `Creating ${createChanges.length} new resources in batches...`;\n\n // Group changes by resource type for better batch processing\n const variableChanges = createChanges.filter(\n (c) => c.type === \"gtm_variable\"\n );\n const triggerChanges = createChanges.filter(\n (c) => c.type === \"gtm_trigger\"\n );\n const tagChanges = createChanges.filter((c) => c.type === \"gtm_tag\");\n\n // Process variables first (they're often used by other resources)\n if (variableChanges.length > 0) {\n const variableOps = variableChanges.map((change) => ({\n fn: async () => {\n if (!change.change?.after) return null;\n const variableConfig =\n this.transformVariableConfigWithWorkingTransformer(\n change.change.after\n );\n const result = await this.clients.gtm.createVariable(\n variableConfig\n );\n if (result.success) {\n console.log(\n chalk.green(\n `+ Created variable: ${\n change.change.after.name || change.name\n }`\n )\n );\n } else {\n // Fail fast if enabled\n const error = new Error(\n `Failed to create variable \"${\n change.change.after.name || change.name\n }\": ${result.error}`\n );\n console.error(\n chalk.red(\n `[ERROR] Failed to create variable \"${\n change.change.after.name || change.name\n }\" { error: '${result.error}' }`\n )\n );\n throw error;\n }\n return result;\n },\n context: `variable ${change.name}`,\n }));\n\n spinner.text = `Creating ${variableChanges.length} variables...`;\n await this.clients.gtm.rateLimiter.executeBatch(variableOps, 3); // Smaller batches for variables\n }\n\n // Process triggers second (they're used by tags)\n if (triggerChanges.length > 0) {\n const triggerOps = triggerChanges.map((change) => ({\n fn: async () => {\n if (!change.change?.after) return null;\n const triggerConfig = this.transformTriggerConfig(\n change.change.after\n );\n const result = await this.clients.gtm.createTrigger(\n triggerConfig\n );\n if (result.success) {\n console.log(\n chalk.green(\n `+ Created trigger: ${\n change.change.after.name || change.name\n }`\n )\n );\n } else {\n // Fail fast if enabled\n const error = new Error(\n `Failed to create trigger \"${\n change.change.after.name || change.name\n }\": ${result.error}`\n );\n console.error(\n chalk.red(\n `[ERROR] Failed to create trigger \"${\n change.change.after.name || change.name\n }\" { error: '${result.error}' }`\n )\n );\n throw error;\n }\n return result;\n },\n context: `trigger ${change.name}`,\n }));\n\n spinner.text = `Creating ${triggerChanges.length} triggers...`;\n await this.clients.gtm.rateLimiter.executeBatch(triggerOps, 4); // Medium batches for triggers\n }\n\n // Process tags last (they depend on variables and triggers)\n if (tagChanges.length > 0) {\n const tagOps = tagChanges.map((change) => ({\n fn: async () => {\n if (!change.change?.after) return null;\n const tagConfig = this.transformTagConfig(change.change.after);\n\n // Resolve trigger names to IDs if needed\n if (tagConfig.firingTriggerName) {\n const triggerIds = await this.resolveTriggerNames(\n tagConfig.firingTriggerName\n );\n tagConfig.firingTriggerId = triggerIds;\n delete tagConfig.firingTriggerName;\n }\n\n const result = await this.clients.gtm.createTag(tagConfig);\n if (result.success) {\n console.log(\n chalk.green(\n `+ Created tag: ${change.change.after.name || change.name}`\n )\n );\n } else {\n // Fail fast if enabled\n const error = new Error(\n `Failed to create tag \"${\n change.change.after.name || change.name\n }\": ${result.error}`\n );\n console.error(\n chalk.red(\n `[ERROR] Failed to create tag \"${\n change.change.after.name || change.name\n }\" { error: '${result.error}' }`\n )\n );\n throw error;\n }\n return result;\n },\n context: `tag ${change.name}`,\n }));\n\n spinner.text = `Creating ${tagChanges.length} tags...`;\n await this.clients.gtm.rateLimiter.executeBatch(tagOps, 3); // Smaller batches for tags\n }\n }\n\n // Execute updates using the enhanced executeUpdate function\n if (updateChanges.length > 0) {\n spinner.text = `Updating ${updateChanges.length} resources...`;\n verboseLog(`Processing ${updateChanges.length} update operations`);\n\n const updateResults = {\n updated: 0,\n errors: [] as string[],\n };\n\n for (const change of updateChanges) {\n verboseLog(\n `Processing update for ${change.address} (${change.name})`\n );\n await this.smartDelay(); // GTM API rate limiting\n\n // Use the enhanced executeUpdate function with verbose logging\n await this.executeUpdate(change, updateResults, options.verbose);\n }\n\n // Report any errors from the update process\n if (updateResults.errors.length > 0) {\n console.error(chalk.red(`\\n❌ Update errors occurred:`));\n updateResults.errors.forEach((error) => {\n console.error(chalk.red(` • ${error}`));\n });\n throw new Error(\n `Failed to update ${updateResults.errors.length} resources`\n );\n }\n\n verboseLog(`Successfully updated ${updateResults.updated} resources`);\n }\n\n // Update state file\n spinner.text = \"Updating state file...\";\n const newState = {\n ...currentState,\n serial: currentState.serial + 1,\n resources: plan.final_state || currentState.resources,\n };\n await stateManager.save(newState);\n\n spinner.stop();\n console.log(chalk.green(\"\\n✅ GTM configuration applied successfully!\"));\n console.log(chalk.blue(\"\\n📋 Summary:\"));\n console.log(chalk.blue(` Resources removed: ${deleteChanges.length}`));\n console.log(chalk.blue(` Resources created: ${createChanges.length}`));\n console.log(chalk.blue(` Resources updated: ${updateChanges.length}`));\n console.log(chalk.yellow(\"\\n🚀 Next steps:\"));\n console.log(\n chalk.yellow(\" 1. Test the configuration in GTM Preview mode\")\n );\n console.log(\n chalk.yellow(\" 2. Use GTM UI to publish workspace to production\")\n );\n } catch (error) {\n spinner.fail(\"Apply failed\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n /**\n * Enhanced incremental sync with validation and proper error handling\n */\n async gtmIncrementalSync(options: {\n config: string;\n dryRun?: boolean;\n }): Promise<void> {\n const spinner = ora(\"Starting incremental GTM sync...\").start();\n const results = {\n validated: 0,\n created: 0,\n updated: 0,\n deleted: 0,\n errors: [] as string[],\n warnings: [] as string[],\n };\n\n try {\n // 1. Load and validate configuration\n spinner.text = \"Loading and validating configuration...\";\n const configParser = new ConfigParser();\n let config = await configParser.loadConfig(options.config);\n\n // Resolve variable references in the config\n config = configParser.resolveVariables(config);\n\n const validation = configParser.validateConfig(config);\n if (!validation.valid) {\n throw new Error(\n `Configuration validation failed:\\n${validation.errors.join(\"\\n\")}`\n );\n }\n results.validated = validation.errors.length === 0 ? 1 : 0;\n\n // 2. Setup GTM client with authentication\n if (!this.clients.gtm) {\n const gtmConfig = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config: gtmConfig });\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`GTM authentication failed: ${authResult.error}`);\n }\n\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(\n `Workspace selection failed: ${workspaceResult.error}`\n );\n }\n }\n\n // 3. Generate incremental plan\n spinner.text = \"Analyzing changes and generating plan...\";\n const planner = new Planner(this.clients.gtm, configParser);\n const stateManager = new StateManager();\n\n let currentState = await stateManager.load();\n if (!currentState) {\n // Initialize empty state if none exists\n currentState = {\n version: \"1.0.0\",\n terraform_version: \"0.1.0\",\n serial: 0,\n lineage: crypto.randomUUID(),\n outputs: {},\n resources: [],\n check_results: [],\n };\n }\n\n const planResult = await planner.plan(config, currentState);\n if (!planResult.success) {\n throw new Error(`Plan generation failed: ${planResult.error}`);\n }\n\n const plan = planResult.data!;\n console.log(chalk.blue(\"\\n📋 Planned Changes:\"));\n console.log(planner.formatPlan(plan));\n\n if (plan.changes.length === 0) {\n spinner.succeed(\"No changes needed - configuration is up to date\");\n return;\n }\n\n if (options.dryRun) {\n spinner.succeed(\n `Dry run completed - ${plan.changes.length} changes planned`\n );\n return;\n }\n\n // 4. Execute changes incrementally with rate limiting\n spinner.text = \"Applying changes incrementally...\";\n // GTM API limit: 0.25 QPS = 1 request every 4 seconds\n // Use 5 seconds to be safe: 5000ms between API calls\n const delayMs = 5000;\n\n // Group changes by operation type\n const creates = plan.changes.filter((c) =>\n c.change.actions.includes(\"create\")\n );\n const updates = plan.changes.filter((c) =>\n c.change.actions.includes(\"update\")\n );\n const deletes = plan.changes.filter((c) =>\n c.change.actions.includes(\"delete\")\n );\n\n // Execute deletions first (cleanup)\n for (const change of deletes) {\n await this.smartDelay(); // Intelligent rate limiting\n await this.executeDelete(change, results);\n }\n\n // Then execute creates\n for (const change of creates) {\n await this.smartDelay(); // Intelligent rate limiting\n await this.executeCreate(change, results);\n }\n\n // Finally execute updates\n for (const change of updates) {\n await this.smartDelay(); // Intelligent rate limiting\n await this.executeUpdate(change, results);\n }\n\n // 5. Update state with successful changes\n spinner.text = \"Updating state file...\";\n const newState = {\n ...currentState,\n serial: currentState.serial + 1,\n resources:\n plan.planned_values?.root_module?.resources?.map((r) => ({\n mode: \"managed\" as const,\n type: r.type,\n name: r.name,\n provider: 'provider[\"gtm\"]',\n instances: [\n {\n schema_version: 1,\n attributes: r.values,\n sensitive_attributes: [],\n private: \"\",\n dependencies: [],\n },\n ],\n })) || currentState.resources,\n };\n await stateManager.save(newState);\n\n // 6. Report results\n spinner.succeed(\"Incremental sync completed successfully\");\n console.log(chalk.green(\"\\n✅ Sync Results:\"));\n console.log(\n chalk.blue(\n ` Configuration validated: ${results.validated ? \"Yes\" : \"No\"}`\n )\n );\n console.log(chalk.blue(` Resources created: ${results.created}`));\n console.log(chalk.blue(` Resources updated: ${results.updated}`));\n console.log(chalk.blue(` Resources deleted: ${results.deleted}`));\n\n if (results.warnings.length > 0) {\n console.log(chalk.yellow(` Warnings: ${results.warnings.length}`));\n results.warnings.forEach((w) =>\n console.log(chalk.yellow(` - ${w}`))\n );\n }\n\n if (results.errors.length > 0) {\n console.log(chalk.red(` Errors: ${results.errors.length}`));\n results.errors.forEach((e) => console.log(chalk.red(` - ${e}`)));\n }\n } catch (error) {\n spinner.fail(\"Incremental sync failed\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n throw error;\n }\n }\n\n private async executeDelete(change: any, results: any): Promise<void> {\n try {\n const resourceType = change.type.replace(\"gtm_\", \"\");\n const resourceData = change.change.before;\n\n let deleteResult: any;\n switch (resourceType) {\n case \"tag\":\n deleteResult = await this.clients.gtm.deleteTag(resourceData.tagId);\n break;\n case \"trigger\":\n deleteResult = await this.clients.gtm.deleteTrigger(\n resourceData.triggerId\n );\n break;\n case \"variable\":\n deleteResult = await this.clients.gtm.deleteVariable(\n resourceData.variableId\n );\n break;\n }\n\n if (deleteResult?.success) {\n results.deleted++;\n console.log(\n chalk.red(`- Deleted ${resourceType}: ${resourceData.name}`)\n );\n } else {\n results.errors.push(\n `Failed to delete ${resourceType}: ${resourceData.name}`\n );\n }\n } catch (error) {\n results.errors.push(\n `Delete error: ${\n error instanceof Error ? error.message : String(error)\n }`\n );\n }\n }\n\n private async executeCreate(change: any, results: any): Promise<void> {\n try {\n const resourceType = change.type.replace(\"gtm_\", \"\");\n const resourceData = change.change.after;\n\n // Transform YAML config to GTM API format\n const transformedData = this.transformResourceForGTM(\n resourceType,\n resourceData\n );\n\n let createResult: any;\n switch (resourceType) {\n case \"tag\":\n createResult = await this.clients.gtm.createTag(transformedData);\n break;\n case \"trigger\":\n createResult = await this.clients.gtm.createTrigger(transformedData);\n break;\n case \"variable\":\n createResult = await this.clients.gtm.createVariable(transformedData);\n break;\n }\n\n if (createResult?.success) {\n results.created++;\n console.log(\n chalk.green(`+ Created ${resourceType}: ${resourceData.name}`)\n );\n } else {\n results.errors.push(\n `Failed to create ${resourceType}: ${resourceData.name}`\n );\n }\n } catch (error) {\n results.errors.push(\n `Create error: ${\n error instanceof Error ? error.message : String(error)\n }`\n );\n }\n }\n\n private async executeUpdate(\n change: any,\n results: any,\n verbose: boolean = false\n ): Promise<void> {\n try {\n const resourceType = change.type.replace(\"gtm_\", \"\");\n const beforeData = change.change.before;\n const afterData = change.change.after;\n\n // Check if resource has a valid ID - if not, it needs to be created not updated\n const resourceId =\n beforeData?.tagId || beforeData?.triggerId || beforeData?.variableId;\n if (!resourceId || resourceId === \"undefined\") {\n console.log(\n chalk.yellow(\n `[WARN] Resource \"${afterData.name}\" has no ID - treating as create instead of update`\n )\n );\n\n // Transform to a create operation\n let createResult: any;\n switch (resourceType) {\n case \"tag\":\n const tagConfig = this.transformTagConfig(afterData);\n createResult = await this.clients.gtm.createTag(tagConfig);\n break;\n case \"trigger\":\n const triggerConfig = this.transformTriggerConfig(afterData);\n createResult = await this.clients.gtm.createTrigger(triggerConfig);\n break;\n case \"variable\":\n createResult = await this.clients.gtm.createVariable(afterData);\n break;\n default:\n throw new Error(`Unknown resource type: ${resourceType}`);\n }\n\n if (createResult.success) {\n console.log(\n chalk.green(`+ Created ${resourceType}: ${afterData.name}`)\n );\n results.created = (results.created || 0) + 1;\n } else {\n console.log(\n chalk.red(\n `[ERROR] Failed to create ${resourceType}: ${afterData.name}`\n ),\n createResult.error\n );\n results.errors.push(\n `Failed to create ${resourceType}: ${afterData.name} - ${createResult.error}`\n );\n }\n return;\n }\n\n if (verbose) {\n console.log(\n chalk.magenta(\n `\\n=== VERBOSE UPDATE: ${resourceType.toUpperCase()} ===`\n )\n );\n console.log(\n chalk.cyan(`Resource Name: ${afterData.name || beforeData.name}`)\n );\n console.log(\n chalk.cyan(\n `Resource ID: ${\n beforeData.tagId || beforeData.triggerId || beforeData.variableId\n }`\n )\n );\n console.log(chalk.yellow(`Before state:`));\n console.log(JSON.stringify(beforeData, null, 2));\n console.log(chalk.green(`After state (config):`));\n console.log(JSON.stringify(afterData, null, 2));\n }\n\n let updateResult: any;\n let transformedConfig: any;\n\n switch (resourceType) {\n case \"tag\": {\n // Transform the tag config and resolve triggers\n transformedConfig = this.transformTagConfig(afterData);\n\n if (verbose) {\n console.log(chalk.blue(`Transformed config for GTM API:`));\n console.log(JSON.stringify(transformedConfig, null, 2));\n }\n\n // CRITICAL: Preserve existing trigger associations\n // If current tag has no firingTriggerId but config specifies triggers, add them\n // If current tag has firingTriggerId, merge with config (don't replace)\n if (\n transformedConfig.firingTriggerName &&\n Array.isArray(transformedConfig.firingTriggerName)\n ) {\n console.log(\n chalk.cyan(\n `[INFO] Adding missing triggers to tag: ${afterData.name}`\n )\n );\n console.log(\n chalk.cyan(\n `[INFO] Triggers to add: ${transformedConfig.firingTriggerName.join(\n \", \"\n )}`\n )\n );\n\n const triggerIds = await this.resolveTriggerNames(\n transformedConfig.firingTriggerName\n );\n if (triggerIds.length > 0) {\n // Preserve existing triggers if they exist\n const existingTriggers = beforeData.firingTriggerId || [];\n const allTriggers = [\n ...new Set([...existingTriggers, ...triggerIds]),\n ];\n\n transformedConfig.firingTriggerId = allTriggers;\n delete transformedConfig.firingTriggerName;\n\n console.log(\n chalk.green(\n `[INFO] Final trigger IDs: ${allTriggers.join(\", \")}`\n )\n );\n\n if (verbose) {\n console.log(chalk.magenta(`Trigger resolution details:`));\n console.log(\n chalk.cyan(\n ` Original trigger names: ${\n transformedConfig.firingTriggerName || \"none\"\n }`\n )\n );\n console.log(\n chalk.cyan(` Resolved trigger IDs: ${triggerIds.join(\", \")}`)\n );\n console.log(\n chalk.cyan(\n ` Existing trigger IDs: ${existingTriggers.join(\", \")}`\n )\n );\n console.log(\n chalk.cyan(` Merged trigger IDs: ${allTriggers.join(\", \")}`)\n );\n }\n } else {\n console.log(\n chalk.yellow(\n `[WARN] Could not resolve any trigger names for ${afterData.name}`\n )\n );\n // Don't update if we can't resolve triggers - preserve current state\n delete transformedConfig.firingTriggerName;\n }\n }\n\n // Apply filtering to match GTM update patterns\n const filteredConfig = this.filterTagUpdateFields(transformedConfig);\n\n if (verbose) {\n console.log(chalk.blue(`Final filtered config sent to GTM:`));\n console.log(JSON.stringify(filteredConfig, null, 2));\n }\n\n updateResult = await this.clients.gtm.updateTag(\n beforeData.tagId,\n filteredConfig\n );\n break;\n }\n case \"trigger\": {\n // Apply filtering to match GTM update patterns\n transformedConfig = this.filterTriggerUpdateFields(afterData);\n\n if (verbose) {\n console.log(chalk.blue(`Filtered trigger config sent to GTM:`));\n console.log(JSON.stringify(transformedConfig, null, 2));\n }\n\n updateResult = await this.clients.gtm.updateTrigger(\n beforeData.triggerId,\n transformedConfig\n );\n break;\n }\n case \"variable\": {\n // Apply filtering to match GTM update patterns\n transformedConfig = this.filterVariableUpdateFields(afterData);\n\n if (verbose) {\n console.log(chalk.blue(`Filtered variable config sent to GTM:`));\n console.log(JSON.stringify(transformedConfig, null, 2));\n }\n\n updateResult = await this.clients.gtm.updateVariable(\n beforeData.variableId,\n transformedConfig\n );\n break;\n }\n }\n\n if (verbose && updateResult) {\n console.log(chalk.magenta(`GTM API Response:`));\n console.log(JSON.stringify(updateResult, null, 2));\n console.log(chalk.magenta(`=== END VERBOSE UPDATE ===\\n`));\n }\n\n if (updateResult?.success) {\n results.updated++;\n console.log(chalk.blue(`~ Updated ${resourceType}: ${afterData.name}`));\n } else {\n results.errors.push(\n `Failed to update ${resourceType}: ${afterData.name}`\n );\n console.log(\n chalk.red(\n `[ERROR] Failed to update ${resourceType}: ${afterData.name}`\n )\n );\n if (verbose && updateResult?.error) {\n console.log(chalk.red(`API Error Details: ${updateResult.error}`));\n }\n }\n } catch (error) {\n results.errors.push(\n `Update error: ${\n error instanceof Error ? error.message : String(error)\n }`\n );\n console.log(\n chalk.red(\n `[ERROR] Update error: ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n );\n\n if (verbose) {\n console.log(\n chalk.red(\n `Error Stack: ${error instanceof Error ? error.stack : \"N/A\"}`\n )\n );\n }\n }\n }\n\n /**\n * Fix variable references in all GTM tags\n * Updates tags with incorrect variable references to use the correct GTM variable names\n */\n async gtmFixVariableReferences(\n options: { dryRun?: boolean } = {}\n ): Promise<void> {\n const spinner = ora(\"Fixing variable references in GTM tags...\").start();\n\n try {\n // Initialize GTM client\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(\n `Failed to select workspace: ${workspaceResult.error}`\n );\n }\n }\n\n // Get all tags\n spinner.text = \"Fetching tags from GTM...\";\n const tagsResult = await this.clients.gtm.listTags();\n if (!tagsResult.success || !tagsResult.data) {\n throw new Error(\"Failed to fetch tags\");\n }\n\n // Find tags that need fixing\n const tagsToFix: Array<{\n tag: any;\n fixes: Array<{ param: any; oldValue: string; newValue: string }>;\n }> = [];\n\n for (const tag of tagsResult.data) {\n const fixes: Array<{ param: any; oldValue: string; newValue: string }> =\n [];\n\n // Check each parameter for variable references that need fixing\n if (tag.parameter && Array.isArray(tag.parameter)) {\n for (const param of tag.parameter) {\n if (param.value && typeof param.value === \"string\") {\n const newValue = this.resolveVariableReferences(param.value);\n if (newValue !== param.value) {\n fixes.push({ param, oldValue: param.value, newValue });\n }\n }\n }\n }\n\n if (fixes.length > 0) {\n tagsToFix.push({ tag, fixes });\n }\n }\n\n if (tagsToFix.length === 0) {\n spinner.succeed(\"No tags need variable reference fixes\");\n return;\n }\n\n // Display what will be fixed\n spinner.stop();\n console.log(\n chalk.cyan(\n `\\n📋 Found ${tagsToFix.length} tags with incorrect variable references:\\n`\n )\n );\n\n for (const { tag, fixes } of tagsToFix) {\n console.log(chalk.yellow(`\\n🏷️ ${tag.name} (ID: ${tag.tagId})`));\n for (const { param, oldValue, newValue } of fixes) {\n console.log(` ${chalk.red(\"- \" + param.key + \": \" + oldValue)}`);\n console.log(` ${chalk.green(\"+ \" + param.key + \": \" + newValue)}`);\n }\n }\n\n if (options.dryRun) {\n console.log(chalk.blue(\"\\n✨ Dry run mode - no changes were made\"));\n return;\n }\n\n // Apply fixes\n console.log(chalk.cyan(\"\\n🔧 Applying fixes...\\n\"));\n const updateSpinner = ora(\"Updating tags...\").start();\n\n let successCount = 0;\n let failCount = 0;\n\n for (const { tag, fixes } of tagsToFix) {\n try {\n // Create updated parameters array\n const updatedParameters = tag.parameter.map((param: any) => {\n const fix = fixes.find((f) => f.param === param);\n if (fix) {\n return { ...param, value: fix.newValue };\n }\n return param;\n });\n\n // Update the tag\n updateSpinner.text = `Updating ${tag.name}...`;\n const updateResult = await this.clients.gtm.updateTag(tag.tagId, {\n parameter: updatedParameters,\n });\n\n if (updateResult.success) {\n successCount++;\n console.log(chalk.green(`✅ Fixed: ${tag.name}`));\n } else {\n failCount++;\n console.log(\n chalk.red(`❌ Failed to fix ${tag.name}: ${updateResult.error}`)\n );\n }\n } catch (error) {\n failCount++;\n console.log(\n chalk.red(\n `❌ Error fixing ${tag.name}: ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n );\n }\n }\n\n updateSpinner.stop();\n\n // Summary\n console.log(chalk.cyan(\"\\n📊 Summary:\"));\n console.log(chalk.green(` ✅ Successfully fixed: ${successCount} tags`));\n if (failCount > 0) {\n console.log(chalk.red(` ❌ Failed: ${failCount} tags`));\n }\n\n if (successCount > 0) {\n console.log(\n chalk.yellow(\n \"\\n⚠️ Remember to publish the workspace to apply changes to production\"\n )\n );\n }\n } catch (error) {\n spinner.fail(\"Failed to fix variable references\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n private currentConfig: any = null;\n\n private getConfigVariables(): any {\n if (!this.currentConfig) {\n console.warn(\"No current config loaded for variable resolution\");\n return {};\n }\n\n const vars = this.currentConfig?.variables || {};\n console.log(\"Available config variables:\", Object.keys(vars));\n return vars;\n }\n\n /**\n * Resolve variable references in tag parameter values\n * Maps old variable references to new GTM variable names\n */\n private resolveVariableReferences(value: string): string {\n if (typeof value !== \"string\") return value;\n\n // Define variable reference mappings\n const variableMap: Record<string, string> = {\n \"{{ecommerce.value}}\": \"{{Ecommerce Value}}\",\n \"{{lead_score}}\": \"{{Lead Score}}\",\n \"{{google_ads_id}}\": \"{{Google Ads ID}}\",\n \"AW-{{google_ads_id}}\": \"AW-{{Google Ads ID}}\",\n // Add more mappings as needed\n };\n\n let resolvedValue = value;\n\n // First handle ${var.variable} syntax - resolve from YAML variables\n // This handles config variables like ${var.google_ads_id}, ${var.conversion_labels.form_submission}\n resolvedValue = resolvedValue.replace(\n /\\$\\{var\\.([^}]+)\\}/g,\n (match, varPath) => {\n console.log(\n `Attempting to resolve variable: ${match} (path: ${varPath})`\n );\n\n // Handle nested variable references like var.conversion_labels.form_submission\n const pathParts = varPath.split(\".\");\n let currentValue: any = this.getConfigVariables();\n\n console.log(`Starting resolution with:`, currentValue);\n\n for (const part of pathParts) {\n console.log(`Looking for part: ${part} in:`, currentValue);\n if (\n currentValue &&\n typeof currentValue === \"object\" &&\n part in currentValue\n ) {\n currentValue = currentValue[part];\n console.log(`Found value: ${currentValue}`);\n } else {\n // Variable not found, return original match\n console.warn(\n `Variable not found: ${match} (missing part: ${part})`\n );\n return match;\n }\n }\n\n const result = String(currentValue);\n console.log(`Resolved ${match} to: ${result}`);\n return result;\n }\n );\n\n // Then handle {{variable}} GTM variable references\n for (const [oldRef, newRef] of Object.entries(variableMap)) {\n resolvedValue = resolvedValue.replace(\n new RegExp(oldRef.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\"), \"g\"),\n newRef\n );\n }\n\n return resolvedValue;\n }\n\n /**\n * Normalize parameter list structures for GTM API (convert lowercase types to uppercase)\n */\n private normalizeParameterList(list: any[]): any[] {\n return list.map((item: any) => ({\n ...item,\n type: item.type?.toUpperCase() || \"TEMPLATE\",\n ...(item.map && { map: this.normalizeParameterMap(item.map) }),\n ...(item.list && { list: this.normalizeParameterList(item.list) }),\n }));\n }\n\n /**\n * Normalize parameter map structures for GTM API (convert lowercase types to uppercase)\n */\n private normalizeParameterMap(map: any[]): any[] {\n return map.map((item: any) => ({\n ...item,\n type: item.type?.toUpperCase() || \"TEMPLATE\",\n ...(item.map && { map: this.normalizeParameterMap(item.map) }),\n ...(item.list && { list: this.normalizeParameterList(item.list) }),\n }));\n }\n\n /**\n * Process GA4 event tag parameters to ensure they match GTM API expectations\n * For gaawe tags, converts tagId to measurementIdOverride and properly structures eventParameters\n */\n private processGA4EventParameters(parameters: any[]): any[] {\n return parameters.map((param: any) => {\n // For gaawe (GA4 Event) tags, the API expects 'measurementIdOverride'\n // Handle both 'tagId' and 'measurementId' fields from YAML\n if (param.key === \"tagId\" || param.key === \"measurementId\") {\n return {\n ...param,\n key: \"measurementIdOverride\",\n type: \"TEMPLATE\", // GA4 event tags use TEMPLATE type for measurementIdOverride\n };\n }\n\n // Convert eventParameters to eventSettingsTable format for GA4 event tags\n if (param.key === \"eventParameters\" && param.list) {\n const eventSettingsList = param.list.map((item: any) => {\n if (item.type === \"map\" && item.map) {\n const nameField = item.map.find(\n (field: any) => field.key === \"name\"\n );\n const valueField = item.map.find(\n (field: any) => field.key === \"value\"\n );\n\n if (nameField && valueField) {\n // Debug logging to see what we're converting\n console.log(\n `[DEBUG] Converting eventParameters: ${nameField.value} -> ${valueField.value}`\n );\n return {\n type: \"map\",\n map: [\n {\n key: \"parameter\",\n type: \"TEMPLATE\",\n value: nameField.value,\n },\n {\n key: \"parameterValue\",\n type: \"TEMPLATE\",\n value: valueField.value,\n },\n ],\n };\n }\n }\n return item;\n });\n\n return {\n key: \"eventSettingsTable\",\n type: \"LIST\",\n list: eventSettingsList,\n };\n }\n\n return param;\n });\n }\n\n /**\n * Process Google Ads conversion tag parameters to ensure they match GTM API expectations\n * Properly structures enhancedConversionData and ensures correct parameter types\n */\n private processGoogleAdsParameters(parameters: any[]): any[] {\n console.log(\n `[DEBUG] Processing Google Ads parameters:`,\n JSON.stringify(parameters, null, 2)\n );\n\n return parameters.map((param: any) => {\n // Handle enhancedConversionData special structure (similar to GA4 eventParameters)\n if (param.key === \"enhancedConversionData\" && param.list) {\n console.log(\n `[DEBUG] Processing enhancedConversionData with ${param.list.length} items`\n );\n return {\n ...param,\n type: \"LIST\",\n list: this.normalizeParameterList(param.list), // Use the recursive normalizer\n };\n }\n\n // Handle eventParameters for Google Ads tags (similar structure to GA4)\n if (param.key === \"eventParameters\" && param.list) {\n console.log(\n `[DEBUG] Processing Google Ads eventParameters with ${param.list.length} items`\n );\n return {\n ...param,\n type: \"LIST\",\n list: this.normalizeParameterList(param.list), // Use the recursive normalizer\n };\n }\n\n // Ensure boolean parameters have correct type\n if (\n param.key === \"enableEnhancedConversions\" ||\n param.key === \"enableNewCustomerReporting\"\n ) {\n console.log(`[DEBUG] Processing boolean parameter: ${param.key}`);\n return {\n ...param,\n type: \"BOOLEAN\",\n };\n }\n\n return param;\n });\n }\n\n /**\n * Transform tag config from YAML format to GTM API format\n */\n private transformTagConfig(yamlConfig: any): any {\n // Check if already in GTM API format (has parameter array)\n if (yamlConfig.parameter && Array.isArray(yamlConfig.parameter)) {\n // Already transformed, but resolve variable references and normalize types\n // Important: Preserve GTM's expected parameter order (type first, then key)\n const resolvedParameters = yamlConfig.parameter.map((param: any) => ({\n type: param.type?.toUpperCase() || \"TEMPLATE\", // GTM API expects uppercase types\n key: param.key,\n value: this.resolveVariableReferences(param.value),\n // Include other fields if present, recursively processing nested structures\n ...(param.list && { list: this.normalizeParameterList(param.list) }),\n ...(param.map && { map: this.normalizeParameterMap(param.map) }),\n }));\n\n // Special processing for GA4 event tags (googtag or gaawe with eventName)\n let processedParameters = resolvedParameters;\n if (\n (yamlConfig.type === \"googtag\" || yamlConfig.type === \"gaawe\") &&\n resolvedParameters.some((p: any) => p.key === \"eventName\")\n ) {\n processedParameters =\n this.processGA4EventParameters(resolvedParameters);\n }\n\n // Special processing for Google Ads conversion tags (awct with enhancedConversionData)\n if (\n yamlConfig.type === \"awct\" &&\n resolvedParameters.some((p: any) => p.key === \"enhancedConversionData\")\n ) {\n processedParameters =\n this.processGoogleAdsParameters(processedParameters);\n }\n\n const transformed: any = {\n name: yamlConfig.name,\n type: this.mapTagType(yamlConfig.type, yamlConfig), // Pass yamlConfig for auto-correction\n parameter: processedParameters, // GTM API expects 'parameter' (singular)\n };\n\n // Also extract common parameters for client methods (use processed parameters)\n for (const param of processedParameters) {\n if (param.key === \"html\") {\n transformed.html = param.value;\n } else if (param.key === \"tagId\" || param.key === \"measurementId\") {\n // GA4 Configuration uses tagId in YAML but measurementId in API\n transformed.measurementId = param.value;\n } else if (param.key === \"conversionId\") {\n transformed.conversionId = param.value;\n } else if (param.key === \"conversionLabel\") {\n transformed.conversionLabel = param.value;\n } else if (param.key === \"eventName\") {\n // Extract eventName for GA4 event tags\n transformed.eventName = param.value;\n }\n }\n\n // Handle trigger references from various fields\n // CRITICAL FIX: Keep firingTriggerId for proper trigger name resolution\n if (\n yamlConfig.firingTriggerId &&\n Array.isArray(yamlConfig.firingTriggerId)\n ) {\n // These are trigger names that need to be resolved to IDs by the client\n transformed.firingTriggerId = yamlConfig.firingTriggerId;\n } else if (\n yamlConfig.firing_triggers &&\n Array.isArray(yamlConfig.firing_triggers)\n ) {\n transformed.firingTriggerId = yamlConfig.firing_triggers;\n } else if (yamlConfig.triggers && Array.isArray(yamlConfig.triggers)) {\n transformed.firingTriggerId = yamlConfig.triggers;\n }\n\n // Add description if present\n if (yamlConfig.description) {\n transformed.notes = yamlConfig.description;\n }\n\n return transformed;\n }\n\n // Handle YAML format with parameters object\n const transformed: any = {\n name: yamlConfig.name,\n type: this.mapTagType(yamlConfig.type, yamlConfig), // Pass yamlConfig for auto-correction\n };\n\n // Handle tag parameters - special handling for GA4 tags\n if (yamlConfig.parameters) {\n transformed.parameter = [];\n\n // Special handling for GA4 tags\n if (yamlConfig.type === \"gaawc\") {\n // GA4 Configuration Tag\n if (yamlConfig.parameters.measurementId) {\n const resolvedMeasurementId = this.resolveVariableReferences(\n yamlConfig.parameters.measurementId\n );\n transformed.parameter.push({\n type: \"template\",\n key: \"measurementId\",\n value: resolvedMeasurementId,\n });\n transformed.measurementId = resolvedMeasurementId;\n }\n\n if (yamlConfig.parameters.sendPageView !== undefined) {\n transformed.parameter.push({\n type: \"boolean\",\n key: \"sendPageView\",\n value: String(yamlConfig.parameters.sendPageView),\n });\n }\n } else if (yamlConfig.type === \"gaawe\") {\n // GA4 Event Tag\n if (yamlConfig.parameters.measurementId) {\n transformed.parameter.push({\n type: \"template\",\n key: \"measurementIdOverride\",\n value: yamlConfig.parameters.measurementId,\n });\n transformed.measurementId = yamlConfig.parameters.measurementId;\n }\n\n if (yamlConfig.parameters.eventName) {\n transformed.parameter.push({\n type: \"template\",\n key: \"eventName\",\n value: yamlConfig.parameters.eventName,\n });\n transformed.eventName = yamlConfig.parameters.eventName;\n }\n\n if (yamlConfig.parameters.eventParameters) {\n transformed.parameter.push({\n type: \"list\",\n key: \"eventSettingsTable\",\n value: yamlConfig.parameters.eventParameters,\n });\n }\n } else if (yamlConfig.type === \"html\") {\n // HTML tags need special handling\n if (yamlConfig.parameters.html) {\n const resolvedHtml = this.resolveVariableReferences(\n yamlConfig.parameters.html\n );\n transformed.parameter.push({\n type: \"template\",\n key: \"html\",\n value: resolvedHtml,\n });\n transformed.html = resolvedHtml;\n }\n } else {\n // Default parameter handling for other tag types\n for (const [key, value] of Object.entries(yamlConfig.parameters)) {\n const resolvedValue = this.resolveVariableReferences(String(value));\n transformed.parameter.push({\n type: this.getTagParameterType(yamlConfig.type, key, value),\n key,\n value: resolvedValue,\n });\n }\n }\n }\n\n // Handle trigger references (convert trigger names to IDs later)\n // CRITICAL FIX: Use firingTriggerId so the client can resolve names to IDs\n if (\n yamlConfig.firingTriggerId &&\n Array.isArray(yamlConfig.firingTriggerId)\n ) {\n // Use firingTriggerId field if present\n transformed.firingTriggerId = yamlConfig.firingTriggerId;\n } else if (\n yamlConfig.firing_triggers &&\n Array.isArray(yamlConfig.firing_triggers)\n ) {\n // Use firing_triggers field (alternative format)\n transformed.firingTriggerId = yamlConfig.firing_triggers;\n } else if (yamlConfig.triggers && Array.isArray(yamlConfig.triggers)) {\n // Fall back to triggers field for backward compatibility\n transformed.firingTriggerId = yamlConfig.triggers;\n }\n\n // Add description if present\n if (yamlConfig.description) {\n transformed.notes = yamlConfig.description;\n }\n\n return transformed;\n }\n\n /**\n * Detect if a tag configuration represents a GA4 event tag\n * (has eventName or eventParameters)\n */\n private isGA4EventTag(yamlConfig: any): boolean {\n // Check if tag has event-specific parameters\n if (yamlConfig.parameter && Array.isArray(yamlConfig.parameter)) {\n return yamlConfig.parameter.some(\n (p: any) => p.key === \"eventName\" || p.key === \"eventParameters\"\n );\n }\n\n // Check if tag has parameters object with event fields\n if (yamlConfig.parameters) {\n return (\n yamlConfig.parameters.eventName || yamlConfig.parameters.eventParameters\n );\n }\n\n return false;\n }\n\n /**\n * Map tag type codes to full GTM API type names\n * CRITICAL: Auto-corrects googtag to gaawe for GA4 event tags\n */\n private mapTagType(type: string, yamlConfig?: any): string {\n const typeMap: Record<string, string> = {\n googtag: \"googtag\", // Google Tag (basic config only - NOT for events)\n gaawe: \"gaawe\", // GA4 Event Tag (supports eventName, eventParameters)\n gaawc: \"gaawc\", // GA4 Configuration Tag\n ua: \"ua\", // Universal Analytics\n html: \"html\", // Custom HTML\n img: \"img\", // Custom Image\n gclidw: \"gclidw\", // Google Ads Conversion Linker\n awct: \"awct\", // Google Ads Conversion Tracking\n sp: \"sp\", // Salesforce Pardot\n flc: \"flc\", // Floodlight Counter\n fls: \"fls\", // Floodlight Sales\n };\n\n // CRITICAL FIX: Auto-detect and correct GA4 event tags\n if (type === \"googtag\" && yamlConfig && this.isGA4EventTag(yamlConfig)) {\n console.log(\n `[AUTO-CORRECT] Converting tag \"${yamlConfig.name}\" from type \"googtag\" to \"gaawe\" (GA4 Event Tag)`\n );\n return \"gaawe\";\n }\n\n return typeMap[type] || type;\n }\n\n /**\n * Get parameter type for tag parameters\n */\n private getTagParameterType(\n tagType: string,\n key: string,\n value: any\n ): string {\n // Most tag parameters are templates\n if (typeof value === \"boolean\") {\n return \"boolean\";\n } else if (typeof value === \"number\") {\n return \"integer\";\n } else {\n return \"template\";\n }\n }\n\n /**\n * Resolve trigger names or IDs to trigger IDs\n * Handles both trigger names (e.g., \"All Pages\") and IDs (e.g., \"225\")\n */\n private async resolveTriggerNames(\n triggerNamesOrIds: string[]\n ): Promise<string[]> {\n try {\n const triggersResult = await this.clients.gtm.listTriggers();\n if (!triggersResult.success || !triggersResult.data) {\n console.warn(`Warning: Could not list triggers to resolve names`);\n return [];\n }\n\n const triggerIds: string[] = [];\n for (const triggerNameOrId of triggerNamesOrIds) {\n // Check if it's already a numeric ID\n if (/^\\d+$/.test(triggerNameOrId)) {\n // It's an ID - verify it exists\n const triggerExists = triggersResult.data.some(\n (t) => t.triggerId === triggerNameOrId\n );\n if (triggerExists) {\n triggerIds.push(triggerNameOrId);\n } else {\n console.warn(\n `Warning: Trigger ID \"${triggerNameOrId}\" not found in GTM`\n );\n }\n } else {\n // It's a name - resolve to ID\n const trigger = triggersResult.data.find(\n (t) => t.name === triggerNameOrId\n );\n if (trigger && trigger.triggerId) {\n triggerIds.push(trigger.triggerId);\n } else {\n console.warn(\n `Warning: Could not find trigger with name \"${triggerNameOrId}\"`\n );\n }\n }\n }\n\n return triggerIds;\n } catch (error) {\n console.warn(`Warning: Error resolving trigger names:`, error);\n return [];\n }\n }\n\n /**\n * Transform trigger config from YAML format to GTM API format\n */\n private transformTriggerConfig(yamlConfig: any): any {\n const transformed: any = {\n name: yamlConfig.name,\n type: this.mapTriggerType(yamlConfig.type),\n };\n\n // Handle custom event filters - GTM expects specific format for customEvent\n if (yamlConfig.type === \"customEvent\") {\n if (yamlConfig.custom_event_filter || yamlConfig.customEventFilter) {\n const filters =\n yamlConfig.custom_event_filter || yamlConfig.customEventFilter;\n\n // Transform filter to GTM API format\n if (Array.isArray(filters) && filters.length > 0) {\n const filter = filters[0];\n // Extract event name from filter parameters\n let eventName = \"\";\n if (filter.parameter && Array.isArray(filter.parameter)) {\n const eventParam = filter.parameter.find(\n (p: any) => p.key === \"event\" || p.key === \"arg1\"\n );\n if (eventParam) {\n eventName = eventParam.value;\n }\n }\n\n // Build proper custom event filter for GTM API - must be exactly one filter\n transformed.customEventFilter = [\n {\n type: \"equals\",\n parameter: [\n {\n type: \"template\",\n key: \"arg0\",\n value: \"{{_event}}\",\n },\n {\n type: \"template\",\n key: \"arg1\",\n value: eventName,\n },\n ],\n },\n ];\n }\n }\n }\n\n // Handle event name for custom triggers\n if (yamlConfig.eventName) {\n transformed.eventName = yamlConfig.eventName;\n }\n\n // Add description if present\n if (yamlConfig.description) {\n transformed.notes = yamlConfig.description;\n }\n\n return transformed;\n }\n\n /**\n * Map trigger type codes to full GTM API type names\n */\n private mapTriggerType(type: string): string {\n const typeMap: Record<string, string> = {\n pageview: \"pageview\",\n domReady: \"domReady\",\n windowLoaded: \"windowLoaded\",\n customEvent: \"customEvent\",\n click: \"click\",\n linkClick: \"linkClick\",\n formSubmission: \"formSubmission\",\n historyChange: \"historyChange\",\n timer: \"timer\",\n scrollDepth: \"scrollDepth\",\n youtubeVideo: \"youtubeVideo\",\n };\n return typeMap[type] || type;\n }\n\n /**\n * Filter trigger fields for update operations\n * Only include fields that can be updated via the GTM API\n */\n private filterTriggerUpdateFields(triggerConfig: any): any {\n // Include all essential trigger fields for updates\n const filtered: any = {\n name: triggerConfig.name,\n type: triggerConfig.type,\n };\n\n // Include all configuration fields that might be present\n const configFields = [\n \"customEventFilter\",\n \"filter\",\n \"autoEventFilter\",\n \"waitForTags\",\n \"checkValidation\",\n \"waitForTagsTimeout\",\n \"uniqueTriggerId\",\n \"eventName\",\n \"interval\",\n \"intervalSeconds\",\n \"limit\",\n \"maxTimerLengthSeconds\",\n \"parameter\",\n \"notes\",\n ];\n\n for (const field of configFields) {\n if (triggerConfig[field] !== undefined) {\n filtered[field] = triggerConfig[field];\n }\n }\n\n // Always include notes field - essential for proper sync\n filtered.notes = triggerConfig.notes || triggerConfig.description || \"\";\n\n return filtered;\n }\n\n /**\n * Filter variable fields for update operations\n * Only include fields that can be updated via the GTM API\n */\n private filterVariableUpdateFields(variableConfig: any): any {\n // For variables, we need to include the parameter array which contains the actual configuration\n // GTM expects the parameter array format for updates\n const filtered: any = {\n name: variableConfig.name,\n type: variableConfig.type,\n };\n\n // Always include parameter if present (this is the main configuration)\n if (variableConfig.parameter) {\n filtered.parameter = variableConfig.parameter;\n }\n\n // Always include notes field - essential for proper sync\n filtered.notes = variableConfig.notes || variableConfig.description || \"\";\n\n // Include formatValue if present (for certain variable types)\n if (variableConfig.formatValue) {\n filtered.formatValue = variableConfig.formatValue;\n }\n\n return filtered;\n }\n\n /**\n * Filter tag fields for update operations\n * Only include fields that can be updated via the GTM API\n */\n private filterTagUpdateFields(tagConfig: any): any {\n // Include all essential tag fields for updates\n // NOTE: Do NOT include 'type' - GTM doesn't allow changing tag type after creation\n const filtered: any = {\n name: tagConfig.name,\n };\n\n // Include all configuration fields that might be present\n const configFields = [\n \"parameter\",\n \"parameters\",\n \"firingTriggerId\",\n \"blockingTriggerId\",\n \"liveOnly\",\n \"priority\",\n \"scheduleStartMs\",\n \"scheduleEndMs\",\n \"notes\",\n \"tagFiringOption\",\n \"monitoringMetadata\",\n \"monitoringMetadataTagNameKey\",\n ];\n\n for (const field of configFields) {\n if (tagConfig[field] !== undefined) {\n filtered[field] = tagConfig[field];\n }\n }\n\n // Always include notes field - essential for proper sync\n // Check various possible note field names from the config\n const notesValue =\n tagConfig.notes || tagConfig.description || tagConfig.desc || \"\";\n if (notesValue) {\n filtered.notes = notesValue;\n }\n\n // Don't send undefined monitoringMetadata - GTM keeps it as {\"type\":\"map\"}\n if (filtered.monitoringMetadata === undefined) {\n delete filtered.monitoringMetadata;\n }\n\n return filtered;\n }\n\n /**\n * Transform variable config from YAML format to GTM API format using the working GTMApiTransformer\n */\n private transformVariableConfig(yamlConfig: any): any {\n // Check if already in GTM API format (has parameter array)\n if (yamlConfig.parameter && Array.isArray(yamlConfig.parameter)) {\n // Already transformed, keep the full structure for GTM\n const transformed: any = {\n name: yamlConfig.name,\n type: this.mapVariableTypeForGTMApi(yamlConfig.type),\n parameter: yamlConfig.parameter, // Keep the full parameter array\n };\n\n // Add notes if present\n if (yamlConfig.notes) {\n transformed.notes = yamlConfig.notes;\n }\n\n // For AEV variables, ensure parameter format is correct\n if (yamlConfig.type === \"aev\") {\n // Make sure parameter type is uppercase\n transformed.parameter = yamlConfig.parameter.map((p: any) => ({\n ...p,\n type: p.type?.toUpperCase() || \"TEMPLATE\",\n }));\n }\n\n return transformed;\n }\n\n // Handle YAML format with parameters object - convert to GTM parameter array format\n const transformed: any = {\n name: yamlConfig.name,\n type: this.mapVariableTypeForGTMApi(yamlConfig.type),\n };\n\n // Add notes if present\n if (yamlConfig.description) {\n transformed.notes = yamlConfig.description;\n }\n\n // Convert parameters object to parameter array format that GTM expects\n if (yamlConfig.parameters) {\n const paramArray: any[] = [];\n\n // Handle different variable types\n if (yamlConfig.type === \"c\" || yamlConfig.type === \"constant\") {\n // Constant variable\n if (yamlConfig.parameters.value !== undefined) {\n paramArray.push({\n type: \"TEMPLATE\",\n key: \"value\",\n value: yamlConfig.parameters.value,\n });\n }\n } else if (yamlConfig.type === \"v\" || yamlConfig.type === \"dataLayer\") {\n // Data Layer Variable - add required parameters\n if (yamlConfig.parameters.name !== undefined) {\n paramArray.push({\n type: \"TEMPLATE\",\n key: \"name\",\n value: yamlConfig.parameters.name,\n });\n }\n // Always add dataLayerVersion (required)\n paramArray.push({\n type: \"INTEGER\",\n key: \"dataLayerVersion\",\n value: yamlConfig.parameters.dataLayerVersion || \"2\",\n });\n // Always add setDefaultValue (required)\n paramArray.push({\n type: \"BOOLEAN\",\n key: \"setDefaultValue\",\n value:\n yamlConfig.parameters.setDefaultValue !== undefined\n ? String(yamlConfig.parameters.setDefaultValue)\n : \"false\",\n });\n // Optional defaultValue\n if (yamlConfig.parameters.defaultValue !== undefined) {\n paramArray.push({\n type: \"TEMPLATE\",\n key: \"defaultValue\",\n value: yamlConfig.parameters.defaultValue,\n });\n }\n } else if (yamlConfig.type === \"u\" || yamlConfig.type === \"url\") {\n // URL variable\n if (yamlConfig.parameters.component !== undefined) {\n paramArray.push({\n type: \"TEMPLATE\",\n key: \"component\",\n value: yamlConfig.parameters.component,\n });\n }\n } else if (yamlConfig.type === \"aev\" || yamlConfig.type === \"autoEvent\") {\n // Auto Event Variable - this is the key fix for Click URL/ID\n if (yamlConfig.parameters.varType !== undefined) {\n paramArray.push({\n type: \"TEMPLATE\",\n key: \"varType\",\n value: yamlConfig.parameters.varType.toString().toUpperCase(), // Ensure uppercase\n });\n }\n } else if (\n yamlConfig.type === \"jsm\" ||\n yamlConfig.type === \"customJavascript\"\n ) {\n // Custom JavaScript variable\n if (yamlConfig.parameters.javascript !== undefined) {\n paramArray.push({\n type: \"TEMPLATE\",\n key: \"javascript\",\n value: yamlConfig.parameters.javascript,\n });\n }\n }\n\n // Set the parameter array\n if (paramArray.length > 0) {\n transformed.parameter = paramArray;\n }\n }\n\n return transformed;\n }\n\n /**\n * Transform variable config using the proven working GTMApiTransformer (NEW - replaces manual logic)\n */\n private transformVariableConfigWithWorkingTransformer(yamlConfig: any): any {\n // Use the proven working transformer instead of manual parameter building\n return this.gtmTransformer.transformVariable(yamlConfig);\n }\n\n /**\n * Map short variable type codes to full GTM API type names (LEGACY - for display purposes)\n */\n private mapVariableType(type: string): string {\n const typeMap: Record<string, string> = {\n c: \"Constant\",\n constant: \"Constant\",\n v: \"Data Layer Variable\",\n dataLayer: \"Data Layer Variable\",\n u: \"URL\",\n url: \"URL\",\n jsm: \"Custom JavaScript\",\n customJavascript: \"Custom JavaScript\",\n aev: \"Auto-Event Variable\",\n e: \"Environment Name\",\n j: \"JavaScript Variable\",\n k: \"Cookie\",\n r: \"Referrer\",\n gas: \"Google Analytics Settings\",\n };\n return typeMap[type] || type;\n }\n\n /**\n * Map variable type codes to GTM API format (keep short codes, normalize long names to short codes)\n */\n private mapVariableTypeForGTMApi(type: string): string {\n // GTM API expects short codes, not human-readable names\n const typeMap: Record<string, string> = {\n // Short codes remain as-is (these are what GTM API wants)\n c: \"c\",\n v: \"v\",\n u: \"u\",\n jsm: \"jsm\",\n aev: \"aev\",\n e: \"e\",\n j: \"j\",\n k: \"k\",\n r: \"r\",\n gas: \"gas\",\n // Human-readable names get converted to short codes\n Constant: \"c\",\n \"Data Layer Variable\": \"v\",\n URL: \"u\",\n \"Custom JavaScript\": \"jsm\",\n \"Auto-Event Variable\": \"aev\",\n \"Environment Name\": \"e\",\n \"JavaScript Variable\": \"j\",\n Cookie: \"k\",\n Referrer: \"r\",\n \"Google Analytics Settings\": \"gas\",\n // Additional common alternatives\n constant: \"c\",\n dataLayer: \"v\",\n dataLayerVariable: \"v\",\n customJavascript: \"jsm\",\n autoEvent: \"aev\",\n autoEventVariable: \"aev\",\n };\n return typeMap[type] || type;\n }\n\n /**\n * GTM API rate limiter: 0.25 QPS (1 request every 4 seconds)\n * Uses 5 seconds delay to stay well within limits\n */\n private async delay(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\n }\n\n /**\n * Intelligent rate limiter that tracks request timing\n * Ensures we never exceed GTM API limits of 0.25 QPS\n */\n private lastRequestTime: number = 0;\n private async smartDelay(context?: string): Promise<void> {\n const now = Date.now();\n const timeSinceLastRequest = now - this.lastRequestTime;\n const minInterval = 5000; // 5 seconds between requests for GTM API\n\n if (timeSinceLastRequest < minInterval) {\n const delayNeeded = minInterval - timeSinceLastRequest;\n if (context) {\n console.log(\n chalk.dim(\n `⏳ Rate limiting: waiting ${Math.round(\n delayNeeded / 1000\n )}s before ${context}...`\n )\n );\n }\n await this.delay(delayNeeded);\n }\n\n this.lastRequestTime = Date.now();\n }\n\n /**\n * Find tags that are linked to a specific trigger and unlink them\n */\n private async unlinkTagsFromTrigger(\n triggerId: string,\n triggerName: string\n ): Promise<void> {\n try {\n // Get all tags to find which ones use this trigger\n const tagsResult = await this.clients.gtm.listTags();\n if (!tagsResult.success || !tagsResult.data) {\n console.warn(\n chalk.yellow(\n `Could not list tags to check for trigger dependencies: ${tagsResult.error}`\n )\n );\n return;\n }\n\n const linkedTags = tagsResult.data.filter(\n (tag) => tag.firingTriggerId && tag.firingTriggerId.includes(triggerId)\n );\n\n if (linkedTags.length === 0) {\n console.log(chalk.dim(` No tags linked to trigger: ${triggerName}`));\n return;\n }\n\n console.log(\n chalk.yellow(\n ` 🔗 Found ${linkedTags.length} tags linked to trigger \"${triggerName}\"`\n )\n );\n\n for (const tag of linkedTags) {\n if (!tag.tagId || !tag.firingTriggerId) continue;\n\n await this.smartDelay(`unlinking tag ${tag.name}`);\n\n // Remove the trigger ID from the tag's firingTriggerId array\n const updatedTriggerIds = tag.firingTriggerId.filter(\n (id) => id !== triggerId\n );\n\n try {\n const updateResult = await this.clients.gtm.updateTag(tag.tagId, {\n firingTriggerId: updatedTriggerIds,\n });\n\n if (updateResult.success) {\n console.log(\n chalk.blue(\n ` ↳ Unlinked tag: ${tag.name} (${updatedTriggerIds.length} triggers remaining)`\n )\n );\n } else {\n console.warn(\n chalk.yellow(\n ` ⚠️ Failed to unlink tag \"${tag.name}\": ${updateResult.error}`\n )\n );\n }\n } catch (error) {\n console.warn(\n chalk.yellow(\n ` ⚠️ Error unlinking tag \"${tag.name}\": ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n );\n }\n }\n } catch (error) {\n console.warn(\n chalk.yellow(\n `Could not check for tag dependencies: ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n );\n }\n }\n\n /**\n * Check if a resource has dependencies and handle unlinking before deletion\n */\n private async handleDependenciesBeforeDeletion(\n change: any\n ): Promise<boolean> {\n const resourceType = change.type.replace(\"gtm_\", \"\");\n const resourceData = change.change?.before;\n\n if (!resourceData) {\n console.warn(\n chalk.yellow(`No resource data found for deletion: ${change.name}`)\n );\n return false;\n }\n\n // Handle trigger dependencies\n if (resourceType === \"trigger\" && resourceData.triggerId) {\n console.log(\n chalk.cyan(\n ` 🔍 Checking dependencies for trigger: ${\n resourceData.name || change.name\n }`\n )\n );\n await this.unlinkTagsFromTrigger(\n resourceData.triggerId,\n resourceData.name || change.name\n );\n return true;\n }\n\n // Tags and variables typically don't have dependencies that prevent deletion\n return true;\n }\n\n async gtmCreateWorkspace(options: {\n name: string;\n description?: string;\n }): Promise<void> {\n const spinner = ora(\"Creating GTM workspace...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n }\n\n spinner.text = `Creating workspace \"${options.name}\"...`;\n const createResult = await this.clients.gtm.createWorkspace(\n options.name,\n options.description\n );\n\n if (!createResult.success) {\n throw new Error(`Failed to create workspace: ${createResult.error}`);\n }\n\n spinner.succeed(`Workspace \"${options.name}\" created successfully!`);\n console.log(`Workspace ID: ${createResult.data?.workspaceId}`);\n console.log(`Workspace Name: ${createResult.data?.name}`);\n } catch (error) {\n spinner.fail(\"Failed to create workspace\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmTerraformDestroy(_options: {\n config: string;\n yes?: boolean;\n }): Promise<void> {\n console.log(chalk.yellow(\"GTM Destroy functionality coming soon...\"));\n console.log(\n chalk.blue(\"This would remove all GTM resources defined in configuration\")\n );\n }\n\n async gtmTerraformImport(options: {\n type: string;\n name: string;\n id: string;\n }): Promise<void> {\n const spinner = ora(\n `Importing GTM ${options.type} ${options.name}...`\n ).start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n // Select workspace\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(\n `Failed to select workspace: ${workspaceResult.error}`\n );\n }\n }\n\n const stateManager = new StateManager();\n let attributes: any = {};\n\n // Fetch resource details from GTM\n switch (options.type) {\n case \"tag\": {\n const tagResult = await this.clients.gtm.getTag(options.id);\n if (tagResult.success) attributes = tagResult.data;\n break;\n }\n case \"trigger\": {\n const triggerResult = await this.clients.gtm.getTrigger(options.id);\n if (triggerResult.success) attributes = triggerResult.data;\n break;\n }\n case \"variable\": {\n const variableResult = await this.clients.gtm.getVariable(options.id);\n if (variableResult.success) attributes = variableResult.data;\n break;\n }\n default:\n throw new Error(`Unsupported resource type: ${options.type}`);\n }\n\n const result = await stateManager.importResource(\n `gtm_${options.type}`,\n options.name,\n options.id,\n attributes\n );\n\n if (result.success) {\n spinner.succeed(`Imported ${options.type} ${options.name}`);\n } else {\n spinner.fail(\"Import failed\");\n console.error(chalk.red(\"Error:\"), result.error);\n }\n } catch (error) {\n spinner.fail(\"Import failed\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmTerraformShow(options: { format: string }): Promise<void> {\n const spinner = ora(\"Loading GTM state...\").start();\n\n try {\n const stateManager = new StateManager();\n const state = await stateManager.load();\n\n spinner.stop();\n\n if (!state) {\n console.log(chalk.yellow(\"No state file found. Run `gtm init` first.\"));\n return;\n }\n\n if (options.format === \"table\") {\n const tableData = [[\"Type\", \"Name\", \"Address\", \"Provider\"]];\n\n for (const resource of state.resources) {\n tableData.push([\n resource.type,\n resource.name,\n `${resource.type}.${resource.name}`,\n resource.provider,\n ]);\n }\n\n console.log(chalk.bold(\"\\n📋 GTM State Resources\\n\"));\n console.log(table(tableData));\n console.log(chalk.blue(`\\nTotal resources: ${state.resources.length}`));\n } else if (options.format === \"yaml\") {\n const configParser = new ConfigParser();\n const config = configParser.stateToConfig(state);\n console.log(yaml.dump(config));\n } else {\n console.log(JSON.stringify(state, null, 2));\n }\n } catch (error) {\n spinner.fail(\"Failed to load state\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmTerraformValidate(options: { config: string }): Promise<void> {\n const spinner = ora(\"Validating GTM configuration...\").start();\n\n try {\n const configParser = new ConfigParser();\n const config = await configParser.loadConfig(options.config);\n const validationResult = configParser.validateConfig(config);\n\n spinner.stop();\n\n if (validationResult.valid) {\n console.log(chalk.green(\"✅ Configuration is valid\"));\n console.log(\n chalk.blue(\n `Resources: ${Object.keys(config.resources || {}).length} types`\n )\n );\n if (config.resources) {\n for (const [type, resources] of Object.entries(config.resources)) {\n if (Array.isArray(resources)) {\n console.log(\n chalk.blue(` - ${type}: ${resources.length} resources`)\n );\n }\n }\n }\n } else {\n console.log(chalk.red(\"❌ Configuration has errors:\"));\n for (const error of validationResult.errors) {\n console.log(chalk.red(` - ${error}`));\n }\n }\n } catch (error) {\n spinner.fail(\"Validation failed\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmTerraformStateList(options: { type?: string }): Promise<void> {\n try {\n const stateManager = new StateManager();\n const resources = await stateManager.listResources();\n\n const filteredResources = options.type\n ? resources.filter((r) => r.type === options.type)\n : resources;\n\n if (filteredResources.length === 0) {\n console.log(chalk.yellow(\"No resources found in state\"));\n return;\n }\n\n console.log(chalk.bold(\"\\n📋 State Resources\\n\"));\n for (const resource of filteredResources) {\n console.log(`${resource.type}.${resource.name}`);\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmTerraformStateShow(options: { address: string }): Promise<void> {\n try {\n const stateManager = new StateManager();\n const [type, name] = options.address.split(\".\");\n const resource = await stateManager.getResource(type, name);\n\n if (!resource) {\n console.log(\n chalk.yellow(`Resource ${options.address} not found in state`)\n );\n return;\n }\n\n console.log(chalk.bold(`\\n📋 Resource: ${options.address}\\n`));\n console.log(JSON.stringify(resource, null, 2));\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmTerraformStateRemove(options: { address: string }): Promise<void> {\n const spinner = ora(`Removing ${options.address} from state...`).start();\n\n try {\n const stateManager = new StateManager();\n const [type, name] = options.address.split(\".\");\n const result = await stateManager.removeResource(type, name);\n\n if (result.success) {\n spinner.succeed(`Removed ${options.address} from state`);\n } else {\n spinner.fail(\"Remove failed\");\n console.error(chalk.red(\"Error:\"), result.error);\n }\n } catch (error) {\n spinner.fail(\"Remove failed\");\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async removeTriggers(triggerIds: string[]): Promise<void> {\n const spinner = ora(\"Removing unused triggers from GTM...\").start();\n\n try {\n // Force a fresh GTM client\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, debug: true, failFast: true });\n\n // Authenticate\n spinner.text = \"Authenticating with GTM API...\";\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // Select workspace\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n spinner.text = \"Finding triggers to remove...\";\n const triggersResult = await this.clients.gtm.listTriggers();\n if (!triggersResult.success) {\n throw new Error(`Failed to list triggers: ${triggersResult.error}`);\n }\n\n // Find triggers that match the IDs to remove\n const triggersToRemove = triggersResult.data.filter((trigger) => {\n return triggerIds.includes(trigger.triggerId || \"\");\n });\n\n spinner.stop();\n\n if (triggersToRemove.length > 0) {\n console.log(\n chalk.cyan(`\\nFound ${triggersToRemove.length} triggers to remove:`)\n );\n triggersToRemove.forEach((trigger) => {\n console.log(` - ${trigger.name} (ID: ${trigger.triggerId})`);\n });\n\n console.log(chalk.yellow(\"\\n🗑️ Removing triggers...\"));\n\n for (const trigger of triggersToRemove) {\n console.log(chalk.blue(` 🗑️ Removing ${trigger.name}:`));\n\n // Delete the trigger directly via GTM API\n const triggerPath = `accounts/${\n (this.clients.gtm as any).config.accountId\n }/containers/${\n (this.clients.gtm as any).config.containerId\n }/workspaces/${(this.clients.gtm as any).workspaceId}/triggers/${\n trigger.triggerId\n }`;\n\n try {\n await (\n this.clients.gtm as any\n ).tagmanager.accounts.containers.workspaces.triggers.delete({\n path: triggerPath,\n });\n console.log(chalk.green(\" ✅ Removed successfully\"));\n } catch (error) {\n console.log(\n chalk.red(\n ` ❌ Failed to remove: ${\n error instanceof Error ? error.message : String(error)\n }`\n )\n );\n }\n }\n } else {\n console.log(chalk.green(\"\\n✅ No matching triggers found to remove\"));\n }\n\n console.log(\"\");\n console.log(chalk.cyan(\"🎯 Next Steps:\"));\n console.log(\"1. Review the changes in GTM workspace\");\n console.log(\"2. Test the configuration in Preview mode\");\n console.log(\"3. Use GTM UI to publish workspace to production\");\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmCreateTag(options: {\n name: string;\n type: string;\n config?: string;\n }): Promise<void> {\n const spinner = ora(\"Creating GTM tag...\").start();\n\n try {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, debug: true, failFast: true });\n\n spinner.text = \"Authenticating with GTM API...\";\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n spinner.text = \"Creating tag...\";\n const tagConfig = {\n name: options.name,\n type: options.type as any,\n ...(options.config && JSON.parse(options.config)),\n };\n\n const result = await this.clients.gtm.createTag(tagConfig);\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green(`✅ Tag created successfully:`));\n console.log(` - Name: ${result.data?.name}`);\n console.log(` - ID: ${result.data?.tagId}`);\n console.log(` - Type: ${result.data?.type}`);\n } else {\n console.error(chalk.red(`❌ Failed to create tag: ${result.error}`));\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmDeleteTag(tagId: string): Promise<void> {\n const spinner = ora(\"Deleting GTM tag...\").start();\n\n try {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, debug: true, failFast: true });\n\n spinner.text = \"Authenticating with GTM API...\";\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n spinner.text = \"Deleting tag...\";\n const result = await this.clients.gtm.deleteTag(tagId);\n\n spinner.stop();\n\n if (result.success) {\n console.log(\n chalk.green(`✅ Tag deleted successfully: ${result.message}`)\n );\n } else {\n console.error(chalk.red(`❌ Failed to delete tag: ${result.error}`));\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmCreateTrigger(options: {\n name: string;\n type: string;\n config?: string;\n }): Promise<void> {\n const spinner = ora(\"Creating GTM trigger...\").start();\n\n try {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, debug: true, failFast: true });\n\n spinner.text = \"Authenticating with GTM API...\";\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n spinner.text = \"Creating trigger...\";\n const triggerConfig = {\n name: options.name,\n type: options.type as any,\n ...(options.config && JSON.parse(options.config)),\n };\n\n const result = await this.clients.gtm.createTrigger(triggerConfig);\n\n spinner.stop();\n\n if (result.success) {\n console.log(chalk.green(`✅ Trigger created successfully:`));\n console.log(` - Name: ${result.data?.name}`);\n console.log(` - ID: ${result.data?.triggerId}`);\n console.log(` - Type: ${result.data?.type}`);\n } else {\n console.error(\n chalk.red(`❌ Failed to create trigger: ${result.error}`)\n );\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmDeleteTrigger(triggerId: string): Promise<void> {\n const spinner = ora(\"Deleting GTM trigger...\").start();\n\n try {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, debug: true, failFast: true });\n\n spinner.text = \"Authenticating with GTM API...\";\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n spinner.text = \"Selecting workspace...\";\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n spinner.text = \"Deleting trigger...\";\n const result = await this.clients.gtm.deleteTrigger(triggerId);\n\n spinner.stop();\n\n if (result.success) {\n console.log(\n chalk.green(`✅ Trigger deleted successfully: ${result.message}`)\n );\n } else {\n console.error(\n chalk.red(`❌ Failed to delete trigger: ${result.error}`)\n );\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n /**\n * Transform YAML configuration format to GTM API format\n */\n private transformResourceForGTM(\n resourceType: string,\n resourceData: any\n ): any {\n switch (resourceType) {\n case \"variable\":\n return this.transformVariableForGTM(resourceData);\n case \"trigger\":\n return this.transformTriggerForGTM(resourceData);\n case \"tag\":\n return this.transformTagForGTM(resourceData);\n default:\n return resourceData;\n }\n }\n\n private transformVariableForGTM(yamlVariable: any): any {\n const config: any = {\n name: yamlVariable.name,\n type: yamlVariable.type,\n };\n\n // Map YAML types to GTM client expected format\n if (yamlVariable.type === \"c\") {\n // Constant variable\n config.type = \"Constant\";\n if (yamlVariable.parameter) {\n const valueParam = yamlVariable.parameter.find(\n (p: any) => p.key === \"value\"\n );\n if (valueParam) {\n config.value = valueParam.value;\n }\n }\n } else if (yamlVariable.type === \"v\") {\n // Data Layer Variable\n config.type = \"Data Layer Variable\";\n if (yamlVariable.parameter) {\n const nameParam = yamlVariable.parameter.find(\n (p: any) => p.key === \"name\"\n );\n if (nameParam) {\n config.dataLayerVariableName = nameParam.value;\n }\n }\n } else if (yamlVariable.type === \"aev\" || yamlVariable.type === \"u\") {\n // Keep raw for other types and pass parameters directly\n config.parameters = yamlVariable.parameter;\n }\n\n // Add notes if present\n if (yamlVariable.notes) {\n config.notes = yamlVariable.notes;\n }\n\n return config;\n }\n\n private transformTriggerForGTM(yamlTrigger: any): any {\n const config: any = {\n name: yamlTrigger.name,\n type: yamlTrigger.type,\n };\n\n // For custom event triggers, we need to properly format the filter\n if (yamlTrigger.type === \"customEvent\" && yamlTrigger.customEventFilter) {\n // The filter is already in array format from YAML, just pass it through\n config.customEventFilter = yamlTrigger.customEventFilter;\n // Also extract the event name for the simplified config\n if (yamlTrigger.customEventFilter[0]?.parameter) {\n const eventParam = yamlTrigger.customEventFilter[0].parameter.find(\n (p: any) => p.key === \"arg1\"\n );\n if (eventParam) {\n config.eventName = eventParam.value;\n }\n }\n }\n\n if (yamlTrigger.notes) {\n config.notes = yamlTrigger.notes;\n }\n\n return config;\n }\n\n private transformTagForGTM(yamlTag: any): any {\n const config: any = {\n name: yamlTag.name,\n type: yamlTag.type,\n };\n\n // For tags, pass parameters directly\n if (yamlTag.parameter) {\n config.parameters = yamlTag.parameter;\n\n // Extract specific values for known tag types\n if (yamlTag.type === \"awct\") {\n // Google Ads Conversion\n const conversionId = yamlTag.parameter.find(\n (p: any) => p.key === \"conversionId\"\n );\n const conversionLabel = yamlTag.parameter.find(\n (p: any) => p.key === \"conversionLabel\"\n );\n if (conversionId) config.conversionId = conversionId.value;\n if (conversionLabel) config.conversionLabel = conversionLabel.value;\n } else if (yamlTag.type === \"gaawc\") {\n // GA4 Configuration\n const measurementId = yamlTag.parameter.find(\n (p: any) => p.key === \"tagId\"\n );\n if (measurementId) config.measurementId = measurementId.value;\n }\n }\n\n if (yamlTag.firingTriggerId) {\n config.triggerIds = yamlTag.firingTriggerId;\n }\n\n if (yamlTag.notes) {\n config.notes = yamlTag.notes;\n }\n\n return config;\n }\n\n // Version Management Methods\n async gtmListVersions(options: { limit?: string }): Promise<void> {\n const spinner = ora(\"Fetching GTM versions...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n const versionsResult = await this.clients.gtm.listVersions();\n if (!versionsResult.success) {\n throw new Error(`Failed to fetch versions: ${versionsResult.error}`);\n }\n\n spinner.stop();\n\n const limit = options.limit ? parseInt(options.limit) : 10;\n const versions = versionsResult.data.slice(0, limit);\n\n console.log(\n chalk.bold(\n `\\n📋 GTM Published Versions (${versions.length}/${versionsResult.data.length})\\n`\n )\n );\n\n const tableData = [[\"Version ID\", \"Name\", \"Created\", \"Description\"]];\n versions.forEach((version: any) => {\n tableData.push([\n version.containerVersionId || \"N/A\",\n version.name || \"Unnamed\",\n version.dateCreated\n ? new Date(version.dateCreated).toLocaleDateString()\n : \"N/A\",\n (version.description || \"\").substring(0, 50) +\n (version.description?.length > 50 ? \"...\" : \"\"),\n ]);\n });\n\n console.log(table(tableData));\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmGetVersion(options: { version: string }): Promise<void> {\n const spinner = ora(`Fetching GTM version ${options.version}...`).start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n const versionResult = await this.clients.gtm.getVersion(options.version);\n if (!versionResult.success) {\n throw new Error(`Failed to fetch version: ${versionResult.error}`);\n }\n\n spinner.stop();\n\n const version = versionResult.data;\n console.log(chalk.bold(`\\n📋 GTM Version ${options.version} Details\\n`));\n\n console.log(chalk.cyan(\"Basic Info:\"));\n console.log(` Name: ${version.name || \"Unnamed\"}`);\n console.log(` Description: ${version.description || \"No description\"}`);\n console.log(\n ` Created: ${\n version.dateCreated\n ? new Date(version.dateCreated).toLocaleDateString()\n : \"Unknown\"\n }`\n );\n console.log(` Version ID: ${version.containerVersionId}`);\n\n console.log(chalk.cyan(\"\\nResources:\"));\n console.log(` Tags: ${version.tag?.length || 0}`);\n console.log(` Triggers: ${version.trigger?.length || 0}`);\n console.log(` Variables: ${version.variable?.length || 0}`);\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmGetLiveVersion(): Promise<void> {\n const spinner = ora(\"Fetching live GTM version...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n const liveVersionResult = await this.clients.gtm.getLiveVersion();\n if (!liveVersionResult.success) {\n throw new Error(\n `Failed to fetch live version: ${liveVersionResult.error}`\n );\n }\n\n spinner.stop();\n\n const version = liveVersionResult.data;\n console.log(chalk.bold(`\\n📋 Currently Published Live Version\\n`));\n\n console.log(chalk.cyan(\"Version Info:\"));\n console.log(` Version ID: ${version.containerVersionId}`);\n console.log(` Name: ${version.name || \"Unnamed\"}`);\n console.log(\n ` Published: ${\n version.dateCreated\n ? new Date(version.dateCreated).toLocaleDateString()\n : \"Unknown\"\n }`\n );\n\n console.log(chalk.cyan(\"\\nLive Configuration:\"));\n console.log(` Tags: ${version.tag?.length || 0}`);\n console.log(` Triggers: ${version.trigger?.length || 0}`);\n console.log(` Variables: ${version.variable?.length || 0}`);\n\n // Show detailed tag list\n if (version.tag && version.tag.length > 0) {\n console.log(chalk.cyan(\"\\n🏷️ TAGS:\"));\n version.tag.forEach((tag, i) => {\n console.log(\n `${(i + 1).toString().padStart(2)}. ${tag.name} (${tag.type})`\n );\n });\n }\n\n // Show detailed trigger list\n if (version.trigger && version.trigger.length > 0) {\n console.log(chalk.cyan(\"\\n⚡ TRIGGERS:\"));\n version.trigger.forEach((trigger, i) => {\n console.log(\n `${(i + 1).toString().padStart(2)}. ${trigger.name} (${\n trigger.type\n })`\n );\n });\n }\n\n // Show detailed variable list\n if (version.variable && version.variable.length > 0) {\n console.log(chalk.cyan(\"\\n📝 VARIABLES:\"));\n version.variable.forEach((variable, i) => {\n console.log(\n `${(i + 1).toString().padStart(2)}. ${variable.name} (${\n variable.type\n })`\n );\n });\n }\n\n // Save to file for reference\n const fs = await import(\"fs/promises\");\n await fs.writeFile(\n \"gtm-version-35-detailed.json\",\n JSON.stringify(version, null, 2)\n );\n console.log(\n chalk.cyan(\"\\n💾 Full details saved to gtm-version-35-detailed.json\")\n );\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmCompareVersions(options: {\n version1: string;\n version2?: string;\n output?: string;\n }): Promise<void> {\n const spinner = ora(\"Comparing versions...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // If no workspace selected but comparing with workspace, select default\n if (!options.version2) {\n await this.clients.gtm.selectWorkspace();\n }\n\n const comparisonResult = await this.clients.gtm.compareVersions(\n options.version1,\n options.version2\n );\n if (!comparisonResult.success) {\n throw new Error(\n `Failed to compare versions: ${comparisonResult.error}`\n );\n }\n\n spinner.stop();\n\n const { version1, version2, workspace, comparison } =\n comparisonResult.data;\n\n console.log(chalk.bold(`\\n🔄 Version Comparison\\n`));\n\n if (version2) {\n console.log(\n chalk.cyan(\n `Comparing Version ${options.version1} vs Version ${options.version2}`\n )\n );\n } else {\n console.log(\n chalk.cyan(\n `Comparing Version ${options.version1} vs Current Workspace`\n )\n );\n }\n\n console.log(chalk.yellow(\"\\n📊 Summary of Changes:\"));\n console.log(\n ` Tags: ${chalk.green(\n `+${comparison.tags.added.length}`\n )} ${chalk.yellow(`~${comparison.tags.modified.length}`)} ${chalk.red(\n `-${comparison.tags.removed.length}`\n )}`\n );\n console.log(\n ` Triggers: ${chalk.green(\n `+${comparison.triggers.added.length}`\n )} ${chalk.yellow(\n `~${comparison.triggers.modified.length}`\n )} ${chalk.red(`-${comparison.triggers.removed.length}`)}`\n );\n console.log(\n ` Variables: ${chalk.green(\n `+${comparison.variables.added.length}`\n )} ${chalk.yellow(\n `~${comparison.variables.modified.length}`\n )} ${chalk.red(`-${comparison.variables.removed.length}`)}`\n );\n\n if (comparison.tags.added.length > 0) {\n console.log(chalk.green(\"\\n➕ Added Tags:\"));\n comparison.tags.added.forEach((tag: string) =>\n console.log(` - ${tag}`)\n );\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmCreateVersion(options: {\n name: string;\n description?: string;\n }): Promise<void> {\n const spinner = ora(\"Creating GTM version from workspace...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(`Failed to select workspace: ${workspaceResult.error}`);\n }\n\n const versionResult = await this.clients.gtm.createVersionFromWorkspace(\n options.name,\n options.description\n );\n if (!versionResult.success) {\n throw new Error(`Failed to create version: ${versionResult.error}`);\n }\n\n spinner.stop();\n\n const version = versionResult.data;\n console.log(chalk.bold(`\\n✅ GTM Version Created Successfully\\n`));\n\n console.log(chalk.cyan(\"Version Details:\"));\n console.log(` Version ID: ${version.containerVersionId}`);\n console.log(` Name: ${version.name}`);\n console.log(` Description: ${version.description || \"No description\"}`);\n console.log(` Created: ${new Date().toLocaleDateString()}`);\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n // =============================================================================\n // WORKSPACE STATE MANAGEMENT\n // =============================================================================\n\n async gtmGetWorkspaceState(options: {\n workspace?: string;\n output?: string;\n }): Promise<void> {\n const spinner = ora(\"Fetching workspace state...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // Select workspace if not specified\n if (!options.workspace && !this.clients.gtm.workspaceId) {\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(\n `Failed to select workspace: ${workspaceResult.error}`\n );\n }\n }\n\n const stateResult = await this.clients.gtm.getWorkspaceState(\n options.workspace\n );\n if (!stateResult.success) {\n throw new Error(`Failed to get workspace state: ${stateResult.error}`);\n }\n\n spinner.stop();\n\n const state = stateResult.data!;\n console.log(chalk.bold(`\\n📋 Workspace State: ${state.workspaceName}\\n`));\n\n console.log(chalk.cyan(\"Workspace Info:\"));\n console.log(` Workspace ID: ${state.workspaceId}`);\n console.log(` Name: ${state.workspaceName}`);\n console.log(\n ` Snapshot Time: ${new Date(state.timestamp).toLocaleString()}`\n );\n\n console.log(chalk.cyan(\"\\nConfiguration:\"));\n console.log(` Tags: ${state.tags.length}`);\n console.log(` Triggers: ${state.triggers.length}`);\n console.log(` Variables: ${state.variables.length}`);\n\n // Show detailed lists\n if (state.tags.length > 0) {\n console.log(chalk.cyan(\"\\n🏷️ TAGS:\"));\n state.tags.forEach((tag, i) => {\n console.log(\n `${(i + 1).toString().padStart(2)}. ${tag.name} (${tag.type})`\n );\n });\n }\n\n if (state.triggers.length > 0) {\n console.log(chalk.cyan(\"\\n⚡ TRIGGERS:\"));\n state.triggers.forEach((trigger, i) => {\n console.log(\n `${(i + 1).toString().padStart(2)}. ${trigger.name} (${\n trigger.type\n })`\n );\n });\n }\n\n if (state.variables.length > 0) {\n console.log(chalk.cyan(\"\\n📝 VARIABLES:\"));\n state.variables.forEach((variable, i) => {\n console.log(\n `${(i + 1).toString().padStart(2)}. ${variable.name} (${\n variable.type\n })`\n );\n });\n }\n\n // Save to file if output specified\n if (options.output) {\n const fs = await import(\"fs/promises\");\n await fs.writeFile(options.output, JSON.stringify(state, null, 2));\n console.log(\n chalk.cyan(`\\n💾 Workspace state saved to ${options.output}`)\n );\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmSaveWorkspaceSnapshot(options: {\n file: string;\n workspace?: string;\n }): Promise<void> {\n const spinner = ora(\"Saving workspace snapshot...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // Select workspace if not specified\n if (!options.workspace && !this.clients.gtm.workspaceId) {\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(\n `Failed to select workspace: ${workspaceResult.error}`\n );\n }\n }\n\n const snapshotResult = await this.clients.gtm.saveWorkspaceSnapshot(\n options.file,\n options.workspace\n );\n if (!snapshotResult.success) {\n throw new Error(\n `Failed to save workspace snapshot: ${snapshotResult.error}`\n );\n }\n\n spinner.stop();\n\n const result = snapshotResult.data!;\n console.log(chalk.bold(`\\n✅ Workspace Snapshot Saved\\n`));\n console.log(`File: ${result.filename}`);\n console.log(\n `Workspace: ${result.state.workspaceName} (${result.state.workspaceId})`\n );\n console.log(`Tags: ${result.state.tags.length}`);\n console.log(`Triggers: ${result.state.triggers.length}`);\n console.log(`Variables: ${result.state.variables.length}`);\n console.log(\n `Timestamp: ${new Date(result.state.timestamp).toLocaleString()}`\n );\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gtmCompareWorkspace(options: {\n file?: string;\n withLive?: boolean;\n workspace?: string;\n output?: string;\n }): Promise<void> {\n const spinner = ora(\"Comparing workspace...\").start();\n\n try {\n if (!this.clients.gtm) {\n const config = loadGTMConfig();\n this.clients.gtm = new GTMClient({ config, failFast: true });\n }\n\n const authResult = await this.clients.gtm.authenticate();\n if (!authResult.success) {\n throw new Error(`Authentication failed: ${authResult.error}`);\n }\n\n // Select workspace if not specified\n if (!options.workspace && !this.clients.gtm.workspaceId) {\n const workspaceResult = await this.clients.gtm.selectWorkspace();\n if (!workspaceResult.success) {\n throw new Error(\n `Failed to select workspace: ${workspaceResult.error}`\n );\n }\n }\n\n let compareResult;\n if (options.withLive) {\n compareResult = await this.clients.gtm.compareWorkspaceWithLive(\n options.workspace\n );\n if (!compareResult.success) {\n throw new Error(\n `Failed to compare with live version: ${compareResult.error}`\n );\n }\n } else if (options.file) {\n compareResult = await this.clients.gtm.compareWorkspaceWithSnapshot(\n options.file,\n options.workspace\n );\n if (!compareResult.success) {\n throw new Error(\n `Failed to compare with snapshot: ${compareResult.error}`\n );\n }\n } else {\n throw new Error(\"Must specify either --file <path> or --with-live\");\n }\n\n spinner.stop();\n\n const comparison = compareResult.data!;\n console.log(chalk.bold(`\\n📊 Workspace Comparison\\n`));\n\n if (options.withLive) {\n console.log(chalk.cyan(\"Current Workspace:\"));\n console.log(` Name: ${comparison.workspaceState.workspaceName}`);\n console.log(` ID: ${comparison.workspaceState.workspaceId}`);\n console.log(\n ` Snapshot: ${new Date(\n comparison.workspaceState.timestamp\n ).toLocaleString()}`\n );\n\n console.log(chalk.cyan(\"\\nLive Published Version:\"));\n console.log(\n ` Version ID: ${comparison.liveVersion.containerVersionId}`\n );\n console.log(` Name: ${comparison.liveVersion.name || \"Unnamed\"}`);\n } else {\n console.log(chalk.cyan(\"Current Workspace:\"));\n console.log(` Name: ${comparison.currentState.workspaceName}`);\n console.log(` ID: ${comparison.currentState.workspaceId}`);\n\n console.log(chalk.cyan(\"\\nSnapshot:\"));\n console.log(` Name: ${comparison.snapshotState.workspaceName}`);\n console.log(\n ` Timestamp: ${new Date(\n comparison.snapshotState.timestamp\n ).toLocaleString()}`\n );\n }\n\n const diffs = comparison.differences;\n\n console.log(chalk.bold(\"\\n📈 Changes Summary:\"));\n console.log(\n `Tags: +${diffs.tags.added.length} / -${diffs.tags.removed.length} / ~${diffs.tags.modified.length}`\n );\n console.log(\n `Triggers: +${diffs.triggers.added.length} / -${diffs.triggers.removed.length} / ~${diffs.triggers.modified.length}`\n );\n console.log(\n `Variables: +${diffs.variables.added.length} / -${diffs.variables.removed.length} / ~${diffs.variables.modified.length}`\n );\n\n // Show detailed differences\n if (diffs.tags.added.length > 0) {\n console.log(chalk.green(\"\\n➕ TAGS ADDED:\"));\n diffs.tags.added.forEach((tag, i) => {\n console.log(` ${i + 1}. ${tag.name} (${tag.type})`);\n });\n }\n\n if (diffs.tags.removed.length > 0) {\n console.log(chalk.red(\"\\n➖ TAGS REMOVED:\"));\n diffs.tags.removed.forEach((tag, i) => {\n console.log(` ${i + 1}. ${tag.name} (${tag.type})`);\n });\n }\n\n if (diffs.tags.modified.length > 0) {\n console.log(chalk.yellow(\"\\n🔄 TAGS MODIFIED:\"));\n diffs.tags.modified.forEach((tag, i) => {\n console.log(` ${i + 1}. ${tag.name} (${tag.type})`);\n });\n }\n\n if (diffs.triggers.added.length > 0) {\n console.log(chalk.green(\"\\n➕ TRIGGERS ADDED:\"));\n diffs.triggers.added.forEach((trigger, i) => {\n console.log(` ${i + 1}. ${trigger.name} (${trigger.type})`);\n });\n }\n\n if (diffs.triggers.removed.length > 0) {\n console.log(chalk.red(\"\\n➖ TRIGGERS REMOVED:\"));\n diffs.triggers.removed.forEach((trigger, i) => {\n console.log(` ${i + 1}. ${trigger.name} (${trigger.type})`);\n });\n }\n\n if (diffs.variables.added.length > 0) {\n console.log(chalk.green(\"\\n➕ VARIABLES ADDED:\"));\n diffs.variables.added.forEach((variable, i) => {\n console.log(` ${i + 1}. ${variable.name} (${variable.type})`);\n });\n }\n\n if (diffs.variables.removed.length > 0) {\n console.log(chalk.red(\"\\n➖ VARIABLES REMOVED:\"));\n diffs.variables.removed.forEach((variable, i) => {\n console.log(` ${i + 1}. ${variable.name} (${variable.type})`);\n });\n }\n\n // Save comparison to file if output specified\n if (options.output) {\n const fs = await import(\"fs/promises\");\n await fs.writeFile(options.output, JSON.stringify(comparison, null, 2));\n console.log(chalk.cyan(`\\n💾 Comparison saved to ${options.output}`));\n }\n } catch (error) {\n spinner.stop();\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n // Missing GSC methods\n async gscTopKeywords(options: {\n start: string;\n end: string;\n limit?: string;\n }): Promise<void> {\n try {\n if (!this.clients.gsc) {\n const config = loadGSCConfig();\n this.clients.gsc = new GSCClient({ config });\n }\n\n const limit = parseInt(options.limit || \"50\");\n const result = await this.clients.gsc.getTopKeywords(\n options.start,\n options.end,\n limit\n );\n\n if (result.success) {\n console.log(chalk.green(\"\\n📊 Top Keywords from GSC:\"));\n console.log(\n table([\n [\"Keyword\", \"Clicks\", \"Impressions\", \"CTR (%)\", \"Position\"],\n ...result.data\n .slice(0, limit)\n .map((k) => [\n k.keyword,\n k.clicks.toString(),\n k.impressions.toString(),\n (k.ctr * 100).toFixed(2),\n k.position.toFixed(1),\n ]),\n ])\n );\n } else {\n console.error(chalk.red(\"GSC Error:\"), result.error);\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gscTopPages(options: {\n start: string;\n end: string;\n limit?: string;\n }): Promise<void> {\n try {\n if (!this.clients.gsc) {\n const config = loadGSCConfig();\n this.clients.gsc = new GSCClient({ config });\n }\n\n const result = await this.clients.gsc.getTopPages(\n options.start,\n options.end\n );\n\n if (result.success) {\n const limit = parseInt(options.limit || \"20\");\n console.log(chalk.green(\"\\n📊 Top Pages from GSC:\"));\n console.log(\n table([\n [\"Page\", \"Clicks\", \"Impressions\", \"CTR (%)\", \"Position\"],\n ...result.data\n .slice(0, limit)\n .map((p) => [\n p.page.length > 50 ? p.page.substring(0, 50) + \"...\" : p.page,\n p.clicks.toString(),\n p.impressions.toString(),\n (p.ctr * 100).toFixed(2),\n p.position.toFixed(1),\n ]),\n ])\n );\n } else {\n console.error(chalk.red(\"GSC Error:\"), result.error);\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gscComprehensiveReport(options: {\n start: string;\n end: string;\n output?: string;\n }): Promise<void> {\n try {\n if (!this.clients.gsc) {\n const config = loadGSCConfig();\n this.clients.gsc = new GSCClient({ config });\n }\n\n const authResult = await this.clients.gsc.authenticate();\n if (!authResult.success) {\n throw new Error(`GSC authentication failed: ${authResult.error}`);\n }\n\n const spinner = ora(\"Generating comprehensive GSC report...\").start();\n const result = await this.clients.gsc.getComprehensiveSEOReport(\n options.start,\n options.end\n );\n\n if (result.success && result.data) {\n spinner.succeed(\"GSC comprehensive report generated\");\n console.log(chalk.green(\"\\n📊 GSC Comprehensive Report:\"));\n console.log(chalk.blue(`Period: ${options.start} to ${options.end}`));\n\n if (result.data.summary) {\n console.log(\n chalk.blue(`Total Clicks: ${result.data.summary.totalClicks || 0}`)\n );\n console.log(\n chalk.blue(\n `Total Impressions: ${result.data.summary.totalImpressions || 0}`\n )\n );\n console.log(\n chalk.blue(\n `Average CTR: ${(\n (result.data.summary.averageCTR || 0) * 100\n ).toFixed(2)}%`\n )\n );\n console.log(\n chalk.blue(\n `Average Position: ${(\n result.data.summary.averagePosition || 0\n ).toFixed(1)}`\n )\n );\n }\n\n console.log(\n chalk.yellow(\n `\\n📈 Top Keywords: ${result.data.topKeywords?.length || 0}`\n )\n );\n console.log(\n chalk.yellow(`📄 Top Pages: ${result.data.topPages?.length || 0}`)\n );\n console.log(\n chalk.yellow(\n `🌍 Countries: ${result.data.countryPerformance?.length || 0}`\n )\n );\n console.log(\n chalk.yellow(\n `📱 Devices: ${result.data.devicePerformance?.length || 0}`\n )\n );\n console.log(\n chalk.yellow(`🗺️ Sitemaps: ${result.data.sitemaps?.length || 0}`)\n );\n console.log(\n chalk.yellow(`💬 Messages: ${result.data.messages?.length || 0}`)\n );\n\n if (options.output) {\n await fs.writeFile(\n options.output,\n JSON.stringify(result.data, null, 2)\n );\n console.log(chalk.cyan(`Report saved to ${options.output}`));\n }\n } else {\n spinner.fail(\"GSC report generation failed\");\n console.error(chalk.red(\"GSC Error:\"), result.error);\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async gscEnhancedReport(options: {\n start: string;\n end: string;\n output?: string;\n includeSchema?: boolean;\n includeInspections?: boolean;\n maxKeywords?: string;\n maxPages?: string;\n maxInspections?: string;\n }): Promise<void> {\n try {\n if (!this.clients.gsc) {\n const config = loadGSCConfig();\n this.clients.gsc = new GSCClient({ config });\n }\n\n const authResult = await this.clients.gsc.authenticate();\n if (!authResult.success) {\n throw new Error(`GSC authentication failed: ${authResult.error}`);\n }\n\n const spinner = ora(\n \"Generating enhanced GSC report with schema analysis...\"\n ).start();\n\n // Prepare options for the new comprehensive report\n const reportOptions = {\n startDate: options.start,\n endDate: options.end,\n includeSchemaAnalysis: options.includeSchema !== false, // Default true\n includeUrlInspections: options.includeInspections !== false, // Default true\n maxKeywords: parseInt(options.maxKeywords || \"100\"),\n maxPages: parseInt(options.maxPages || \"50\"),\n maxUrlInspections: parseInt(options.maxInspections || \"10\"),\n };\n\n const result = await this.clients.gsc.generateComprehensiveReport(\n reportOptions\n );\n\n if (result.success && result.data) {\n spinner.succeed(\"Enhanced GSC report generated\");\n\n const report = result.data;\n\n console.log(\n chalk.green(\"\\n📊 Enhanced GSC Report with Schema Analysis\")\n );\n console.log(chalk.blue(`Site: ${report.siteUrl}`));\n console.log(\n chalk.blue(\n `Period: ${report.period.startDate} to ${report.period.endDate}`\n )\n );\n console.log(\n chalk.blue(\n `Generated: ${new Date(report.reportDate).toLocaleString()}`\n )\n );\n\n // Summary Section\n console.log(chalk.yellow(\"\\n📈 PERFORMANCE SUMMARY\"));\n console.log(` Total Clicks: ${report.summary.totalClicks}`);\n console.log(` Total Impressions: ${report.summary.totalImpressions}`);\n console.log(\n ` Average CTR: ${(report.summary.averageCTR * 100).toFixed(2)}%`\n );\n console.log(\n ` Average Position: ${report.summary.averagePosition.toFixed(1)}`\n );\n\n // Change from previous period\n if (report.summary.changeFromPrevious) {\n const change = report.summary.changeFromPrevious;\n console.log(\"\\n 📊 Changes from Previous Period:\");\n console.log(\n ` Clicks: ${change.clicks >= 0 ? \"+\" : \"\"}${change.clicks}`\n );\n console.log(\n ` Impressions: ${change.impressions >= 0 ? \"+\" : \"\"}${\n change.impressions\n }`\n );\n console.log(\n ` CTR: ${change.ctr >= 0 ? \"+\" : \"\"}${(change.ctr * 100).toFixed(\n 2\n )}%`\n );\n console.log(\n ` Position: ${\n change.position >= 0 ? \"+\" : \"\"\n }${change.position.toFixed(1)}`\n );\n }\n\n // Schema Analysis Section\n console.log(chalk.yellow(\"\\n🔍 SCHEMA ANALYSIS\"));\n console.log(` Schema Messages: ${report.schemaMessages.length}`);\n console.log(` URL Inspections: ${report.urlInspections.length}`);\n console.log(` Schema Issues: ${report.analysis.schemaIssuesCount}`);\n console.log(` Error Messages: ${report.analysis.errorMessagesCount}`);\n console.log(\n ` Warning Messages: ${report.analysis.warningMessagesCount}`\n );\n\n // Critical Issues\n if (report.analysis.criticalIssues.length > 0) {\n console.log(chalk.red(\"\\n🚨 CRITICAL ISSUES\"));\n report.analysis.criticalIssues.forEach((issue, index) => {\n console.log(` ${index + 1}. ${issue}`);\n });\n }\n\n // Schema Messages Detail\n if (report.schemaMessages.length > 0) {\n console.log(chalk.yellow(\"\\n📝 SCHEMA-RELATED MESSAGES\"));\n report.schemaMessages.slice(0, 5).forEach((msg, index) => {\n const severityColor =\n msg.severity === \"ERROR\"\n ? \"red\"\n : msg.severity === \"WARNING\"\n ? \"yellow\"\n : \"blue\";\n console.log(\n ` ${index + 1}. [${chalk[severityColor](msg.severity)}] ${\n msg.subject\n }`\n );\n console.log(` Keywords: ${msg.matchedKeywords.join(\", \")}`);\n if (msg.extractedUrls.length > 0) {\n console.log(` URLs: ${msg.extractedUrls.length} found`);\n }\n });\n\n if (report.schemaMessages.length > 5) {\n console.log(\n ` ... and ${report.schemaMessages.length - 5} more messages`\n );\n }\n }\n\n // URL Inspections Detail\n if (report.urlInspections.length > 0) {\n console.log(chalk.yellow(\"\\n🔍 URL INSPECTION RESULTS\"));\n report.urlInspections.slice(0, 5).forEach((inspection, index) => {\n console.log(` ${index + 1}. ${inspection.url}`);\n console.log(` Rich Results: ${inspection.richResultsVerdict}`);\n console.log(\n ` Mobile Usability: ${inspection.mobileUsabilityVerdict}`\n );\n console.log(` Indexing State: ${inspection.indexingState}`);\n console.log(\n ` Schema Issues: ${inspection.schemaIssues.length}`\n );\n\n if (inspection.schemaIssues.length > 0) {\n inspection.schemaIssues.slice(0, 3).forEach((issue) => {\n const severityColor =\n issue.severity === \"ERROR\" ? \"red\" : \"yellow\";\n console.log(\n ` [${chalk[severityColor](issue.severity)}] ${\n issue.message\n }`\n );\n });\n }\n });\n\n if (report.urlInspections.length > 5) {\n console.log(\n ` ... and ${\n report.urlInspections.length - 5\n } more inspections`\n );\n }\n }\n\n // Top Performance Data Summary\n console.log(chalk.yellow(\"\\n📊 TOP PERFORMANCE DATA\"));\n console.log(` Keywords: ${report.topKeywords.length}`);\n console.log(` Pages: ${report.topPages.length}`);\n console.log(` Countries: ${report.countryPerformance.length}`);\n console.log(` Devices: ${report.devicePerformance.length}`);\n console.log(` Sitemaps: ${report.sitemaps.length}`);\n console.log(` Total Messages: ${report.messages.length}`);\n\n // Recommendations\n if (report.analysis.recommendations.length > 0) {\n console.log(chalk.green(\"\\n💡 RECOMMENDATIONS\"));\n report.analysis.recommendations.forEach((rec, index) => {\n console.log(` ${index + 1}. ${rec}`);\n });\n }\n\n // Save to file if requested\n if (options.output) {\n const fs = await import(\"fs/promises\");\n await fs.writeFile(options.output, JSON.stringify(report, null, 2));\n console.log(\n chalk.cyan(`\\n💾 Enhanced report saved to ${options.output}`)\n );\n }\n\n console.log(\n chalk.green(\"\\n✅ Enhanced GSC report generation complete!\")\n );\n } else {\n spinner.fail(\"Enhanced GSC report generation failed\");\n console.error(chalk.red(\"GSC Error:\"), result.error);\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n // Missing Google Ads methods\n async googleAdsKeywords(options: {\n start: string;\n end: string;\n customerId?: string;\n }): Promise<void> {\n try {\n const config = loadGoogleAdsConfig();\n if (!this.clients.googleAds) {\n this.clients.googleAds = new GoogleAdsClient(config);\n }\n\n const result = await this.clients.googleAds.getKeywordPerformanceReport({\n startDate: options.start,\n endDate: options.end,\n customerId: options.customerId,\n });\n\n if (result.success) {\n console.log(chalk.green(\"\\n📊 Google Ads Keywords:\"));\n console.log(\n table([\n [\"Keyword\", \"Impressions\", \"Clicks\", \"CTR (%)\", \"CPC (CHF)\"],\n ...result.data\n .slice(0, 20)\n .map((k: any) => [\n k.keyword || \"N/A\",\n k.impressions?.toString() || \"0\",\n k.clicks?.toString() || \"0\",\n k.ctr ? (k.ctr * 100).toFixed(2) : \"0.00\",\n k.averageCpc ? (k.averageCpc / 1000000).toFixed(2) : \"0.00\",\n ]),\n ])\n );\n } else {\n console.error(chalk.red(\"Google Ads Error:\"), result.error);\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async googleAdsSearchTerms(options: {\n start: string;\n end: string;\n customerId?: string;\n }): Promise<void> {\n try {\n const config = loadGoogleAdsConfig();\n if (!this.clients.googleAds) {\n this.clients.googleAds = new GoogleAdsClient(config);\n }\n\n const result = await this.clients.googleAds.getSearchTermsReport({\n startDate: options.start,\n endDate: options.end,\n customerId: options.customerId,\n });\n\n if (result.success) {\n console.log(chalk.green(\"\\n📊 Google Ads Search Terms:\"));\n console.log(\n table([\n [\"Search Term\", \"Impressions\", \"Clicks\", \"CTR (%)\", \"Conversions\"],\n ...result.data\n .slice(0, 20)\n .map((t: any) => [\n t.searchTerm || \"N/A\",\n t.impressions?.toString() || \"0\",\n t.clicks?.toString() || \"0\",\n t.ctr ? (t.ctr * 100).toFixed(2) : \"0.00\",\n t.conversions?.toString() || \"0\",\n ]),\n ])\n );\n } else {\n console.error(chalk.red(\"Google Ads Error:\"), result.error);\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async googleAdsComprehensiveReport(options: {\n start: string;\n end: string;\n output?: string;\n }): Promise<void> {\n try {\n const config = loadGoogleAdsConfig();\n if (!this.clients.googleAds) {\n this.clients.googleAds = new GoogleAdsClient(config);\n }\n\n const spinner = ora(\n \"Generating comprehensive Google Ads report...\"\n ).start();\n const result = await this.clients.googleAds.getComprehensiveAdsReport(\n options.start,\n options.end\n );\n\n if (result.success) {\n spinner.succeed(\"Google Ads comprehensive report generated\");\n console.log(chalk.green(\"\\n📊 Google Ads Comprehensive Report:\"));\n console.log(chalk.blue(`Period: ${options.start} to ${options.end}`));\n console.log(\n chalk.blue(\n `Total Spend: CHF ${(result.data.totalSpend / 1000000).toFixed(2)}`\n )\n );\n console.log(chalk.blue(`Total Clicks: ${result.data.totalClicks}`));\n console.log(\n chalk.blue(`Total Impressions: ${result.data.totalImpressions}`)\n );\n console.log(\n chalk.blue(\n `Average CPC: CHF ${(result.data.averageCpc / 1000000).toFixed(2)}`\n )\n );\n console.log(\n chalk.blue(`Total Conversions: ${result.data.totalConversions}`)\n );\n\n if (options.output) {\n await fs.writeFile(\n options.output,\n JSON.stringify(result.data, null, 2)\n );\n console.log(chalk.cyan(`Report saved to ${options.output}`));\n }\n } else {\n spinner.fail(\"Google Ads report generation failed\");\n console.error(chalk.red(\"Google Ads Error:\"), result.error);\n }\n } catch (error) {\n console.error(\n chalk.red(\"Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n // Missing Meta methods (placeholder implementations)\n async metaCampaigns(options: { start: string; end: string }): Promise<void> {\n console.log(\n chalk.yellow(\n \"⚠️ Meta Ads functionality requires @akson/cortex-meta-ads package and META_ACCESS_TOKEN\"\n )\n );\n console.log(\n chalk.cyan(\n \"Configure environment variables to enable Meta Ads reporting.\"\n )\n );\n }\n\n async metaConversions(options: {\n start: string;\n end: string;\n }): Promise<void> {\n console.log(\n chalk.yellow(\n \"⚠️ Meta Ads functionality requires @akson/cortex-meta-ads package and META_ACCESS_TOKEN\"\n )\n );\n console.log(\n chalk.cyan(\n \"Configure environment variables to enable Meta Ads reporting.\"\n )\n );\n }\n\n async metaInsights(options: { start: string; end: string }): Promise<void> {\n console.log(\n chalk.yellow(\n \"⚠️ Meta Ads functionality requires @akson/cortex-meta-ads package and META_ACCESS_TOKEN\"\n )\n );\n console.log(\n chalk.cyan(\n \"Configure environment variables to enable Meta Ads reporting.\"\n )\n );\n }\n\n // Missing SEO methods (placeholder implementations)\n async seoAudit(options: { url: string; device?: string }): Promise<void> {\n console.log(\n chalk.yellow(\n \"⚠️ SEO audit functionality requires @akson/cortex-seo package with lighthouse dependencies\"\n )\n );\n console.log(\n chalk.cyan(`Would audit: ${options.url} (${options.device || \"mobile\"})`)\n );\n console.log(\n chalk.cyan(\n \"Install lighthouse and puppeteer dependencies to enable SEO auditing.\"\n )\n );\n }\n\n async seoCoreWebVitals(options: { url: string }): Promise<void> {\n console.log(\n chalk.yellow(\n \"⚠️ Core Web Vitals analysis requires @akson/cortex-seo package with lighthouse\"\n )\n );\n console.log(\n chalk.cyan(`Would analyze Core Web Vitals for: ${options.url}`)\n );\n console.log(\n chalk.cyan(\n \"Install lighthouse dependencies to enable Core Web Vitals analysis.\"\n )\n );\n }\n\n async seoSchemaValidation(options: { url: string }): Promise<void> {\n console.log(\n chalk.yellow(\"⚠️ Schema validation requires @akson/cortex-seo package\")\n );\n console.log(chalk.cyan(`Would validate schema for: ${options.url}`));\n console.log(\n chalk.cyan(\"Configure @akson/cortex-seo to enable schema validation.\")\n );\n }\n\n async seoGEOAnalysis(options: { url: string }): Promise<void> {\n console.log(\n chalk.yellow(\"⚠️ GEO analysis requires @akson/cortex-seo package\")\n );\n console.log(\n chalk.cyan(`Would analyze GEO optimization for: ${options.url}`)\n );\n console.log(\n chalk.cyan(\"Configure @akson/cortex-seo to enable GEO analysis.\")\n );\n }\n\n // Missing specialized analysis methods\n async keywordResearch(options: {\n start: string;\n end: string;\n market?: string;\n }): Promise<void> {\n console.log(chalk.blue(\"\\n🇨🇭 Swiss Military Keyword Research\"));\n console.log(\n chalk.cyan(\n \"This would combine GSC, Google Ads, and market analysis for Swiss military keywords\"\n )\n );\n console.log(chalk.cyan(`Period: ${options.start} to ${options.end}`));\n console.log(chalk.cyan(`Market: ${options.market || \"swiss-military\"}`));\n\n const swissKeywords = [\n \"militär badge\",\n \"funktionsabzeichen\",\n \"rekrutenschule souvenir\",\n \"schweizer armee\",\n \"military patches switzerland\",\n \"custom badges switzerland\",\n \"abzeichen schweizer armee\",\n \"militärische abzeichen\",\n \"truppenabzeichen\",\n ];\n\n console.log(chalk.yellow(\"\\n📊 Key Swiss Military Keywords to Track:\"));\n swissKeywords.forEach((keyword, i) => {\n console.log(` ${i + 1}. \"${keyword}\"`);\n });\n\n console.log(\n chalk.cyan(\n \"\\nConfigure GSC_SITE_URL and other env vars to get real keyword data.\"\n )\n );\n }\n\n async generateMyArmyReport(options: {\n start: string;\n end: string;\n url?: string;\n output?: string;\n }): Promise<void> {\n console.log(chalk.blue(\"\\n🎯 MyArmy.ch Comprehensive Optimization Report\"));\n console.log(chalk.cyan(`Period: ${options.start} to ${options.end}`));\n console.log(chalk.cyan(`URL: ${options.url || \"https://myarmy.ch\"}`));\n\n console.log(chalk.green(\"\\n✅ Analysis Areas:\"));\n console.log(\" 📊 Traffic Analysis - Swiss military keyword performance\");\n console.log(\" 🎯 Conversion Funnel - Lead generation optimization\");\n console.log(\" 🔍 SEO Performance - Search visibility for military terms\");\n console.log(\" 🤖 GEO Optimization - AI search engine performance\");\n console.log(\" 📱 Mobile UX - Swiss mobile market optimization\");\n console.log(\" 🇨🇭 Swiss Market Focus - Local military terminology\");\n\n console.log(\n chalk.yellow(\n \"\\n⚠️ Full report requires configured environment variables:\"\n )\n );\n console.log(\" - GSC_SITE_URL for search performance\");\n console.log(\" - GOOGLE_ADS_CUSTOMER_ID for ads analysis\");\n console.log(\" - POSTHOG_API_KEY for user behavior\");\n console.log(\" - GTM_CONTAINER_ID for conversion tracking\");\n\n if (options.output) {\n const reportData = {\n period: { start: options.start, end: options.end },\n url: options.url || \"https://myarmy.ch\",\n analysis: {\n seo: \"Requires GSC configuration\",\n ads: \"Requires Google Ads configuration\",\n analytics: \"Requires PostHog configuration\",\n conversions: \"GTM configured ✅\",\n },\n recommendations: [\n \"Configure missing environment variables\",\n \"Enable AI crawler access (already done ✅)\",\n \"Optimize for Swiss military keywords\",\n \"Improve mobile conversion funnel\",\n \"Enhance GEO for AI search engines\",\n ],\n };\n\n await fs.writeFile(options.output, JSON.stringify(reportData, null, 2));\n console.log(chalk.cyan(`\\nReport template saved to ${options.output}`));\n }\n }\n\n async trafficAnalysis(options: {\n start: string;\n end: string;\n url?: string;\n }): Promise<void> {\n console.log(chalk.blue(\"\\n📈 Traffic Analysis for MyArmy.ch\"));\n console.log(chalk.cyan(`Period: ${options.start} to ${options.end}`));\n console.log(chalk.cyan(`URL: ${options.url || \"https://myarmy.ch\"}`));\n\n console.log(chalk.green(\"\\n🔍 Analysis Focus:\"));\n console.log(\" 🇨🇭 Swiss military keyword traffic\");\n console.log(\" 📱 Mobile vs desktop performance\");\n console.log(\" 🎯 Conversion funnel efficiency\");\n console.log(\" 🤖 AI search engine referrals\");\n console.log(\" ⚡ Page load performance impact\");\n\n console.log(\n chalk.yellow(\n \"\\n⚠️ Configure analytics platforms for detailed traffic analysis.\"\n )\n );\n }\n\n async googleAdsHistorical(options: {\n start: string;\n end: string;\n customerId?: string;\n granularity?: string;\n detectAnomalies?: boolean;\n analyzeTrends?: boolean;\n analyzeSeasonality?: boolean;\n output?: string;\n outputFile?: string;\n }): Promise<void> {\n const spinner = ora(\"Performing historical Google Ads analysis...\").start();\n\n try {\n // Initialize Google Ads client if needed\n if (!this.clients.googleAds) {\n const config = loadGoogleAdsConfig();\n this.clients.googleAds = new GoogleAdsClient({ config });\n }\n\n await this.clients.googleAds.authenticate();\n\n // Create historical analyzer\n const analyzer = new HistoricalAnalyzer(this.clients.googleAds);\n\n // Perform analysis\n const result = await analyzer.analyze({\n dateRange: {\n startDate: options.start,\n endDate: options.end,\n },\n granularity:\n (options.granularity as \"daily\" | \"weekly\" | \"monthly\") || \"daily\",\n detectAnomalies: options.detectAnomalies || false,\n analyzeTrends: options.analyzeTrends || false,\n });\n\n spinner.succeed(\"Historical analysis completed\");\n\n // Display results\n console.log(chalk.blue(\"\\n📊 Historical Google Ads Analysis\"));\n console.log(chalk.cyan(`Period: ${options.start} to ${options.end}`));\n console.log(chalk.cyan(`Granularity: ${options.granularity || \"daily\"}`));\n\n if (result.success && result.data) {\n const analysis = result.data;\n\n console.log(chalk.green(\"\\n📈 Performance Summary:\"));\n console.log(` Data points: ${analysis.timeSeriesData.length}`);\n console.log(\n ` Date range: ${analysis.dateRange.startDate} to ${analysis.dateRange.endDate}`\n );\n\n if (analysis.anomalies && analysis.anomalies.length > 0) {\n console.log(\n chalk.yellow(\n `\\n⚠️ Anomalies Detected: ${analysis.anomalies.length}`\n )\n );\n analysis.anomalies.forEach((anomaly, index) => {\n console.log(\n ` ${index + 1}. ${anomaly.date}: ${anomaly.metric} = ${\n anomaly.value\n } (${anomaly.severity})`\n );\n console.log(` ${anomaly.description}`);\n });\n }\n\n if (analysis.trends) {\n console.log(chalk.blue(\"\\n📊 Trend Analysis:\"));\n Object.entries(analysis.trends).forEach(([metric, trend]) => {\n const direction =\n trend.slope > 0 ? \"📈\" : trend.slope < 0 ? \"📉\" : \"➡️\";\n console.log(\n ` ${direction} ${metric}: ${\n trend.slope > 0\n ? \"Increasing\"\n : trend.slope < 0\n ? \"Decreasing\"\n : \"Stable\"\n } (R²: ${trend.rSquared.toFixed(3)})`\n );\n });\n }\n\n // Save to file if requested\n if (options.outputFile) {\n const outputData =\n options.output === \"csv\"\n ? this.formatAsCSV(analysis.timeSeriesData)\n : JSON.stringify(analysis, null, 2);\n\n await fs.writeFile(options.outputFile, outputData);\n console.log(\n chalk.green(`\\n✅ Results saved to ${options.outputFile}`)\n );\n }\n } else {\n console.log(chalk.red(\"\\n❌ Analysis failed:\"), result.error);\n }\n } catch (error) {\n spinner.fail(\"Historical analysis failed\");\n console.error(\n chalk.red(\"\\n❌ Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n async googleAdsSwissMarket(options: {\n start?: string;\n end?: string;\n customerId?: string;\n includeCompetitors?: boolean;\n analyzeSeasonality?: boolean;\n opportunityAnalysis?: boolean;\n output?: string;\n outputFile?: string;\n }): Promise<void> {\n const spinner = ora(\"Analyzing Swiss military market...\").start();\n\n try {\n // Initialize Google Ads client if needed\n if (!this.clients.googleAds) {\n const config = loadGoogleAdsConfig();\n this.clients.googleAds = new GoogleAdsClient({ config });\n }\n\n await this.clients.googleAds.authenticate();\n\n // Create Swiss market analyzer\n const analyzer = new SwissMarketAnalyzer(this.clients.googleAds);\n\n // Perform analysis - use provided dates or default to last 30 days\n const endDate = options.end || new Date().toISOString().split(\"T\")[0]; // Today\n const startDate =\n options.start ||\n new Date(Date.now() - 30 * 24 * 60 * 60 * 1000)\n .toISOString()\n .split(\"T\")[0]; // 30 days ago\n\n const result = await analyzer.analyze({\n startDate,\n endDate,\n includeCompetitors: options.includeCompetitors || false,\n analyzeSeasonality: options.analyzeSeasonality || false,\n });\n\n spinner.succeed(\"Swiss market analysis completed\");\n\n // Display results\n console.log(chalk.blue(\"\\n🇨🇭 Swiss Military Market Analysis\"));\n\n if (result.success && result.data) {\n const analysis = result.data;\n\n console.log(chalk.green(\"\\n🎯 Keyword Performance:\"));\n if (\n analysis.keywordPerformance &&\n analysis.keywordPerformance.length > 0\n ) {\n const topKeywords = analysis.keywordPerformance.slice(0, 10);\n topKeywords.forEach((keyword, index) => {\n const cost = keyword.metrics?.cpc\n ? keyword.metrics.cpc.toFixed(2)\n : \"0.00\";\n const impressions = keyword.metrics?.impressions || 0;\n const clicks = keyword.metrics?.clicks || 0;\n console.log(\n ` ${index + 1}. \"${\n keyword.keyword\n }\": ${impressions} impressions, ${clicks} clicks, CHF ${cost}`\n );\n });\n } else {\n console.log(\" No keyword performance data available\");\n }\n\n if (\n options.includeCompetitors &&\n analysis.competitorAnalysis &&\n analysis.competitorAnalysis.length > 0\n ) {\n console.log(chalk.yellow(\"\\n🏢 Competitor Analysis:\"));\n analysis.competitorAnalysis.forEach((competitor, index) => {\n const overlapScore = competitor.overlapScore || 0;\n const marketShare = competitor.marketShare || 0;\n console.log(\n ` ${index + 1}. ${\n competitor.domain\n }: Overlap Score ${overlapScore}%, Market Share ${marketShare}%`\n );\n });\n }\n\n if (\n options.opportunityAnalysis &&\n analysis.opportunities &&\n analysis.opportunities.length > 0\n ) {\n console.log(chalk.cyan(\"\\n💡 Market Opportunities:\"));\n analysis.opportunities.forEach((opportunity, index) => {\n console.log(\n ` ${index + 1}. ${opportunity.keyword}: ${\n opportunity.opportunityType\n } (Score: ${opportunity.opportunityScore})`\n );\n console.log(` ${opportunity.recommendation}`);\n });\n }\n\n // Save to file if requested\n if (options.outputFile) {\n const outputData =\n options.output === \"csv\"\n ? this.formatSwissMarketAsCSV(analysis)\n : JSON.stringify(analysis, null, 2);\n\n await fs.writeFile(options.outputFile, outputData);\n console.log(\n chalk.green(`\\n✅ Results saved to ${options.outputFile}`)\n );\n }\n } else {\n console.log(chalk.red(\"\\n❌ Analysis failed:\"), result.error);\n }\n } catch (error) {\n spinner.fail(\"Swiss market analysis failed\");\n console.error(\n chalk.red(\"\\n❌ Error:\"),\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n private formatAsCSV(data: any[]): string {\n if (data.length === 0) return \"\";\n\n const headers = Object.keys(data[0]);\n const rows = data.map((item) =>\n headers.map((header) => item[header] || \"\").join(\",\")\n );\n\n return [headers.join(\",\"), ...rows].join(\"\\n\");\n }\n\n private formatSwissMarketAsCSV(analysis: any): string {\n const keywordRows = analysis.keywordPerformance.map(\n (k: any) =>\n `${k.keyword},${k.impressions},${k.clicks},${k.cost},${k.ctr},${k.position}`\n );\n\n return [\n \"keyword,impressions,clicks,cost,ctr,position\",\n ...keywordRows,\n ].join(\"\\n\");\n }\n}\n","/**\n * @akson/cortex-analytics Help System\n *\n * Comprehensive help and documentation functions\n */\n\nimport chalk from \"chalk\";\nimport { table } from \"table\";\n\nexport interface CommandHelp {\n command: string;\n description: string;\n usage: string;\n examples: string[];\n options?: { flag: string; description: string; default?: string }[];\n}\n\nexport interface ModuleHelp {\n module: string;\n description: string;\n commands: CommandHelp[];\n dependencies?: string[];\n}\n\n/**\n * Get version information\n */\nexport function getVersion(): string {\n try {\n const pkg = require(\"../package.json\");\n return pkg.version;\n } catch {\n return \"0.0.0\";\n }\n}\n\n/**\n * Display comprehensive help for the entire CLI\n */\nexport function showComprehensiveHelp(): void {\n const version = getVersion();\n\n console.log(\n chalk.cyan.bold(`\n@akson/cortex-analytics v${version}\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n\n🚀 Unified CLI for MyArmy Analytics Operations\n\nQUICK START:\n npx @akson/cortex-analytics health --verbose # Check all platform health\n npx @akson/cortex-analytics setup # Interactive setup\n npx @akson/cortex-analytics myarmy-report --start 2024-01-01 --end 2024-01-31\n\nMAIN COMMANDS:\n`)\n );\n\n const mainCommands = [\n [\"health\", \"Check health of all analytics platforms\", \"health --verbose\"],\n [\"setup\", \"Interactive configuration setup\", \"setup\"],\n [\n \"dashboard\",\n \"Generate unified analytics dashboard\",\n \"dashboard -s 2024-01-01 -e 2024-01-31\",\n ],\n [\n \"analyze\",\n \"Cross-platform analytics analysis\",\n \"analyze -s 2024-01-01 -e 2024-01-31 -p posthog gsc\",\n ],\n [\n \"myarmy-report\",\n \"Comprehensive MyArmy.ch optimization report\",\n \"myarmy-report -s 2024-01-01 -e 2024-01-31\",\n ],\n ];\n\n console.log(\n table(mainCommands, {\n header: {\n alignment: \"left\",\n content: `${chalk.bold(\"Command\")} | ${chalk.bold(\n \"Description\"\n )} | ${chalk.bold(\"Example\")}`,\n },\n border: {\n topBody: `─`,\n topJoin: `┬`,\n topLeft: `┌`,\n topRight: `┐`,\n bottomBody: `─`,\n bottomJoin: `┴`,\n bottomLeft: `└`,\n bottomRight: `┘`,\n bodyLeft: `│`,\n bodyRight: `│`,\n bodyJoin: `│`,\n joinBody: `─`,\n joinLeft: `├`,\n joinRight: `┤`,\n joinJoin: `┼`,\n },\n })\n );\n\n console.log(\n chalk.cyan(`\nPLATFORM-SPECIFIC COMMANDS:\n gtm # Google Tag Manager operations\n gsc # Google Search Console operations \n gads # Google Ads operations\n posthog # PostHog analytics operations\n meta # Meta/Facebook Ads operations\n seo # SEO analysis and optimization\n\nUTILITY COMMANDS:\n events standardize # Standardize events across platforms\n keyword-research # Research keywords across platforms\n traffic-analysis # Analyze traffic patterns\n\nFor detailed help on any command: akson [command] --help\nDocumentation: https://docs.myarmy.ch/akson/cli-analytics\n`)\n );\n}\n\n/**\n * Show quick start guide\n */\nexport function showQuickStart(): void {\n console.log(\n chalk.green.bold(`\n🚀 @akson/cortex-analytics Quick Start Guide\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n\n1. Setup (First Time):\n ${chalk.cyan(\"npx @akson/cortex-analytics setup\")}\n\n2. Health Check:\n ${chalk.cyan(\"npx @akson/cortex-analytics health --verbose\")}\n\n3. Generate Dashboard:\n ${chalk.cyan(\n \"npx @akson/cortex-analytics dashboard -s 2024-01-01 -e 2024-01-31\"\n )}\n\n4. MyArmy Swiss Market Report:\n ${chalk.cyan(\n \"npx @akson/cortex-analytics myarmy-report -s 2024-01-01 -e 2024-01-31\"\n )}\n\n5. Swiss Military Keywords:\n ${chalk.cyan(\n \"npx @akson/cortex-analytics keyword-research -k 'militär badge' 'funktionsabzeichen' -s 2024-01-01 -e 2024-01-31\"\n )}\n\n6. GTM Configuration:\n ${chalk.cyan(\"npx @akson/cortex-analytics gtm validate\")}\n ${chalk.cyan(\"npx @akson/cortex-analytics gtm plan\")}\n ${chalk.cyan(\"npx @akson/cortex-analytics gtm apply\")}\n\nNeed help? Run: ${chalk.yellow(\"akson [command] --help\")}\n`)\n );\n}\n\n/**\n * Show Swiss military market specific help\n */\nexport function showSwissMarketHelp(): void {\n console.log(\n chalk.green.bold(`\n🇨🇭 Swiss Military Market Analytics - MyArmy.ch\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n\nSWISS KEYWORDS (Primary):\n • militär badge\n • funktionsabzeichen \n • rekrutenschule souvenir\n • schweizer armee\n • abzeichen schweizer armee\n\nSWISS KEYWORDS (Secondary):\n • military patches switzerland\n • custom badges switzerland\n • militärische abzeichen\n • truppenabzeichen\n • swiss army patches\n • schweizer militär merchandise\n\nSWISS MARKET ANALYSIS:\n ${chalk.cyan(\n \"akson gads swiss-market --start 2024-01-01 --end 2024-01-31 --analyze-seasonality\"\n )}\n\nGSC RANKINGS (Swiss Keywords):\n ${chalk.cyan(\n \"akson gsc rankings -k 'militär badge' 'funktionsabzeichen' 'schweizer armee' -s 2024-01-01 -e 2024-01-31\"\n )}\n\nCOMPREHENSIVE MYARMY REPORT:\n ${chalk.cyan(\n \"akson myarmy-report -s 2024-01-01 -e 2024-01-31 --output file --file myarmy-optimization.json\"\n )}\n\nSWISS TRAFFIC ANALYSIS:\n ${chalk.cyan(\n \"akson traffic-analysis -s 2024-01-01 -e 2024-01-31 -u https://myarmy.ch\"\n )}\n`)\n );\n}\n\n/**\n * Show platform status and configuration help\n */\nexport function showPlatformStatus(): void {\n console.log(\n chalk.blue.bold(`\n📊 Platform Configuration Status\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n\nPLATFORM CONFIGURATION:\n`)\n );\n\n const platforms = [\n [\"GTM\", \"✅ Connected\", \"GTM-T8WRBMWV\", \"Google Service Account\"],\n [\"GSC\", \"✅ Connected\", \"https://myarmy.ch\", \"Google Service Account\"],\n [\"Google Ads\", \"✅ Connected\", \"8847935674\", \"Google Service Account\"],\n [\"PostHog\", \"✅ Connected\", \"phc_Y8vb...\", \"API Key\"],\n [\"Meta Ads\", \"⚠️ Optional\", \"Not configured\", \"META_ACCESS_TOKEN needed\"],\n ];\n\n console.log(\n table(platforms, {\n header: {\n alignment: \"left\",\n content: `${chalk.bold(\"Platform\")} | ${chalk.bold(\n \"Status\"\n )} | ${chalk.bold(\"Config\")} | ${chalk.bold(\"Auth Method\")}`,\n },\n })\n );\n\n console.log(\n chalk.blue(`\nENVIRONMENT SETUP:\n Run: ${chalk.cyan(\"npx @akson/cortex-analytics setup\")}\n Or manually set environment variables in packages/@akson/cortex-.env\n\nHEALTH CHECK:\n Run: ${chalk.cyan(\"npx @akson/cortex-analytics health --verbose\")}\n\nFor platform-specific help:\n • GTM: akson gtm --help\n • GSC: akson gsc --help \n • Google Ads: akson gads --help\n • PostHog: akson posthog --help\n`)\n );\n}\n\n/**\n * Get all available commands and their descriptions\n */\nexport function getCommands(): ModuleHelp[] {\n return [\n {\n module: \"Core Commands\",\n description: \"Essential analytics operations\",\n commands: [\n {\n command: \"health\",\n description: \"Check health of all analytics platforms\",\n usage: \"akson health [options]\",\n examples: [\"akson health --verbose\", \"akson health\"],\n options: [\n {\n flag: \"-v, --verbose\",\n description: \"Show detailed health information\",\n },\n ],\n },\n {\n command: \"setup\",\n description: \"Interactive setup for analytics configuration\",\n usage: \"akson setup\",\n examples: [\"akson setup\"],\n },\n {\n command: \"dashboard\",\n description: \"Generate unified analytics dashboard\",\n usage: \"akson dashboard [options]\",\n examples: [\n \"akson dashboard -s 2024-01-01 -e 2024-01-31\",\n \"akson dashboard -s 2024-01-01 -e 2024-01-31 --output json\",\n ],\n options: [\n {\n flag: \"-s, --start <date>\",\n description: \"Start date (YYYY-MM-DD)\",\n },\n { flag: \"-e, --end <date>\", description: \"End date (YYYY-MM-DD)\" },\n {\n flag: \"-o, --output <format>\",\n description: \"Output format (json|table)\",\n default: \"table\",\n },\n ],\n },\n ],\n },\n {\n module: \"GTM Operations\",\n description: \"Google Tag Manager configuration and management\",\n commands: [\n {\n command: \"gtm validate\",\n description: \"Validate GTM configuration file\",\n usage: \"akson gtm validate [options]\",\n examples: [\n \"akson gtm validate\",\n \"akson gtm validate -c custom.config.yaml\",\n ],\n options: [\n {\n flag: \"-c, --config <path>\",\n description: \"Configuration file path\",\n default: \"gtm.config.yaml\",\n },\n ],\n },\n {\n command: \"gtm plan\",\n description: \"Show changes that would be applied to GTM\",\n usage: \"akson gtm plan [options]\",\n examples: [\n \"akson gtm plan\",\n \"akson gtm plan -c gtm.config.yaml -o plan.json\",\n ],\n },\n {\n command: \"gtm apply\",\n description: \"Apply GTM configuration changes\",\n usage: \"akson gtm apply [options]\",\n examples: [\"akson gtm apply\", \"akson gtm apply --yes --verbose\"],\n },\n ],\n dependencies: [\"@akson/cortex-gtm\", \"Google Service Account Key\"],\n },\n {\n module: \"Swiss Market Analytics\",\n description: \"Specialized Swiss military market analysis\",\n commands: [\n {\n command: \"myarmy-report\",\n description: \"Generate comprehensive MyArmy.ch optimization report\",\n usage: \"akson myarmy-report [options]\",\n examples: [\n \"akson myarmy-report -s 2024-01-01 -e 2024-01-31\",\n \"akson myarmy-report -s 2024-01-01 -e 2024-01-31 --output file --file report.json\",\n ],\n },\n {\n command: \"keyword-research\",\n description: \"Research Swiss military keywords across platforms\",\n usage: \"akson keyword-research [options]\",\n examples: [\n \"akson keyword-research -k 'militär badge' 'funktionsabzeichen' -s 2024-01-01 -e 2024-01-31\",\n \"akson keyword-research -k 'swiss army patches' -s 2024-01-01 -e 2024-01-31 -c CH\",\n ],\n },\n ],\n },\n ];\n}\n\n/**\n * Show examples for common use cases\n */\nexport function showExamples(): void {\n console.log(\n chalk.magenta.bold(`\n💡 Common Use Cases & Examples\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n\n🔍 DAILY MONITORING:\n ${chalk.cyan(\"akson health --verbose\")}\n ${chalk.cyan(\"akson dashboard -s 2024-01-01 -e 2024-01-31\")}\n\n🇨🇭 SWISS MARKET ANALYSIS:\n ${chalk.cyan(\n \"akson keyword-research -k 'militär badge' 'funktionsabzeichen' -s 2024-01-01 -e 2024-01-31\"\n )}\n ${chalk.cyan(\n \"akson gads swiss-market --start 2024-01-01 --end 2024-01-31 --analyze-seasonality\"\n )}\n ${chalk.cyan(\"akson myarmy-report -s 2024-01-01 -e 2024-01-31\")}\n\n🏷️ GTM MANAGEMENT:\n ${chalk.cyan(\"akson gtm validate\")}\n ${chalk.cyan(\"akson gtm plan\")}\n ${chalk.cyan(\"akson gtm apply --yes\")}\n\n📊 CROSS-PLATFORM ANALYSIS:\n ${chalk.cyan(\n \"akson analyze -s 2024-01-01 -e 2024-01-31 -p posthog gsc google-ads\"\n )}\n ${chalk.cyan(\"akson events standardize -e lead_whatsapp_contact purchase\")}\n\n🔎 SEO OPTIMIZATION:\n ${chalk.cyan(\n 'akson gsc rankings -k \"militär badge\" \"funktionsabzeichen\" -s 2024-01-01 -e 2024-01-31'\n )}\n ${chalk.cyan(\"akson seo audit -u https://myarmy.ch --device mobile\")}\n ${chalk.cyan(\n \"akson traffic-analysis -s 2024-01-01 -e 2024-01-31 -u https://myarmy.ch\"\n )}\n\n📈 POSTHOG QUERIES:\n ${chalk.cyan(\n \"akson posthog query -q \\\"SELECT event, count() FROM events WHERE timestamp > '2024-01-01' GROUP BY event\\\"\"\n )}\n ${chalk.cyan(\n \"akson posthog funnel -e lead_page_view,lead_inquiry_started,lead_form_submitted -s 2024-01-01 -e 2024-01-31\"\n )}\n`)\n );\n}\n\n/**\n * Show troubleshooting guide\n */\nexport function showTroubleshooting(): void {\n console.log(\n chalk.red.bold(`\n🔧 Troubleshooting Guide\n━━━━━━━━━━━━━━━━━━━━━━━━━━━\n\nCOMMON ISSUES:\n\n❌ Authentication Errors:\n • Check Google Service Account key: config/gtm-api-automation.json\n • Verify environment variables: cd packages/@akson && node config-loader.js validate\n • Re-run setup: akson setup\n\n❌ \"No data\" Responses:\n • Check date ranges (use YYYY-MM-DD format)\n • Verify platform access with: akson health --verbose\n • Check site URL configuration: GSC_SITE_URL=\"https://myarmy.ch\"\n\n❌ GTM Configuration Issues:\n • Validate config: akson gtm validate\n • Check workspace access: akson gtm query --type workspaces\n • Use test workspace for development, not Default (ID: 40)\n\n❌ PostHog Connection Issues:\n • Verify API key: POSTHOG_API_KEY in .env\n • Check project host: POSTHOG_HOST=\"https://us.i.posthog.com\"\n • Test connection: akson posthog query -q \"SELECT 1\"\n\n❌ Google Ads Access Issues:\n • Use correct Customer ID: 8847935674 (not 659644670)\n • Check developer token: GOOGLE_ADS_DEVELOPER_TOKEN\n • Verify service account permissions\n\nHELP COMMANDS:\n • Platform status: akson platform-status\n • Environment check: cd packages/@akson && node config-loader.js summary\n • Health check: akson health --verbose\n\nSupport: Check /packages/@akson/cortex-README.md for detailed documentation\n`)\n );\n}\n\n/**\n * Show getting started guide\n */\nexport function showGettingStarted(): void {\n console.log(\n chalk.green.bold(`\n🚀 Getting Started with @akson/cortex-analytics\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n\nSTEP 1: SETUP\n ${chalk.cyan(\"cd /Users/antoineschaller/GitHub/myarmy/packages/@akson\")}\n ${chalk.cyan(\"./setup-env.sh\")}\n\nSTEP 2: VERIFY CONFIGURATION \n ${chalk.cyan(\"node config-loader.js summary\")}\n ${chalk.cyan(\"npx @akson/cortex-analytics health --verbose\")}\n\nSTEP 3: RUN YOUR FIRST REPORTS\n ${chalk.cyan(\n \"npx @akson/cortex-analytics myarmy-report -s 2024-01-01 -e 2024-01-31\"\n )}\n ${chalk.cyan(\n \"npx @akson/cortex-analytics dashboard -s 2024-01-01 -e 2024-01-31\"\n )}\n\nSTEP 4: EXPLORE SWISS MARKET DATA\n ${chalk.cyan(\n \"npx @akson/cortex-analytics keyword-research -k 'militär badge' -s 2024-01-01 -e 2024-01-31\"\n )}\n ${chalk.cyan(\n \"npx @akson/cortex-analytics gsc rankings -k 'funktionsabzeichen' -s 2024-01-01 -e 2024-01-31\"\n )}\n\nKEY FILES:\n • Configuration: packages/@akson/cortex-analytics-config.yaml\n • Environment: packages/@akson/cortex-.env \n • Service Account: landing/config/gtm-api-automation.json\n\nNext Steps:\n • akson quick-start # Show quick start guide\n • akson examples # Show common use cases\n • akson swiss-market # Swiss-specific help\n`)\n );\n}\n"],"mappings":"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","names":["chalk","config","payload","transformed","fs","chalk","table","chalk"]}
|