新增媒体

向媒体库中新增媒体文件时,可以指定工作流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));