Skip to main content
在 Youka 中,每个异步操作最终都会以任务的形式运行,但目前 SDK 的主要接口会返回操作句柄,而不是原始任务 ID。大多数调用方应该使用 client.projects.wait(...)client.exports.wait(...),只有在需要进行底层任务检查时才使用 client.tasks.*

client.tasks.get(taskId, options?)

按 ID 获取任务的当前状态。
const task = await client.tasks.get("tsk_abc123");
console.log(task.status, task.type);

任务状态

状态终态?含义
created任务已创建,但尚未进入队列。
queued任务正在等待运行。
in-progress任务正在执行中。
completed任务已成功完成。
finalized任务已完成,且后处理已结束。
failed任务因错误而失败。
cancelled任务已被取消。
timed-out任务已达到时间限制。

client.tasks.wait(taskId, options?)

轮询任务,直到它进入终态。成功时返回最终任务;失败时抛出 YoukaTaskError
const task = await client.tasks.wait("tsk_abc123", {
  pollIntervalMs: 3_000,
  signal: abortController.signal,
});

选项

pollIntervalMs
number
两次轮询之间的毫秒数。默认为 2000
signal
AbortSignal
中止等待。进行中的请求以及任何尚未执行的延迟都会立即取消。

错误

当任务以 failedcancelledtimed-out 结束时,client.tasks.wait(...) 会抛出 YoukaTaskError
import { YoukaTaskError } from "@youka/sdk";

try {
  await client.tasks.wait("tsk_abc123");
} catch (error) {
  if (error instanceof YoukaTaskError) {
    console.error(error.code); // TASK_FAILED | TASK_CANCELLED | TASK_TIMED_OUT
    console.error(error.task); // Full RestTask payload
  }
  throw error;
}

client.projects.wait(operation, options?)

等待项目范围内的操作完成,然后重新获取项目。返回操作句柄、进入终态的任务以及更新后的项目。
const operation = await client.projects.create({
  source: { type: "path", path: "./song.mp3" },
});

const { project, task } = await client.projects.wait(operation, {
  pollIntervalMs: 2_500,
});

console.log("Project ready:", project.id);
console.log("Task finished in state:", task.status);
operation
ProjectOperation
required
通常是 client.projects.create(...)client.projects.separateStems(...)client.projects.syncLyrics(...) 的返回结果。

client.exports.wait(operationOrId, options?)

等待云端导出进入终态。可传入 client.exports.create(...) 返回的 ExportOperation,或一个 exportId 字符串。
const operation = await client.exports.create("prj_abc123", {
  resolution: "1080p",
  quality: "high",
});

const finalized = await client.exports.wait(operation, {
  pollIntervalMs: 3_000,
});

console.log(finalized.status, finalized.url);

取消

传入 AbortSignal 以取消长时间等待:
const controller = new AbortController();

setTimeout(() => controller.abort(), 60_000);

try {
  await client.projects.wait(operation, { signal: controller.signal });
} catch (error) {
  if (error instanceof Error && error.name === "AbortError") {
    console.log("Wait cancelled after 60s");
  } else {
    throw error;
  }
}
同一个 signal 也会取消底层的任务或导出轮询请求。

下一步

  • 错误 — 处理 YoukaTaskError 和可重试错误
  • 导出 — 等待导出完成
  • API async jobs — 在原始 HTTP 中使用相同模式