向媒体库中新增媒体文件时,可以指定工作流ID触发工作流执行,对新增的媒体文件进行媒体处理。本文介绍通过Node.js SDK V2.0新增媒体并触发工作流执行的示例代码。
示例代码
说明
如果上传的目录满足工作流触发条件,则会触发工作流执行,否则不触发。更多信息,请参见工作流的文件匹配规则。
'use strict';
const Mts20140618 = require('@alicloud/mts20140618');
const OpenApi = require('@alicloud/openapi-client');
const Util = require('@alicloud/tea-util');
const Tea = require('@alicloud/tea-typescript');
class Client {
/**
* 使用AK&SK初始化账号Client
* @return Client
* @throws Exception
*/
static createClient() {
let config = new OpenApi.Config({
// 必填,请确保代码运行环境设置了环境变量 ALIBABA_CLOUD_ACCESS_KEY_ID。
accessKeyId: process.env['ALIBABA_CLOUD_ACCESS_KEY_ID'],
// 必填,请确保代码运行环境设置了环境变量 ALIBABA_CLOUD_ACCESS_KEY_SECRET。
accessKeySecret: process.env['ALIBABA_CLOUD_ACCESS_KEY_SECRET'],
});
config.endpoint = `mts.cn-qingdao.aliyuncs.com`;
return new Mts20140618.default(config);
}
static async main(args) {
let client = Client.createClient();
let addMediaRequest = new Mts20140618.AddMediaRequest({
//输入文件的路径
fileURL: 'http://bucket.oss-cn-hangzhou.aliyuncs.com/A/B/C/test.mp4',
//媒体标题
title: 'mytest',
//描述
description: 'A test video',
//封面URL
coverURL: 'http://bucket.oss-cn-hangzhou.aliyuncs.com/example/1.png',
//标签列表
tags: 'tag1,tag2',
//媒体工作流ID
mediaWorkflowId: '07da6c65da7f458997336e0de192****',
//媒体工作流用户自定义数据
mediaWorkflowUserData: 'test',
//是否检查指定的工作流支持输入路径
inputUnbind: false,
//媒体所属类目ID
cateId: 123,
//覆盖参数
overrideParams: '{“subtitleTransNodeName”:{“InputConfig”:{“Format”:”stl”,”InputFile”:{“URL”:”http://exampleBucket.oss-cn-hangzhou.aliyuncs.com/package/example/CENG.stl"}}}}',
});
let runtime = new Util.RuntimeOptions({ });
try {
// 复制代码运行请自行打印 API 的返回值
await client.addMediaWithOptions(addMediaRequest, runtime);
} catch (error) {
// 此处仅做打印展示,请谨慎对待异常处理,在工程项目中切勿直接忽略异常。
// 错误 message
console.log(error.message);
// 诊断地址
console.log(error.data["Recommend"]);
Util.default.assertAsString(error.message);
}
}
}
exports.Client = Client;
Client.main(process.argv.slice(2));
文档内容是否对您有帮助?