@lightcone-ai/daemon 0.15.29 → 0.15.30

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lightcone-ai/daemon",
3
- "version": "0.15.29",
3
+ "version": "0.15.30",
4
4
  "type": "module",
5
5
  "main": "src/index.js",
6
6
  "bin": {
@@ -1472,7 +1472,7 @@ server.tool('record_url_narration',
1472
1472
  'Record a silent video of a URL by orchestrating Xvfb + Chromium + ffmpeg, driven by a video plan. Outputs a silent mp4 plus an events.json timestamp log that compose_video can use to align audio segments.\n\nUse this as the canonical recording step for URL-narration videos. Falls back: if the page needs interactions outside the visual_action vocabulary (clicks, waits, OCR loops), use Monitor (Bash) with custom Playwright instead.\n\nRuntime requirements: this tool only works on a Linux daemon machine with Xvfb + ffmpeg (x11grab) + Chromium installed. macOS / Windows daemons will fail at startup.',
1473
1473
  {
1474
1474
  url: z.string().describe('Page URL to record'),
1475
- plan: z.record(z.any()).describe('Video plan from plan_video / detail_sections containing phases array with visual_action per phase'),
1475
+ plan: z.record(z.any()).describe('Must be the full output from detail_sections (not plan_video). detail_sections output includes detail_sections_version, sections[], audio metadata, and dwell_ms per phase.'),
1476
1476
  output_path: z.string().optional().describe('Workspace-relative output mp4 path. Default tmp/wx3_video/recorded-{ts}.mp4'),
1477
1477
  events_path: z.string().optional().describe('Workspace-relative events.json path. Default ${output_path}.events.json'),
1478
1478
  viewport: z.object({
@@ -1511,7 +1511,7 @@ server.tool('compose_video',
1511
1511
  text: z.string().describe('Subtitle text for this segment (the narration sentence).'),
1512
1512
  start_ms: z.number().describe('Subtitle start time in milliseconds.'),
1513
1513
  end_ms: z.number().describe('Subtitle end time in milliseconds.'),
1514
- })).optional().describe('Subtitle segments to burn into the video. Pass each phase narration text with its start/end time (derived from detail_sections dwell_ms). Omit to produce no subtitles.'),
1514
+ })).optional().describe('Subtitle segments to burn into the video. Pass each phase sentence text (from detail_sections sections[].sentence) with cumulative start/end time derived from dwell_ms. Omit to produce no subtitles.'),
1515
1515
  outro_path: z.string().optional().describe('Optional outro mp4 path. If omitted, uses ~/.lightcone/assets/outros/default.mp4 when present.'),
1516
1516
  target: z.enum(['short_video_cn', 'douyin', 'xhs']).optional().describe('Transcode target profile. Defaults to short_video_cn.'),
1517
1517
  },
@@ -55,7 +55,7 @@ function assertPipelineCompliance(plan) {
55
55
  if (!plan[PIPELINE_SENTINEL_KEY]) {
56
56
  throw new Error(
57
57
  'pipeline_violation: plan must come from detail_sections output. '
58
- + 'Required pipeline: analyze_page → plan_video → detail_sections → generate_voiceover → record_url_narration → compose_video → submit_to_library. '
58
+ + 'Required pipeline: analyze_page → plan_video → detail_sections → record_url_narration → compose_video → submit_to_library. '
59
59
  + 'Do not hand-write phases or bypass detail_sections.'
60
60
  );
61
61
  }