{"version":3,"sources":["../src/cli/commands/graphs/update.ts"],"sourcesContent":["import chalk from \"chalk\";\nimport ora from \"ora\";\nimport { checkApiKey } from \"../../utils/apiKey\";\nimport { formatFetchError } from \"../../utils/formatFetchError\";\nimport { failSpinner } from \"../../utils/spinnerError\";\nimport { buildAuthHeaders } from \"@/internal/api/auth\";\n\nimport { resolveControlPlaneUrl } from \"@/cli/utils/governance/resolveEndpoint\";\nexport const updateGraphCommand = async (\n  id: string,\n  options: {\n    name?: string;\n    graph?: string;\n    filters?: string;\n    format?: string;\n  }\n): Promise<void> => {\n  checkApiKey();\n\n  if (!options.name && !options.graph && !options.filters) {\n    console.error(\n      chalk.red(\n        \"Error: At least one of --name, --graph, or --filters is required\"\n      )\n    );\n    process.exit(1);\n  }\n\n  const apiKey = process.env.LANGWATCH_API_KEY ?? \"\";\n  const endpoint =\n    resolveControlPlaneUrl();\n\n  const spinner = ora(`Updating graph \"${id}\"...`).start();\n\n  try {\n    const body: Record<string, unknown> = {};\n    if (options.name) body.name = options.name;\n    if (options.graph) {\n      body.graph = JSON.parse(options.graph) as Record<string, unknown>;\n    }\n    if (options.filters) {\n      body.filters = JSON.parse(options.filters) as Record<string, unknown>;\n    }\n\n    const response = await fetch(`${endpoint}/api/graphs/${id}`, {\n      method: \"PATCH\",\n      headers: {\n        \"Content-Type\": \"application/json\",\n        ...buildAuthHeaders({ apiKey }),\n      },\n      body: JSON.stringify(body),\n    });\n\n    if (!response.ok) {\n      const message = await formatFetchError(response);\n      spinner.fail(`Failed to update graph: ${message}`);\n      process.exit(1);\n    }\n\n    const graph = (await response.json()) as {\n      id: string;\n      name: string;\n    };\n    spinner.succeed(`Graph \"${graph.name}\" updated`);\n\n    if (options.format === \"json\") {\n      console.log(JSON.stringify(graph, null, 2));\n      return;\n    }\n\n    console.log();\n    console.log(`  ${chalk.gray(\"ID:\")}   ${chalk.green(graph.id)}`);\n    console.log(`  ${chalk.gray(\"Name:\")} ${chalk.cyan(graph.name)}`);\n    console.log();\n  } catch (error) {\n    if (error instanceof SyntaxError) {\n      spinner.fail(chalk.red(\"--graph and --filters must be valid JSON\"));\n    } else {\n      failSpinner({ spinner, error, action: \"update graph\" });\n    }\n    process.exit(1);\n  }\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,WAAW;AAClB,OAAO,SAAS;AAOT,IAAM,qBAAqB,OAChC,IACA,YAMkB;AAhBpB;AAiBE,cAAY;AAEZ,MAAI,CAAC,QAAQ,QAAQ,CAAC,QAAQ,SAAS,CAAC,QAAQ,SAAS;AACvD,YAAQ;AAAA,MACN,MAAM;AAAA,QACJ;AAAA,MACF;AAAA,IACF;AACA,YAAQ,KAAK,CAAC;AAAA,EAChB;AAEA,QAAM,UAAS,aAAQ,IAAI,sBAAZ,YAAiC;AAChD,QAAM,WACJ,uBAAuB;AAEzB,QAAM,UAAU,IAAI,mBAAmB,EAAE,MAAM,EAAE,MAAM;AAEvD,MAAI;AACF,UAAM,OAAgC,CAAC;AACvC,QAAI,QAAQ,KAAM,MAAK,OAAO,QAAQ;AACtC,QAAI,QAAQ,OAAO;AACjB,WAAK,QAAQ,KAAK,MAAM,QAAQ,KAAK;AAAA,IACvC;AACA,QAAI,QAAQ,SAAS;AACnB,WAAK,UAAU,KAAK,MAAM,QAAQ,OAAO;AAAA,IAC3C;AAEA,UAAM,WAAW,MAAM,MAAM,GAAG,QAAQ,eAAe,EAAE,IAAI;AAAA,MAC3D,QAAQ;AAAA,MACR,SAAS;AAAA,QACP,gBAAgB;AAAA,SACb,iBAAiB,EAAE,OAAO,CAAC;AAAA,MAEhC,MAAM,KAAK,UAAU,IAAI;AAAA,IAC3B,CAAC;AAED,QAAI,CAAC,SAAS,IAAI;AAChB,YAAM,UAAU,MAAM,iBAAiB,QAAQ;AAC/C,cAAQ,KAAK,2BAA2B,OAAO,EAAE;AACjD,cAAQ,KAAK,CAAC;AAAA,IAChB;AAEA,UAAM,QAAS,MAAM,SAAS,KAAK;AAInC,YAAQ,QAAQ,UAAU,MAAM,IAAI,WAAW;AAE/C,QAAI,QAAQ,WAAW,QAAQ;AAC7B,cAAQ,IAAI,KAAK,UAAU,OAAO,MAAM,CAAC,CAAC;AAC1C;AAAA,IACF;AAEA,YAAQ,IAAI;AACZ,YAAQ,IAAI,KAAK,MAAM,KAAK,KAAK,CAAC,MAAM,MAAM,MAAM,MAAM,EAAE,CAAC,EAAE;AAC/D,YAAQ,IAAI,KAAK,MAAM,KAAK,OAAO,CAAC,IAAI,MAAM,KAAK,MAAM,IAAI,CAAC,EAAE;AAChE,YAAQ,IAAI;AAAA,EACd,SAAS,OAAO;AACd,QAAI,iBAAiB,aAAa;AAChC,cAAQ,KAAK,MAAM,IAAI,0CAA0C,CAAC;AAAA,IACpE,OAAO;AACL,kBAAY,EAAE,SAAS,OAAO,QAAQ,eAAe,CAAC;AAAA,IACxD;AACA,YAAQ,KAAK,CAAC;AAAA,EAChB;AACF;","names":[]}