Как автоматически загрузить транскрипт (файл VTT) видео с помощью приложения Logi c? - PullRequest
0 голосов
/ 23 марта 2020

Я проиндексировал несколько видео в videoindexer.ai с помощью приложения logi c. Но мне было интересно, есть ли способ использовать приложение Logi c для загрузки файла с расшифровкой в ​​формате VTT и помещения его в папку Onedrive? Не вижу документации о том, как это можно сделать через приложение logi c.

Azure Функция:

using System;
using System.IO;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Azure.WebJobs;
using Microsoft.Azure.WebJobs.Extensions.Http;
using Microsoft.AspNetCore.Http;
using Microsoft.Extensions.Logging;
using Newtonsoft.Json;
using System.Net.Http.Headers;
using System.Text;
using System.Net.Http;
using System.Web;

namespace TranscriptVtt
{
    public static class Function1
    {
        [FunctionName("Function1")]
        public static async Task<IActionResult> Run(
            [HttpTrigger(AuthorizationLevel.Function, "get", "post", Route = null)] HttpRequest req,
            ILogger log)
        {
            var client = new HttpClient();
            var queryString = HttpUtility.ParseQueryString(string.Empty);

            // Request headers
            client.DefaultRequestHeaders.Add("x-ms-client-request-id", "");
            client.DefaultRequestHeaders.Add("Ocp-Apim-Subscription-Key", "{subscription key}");

            // Request parameters
            queryString["indexId"] = "{string}";
            queryString["format"] = "Vtt";
            queryString["language"] = "{string}";
            queryString["accessToken"] = "{string}";
            var uri = "https://api.videoindexer.ai/{location}/Accounts/{accountId}/Videos/{videoId}/Captions?" + queryString;
            var response = await client.GetAsync(uri);
            return new OkObjectResult("VTT Processed");
        }
    }
}

Ответы [ 2 ]

1 голос
/ 25 марта 2020

Я сделал небольшую демонстрацию, выполнив следующее (и это работает):

  • LogicApp # 1 для загрузки видео: запускает одну папку OneDrive «Input» и загружает видео в Video Indexer для индексации
  • LogicApp # 2 для сбора результатов: триггер http, который будет вызываться при индексировании, затем получить подписи и создать файл в папке «Вывод» OneDrive.

Трюк тот факт, что, как описано в Upload Video операции Video Indexer (см. здесь ), вы можете добавить обратный вызов:

Upload video documentation

Как видите, этот обратный вызов будет иметь идентификатор видео, добавленного в строку запроса.

Так что в вашем LogicApp # 2 используйте это id для действия Get Video Captions Video Indexer:

Implementation detail 1

Выражение для получения идентификатора: triggerOutputs()['queries']['id'].

Тогда вам просто нужно скопировать в свой вывод:

Implementation detail 2

Я использовал именование на основе идентификатора видео: concat(triggerOutputs()['queries']['id'],'-Captions.vtt')

И это работает: Result

Чтобы получить лучшую реализацию, вы должны добавить проверку, чтобы отфильтровать обратные вызовы из-за обнаружений лиц, упомянутых выше. Это можно сделать, отфильтровав значение строки запроса «Состояние».

Вот код моего LogicApp # 2 (с несколькими скрытыми полями):

{
    "definition": {
        "$schema": "https://schema.management.azure.com/providers/Microsoft.Logic/schemas/2016-06-01/workflowdefinition.json#",
        "actions": {
            "Create_file": {
                "inputs": {
                    "body": "@body('Get_Video_Captions')",
                    "host": {
                        "connection": {
                            "name": "@parameters('$connections')['onedrive']['connectionId']"
                        }
                    },
                    "method": "post",
                    "path": "/datasets/default/files",
                    "queries": {
                        "folderPath": "/LogicAppsDemo/VideoIndexing/Output",
                        "name": "@{concat(triggerOutputs()['queries']['id'],'-Captions.vtt')}"
                    }
                },
                "runAfter": {
                    "Get_Video_Captions": [
                        "Succeeded"
                    ]
                },
                "runtimeConfiguration": {
                    "contentTransfer": {
                        "transferMode": "Chunked"
                    }
                },
                "type": "ApiConnection"
            },
            "Get_Account_Access_Token": {
                "inputs": {
                    "host": {
                        "connection": {
                            "name": "@parameters('$connections')['videoindexer-v2']['connectionId']"
                        }
                    },
                    "method": "get",
                    "path": "/auth/@{encodeURIComponent('##VI-REGION##')}/Accounts/@{encodeURIComponent('##VI-ACCOUNT##')}/AccessToken",
                    "queries": {
                        "allowEdit": false
                    }
                },
                "runAfter": {},
                "type": "ApiConnection"
            },
            "Get_Video_Captions": {
                "inputs": {
                    "host": {
                        "connection": {
                            "name": "@parameters('$connections')['videoindexer-v2']['connectionId']"
                        }
                    },
                    "method": "get",
                    "path": "/@{encodeURIComponent('##VI-REGION##')}/Accounts/@{encodeURIComponent('##VI-ACCOUNT##')}/Videos/@{encodeURIComponent(triggerOutputs()['queries']['id'])}/Captions",
                    "queries": {
                        "accessToken": "@body('Get_Account_Access_Token')",
                        "format": "vtt",
                        "language": "English"
                    }
                },
                "runAfter": {
                    "Get_Account_Access_Token": [
                        "Succeeded"
                    ]
                },
                "type": "ApiConnection"
            }
        },
        "contentVersion": "1.0.0.0",
        "outputs": {},
        "parameters": {
            "$connections": {
                "defaultValue": {},
                "type": "Object"
            }
        },
        "triggers": {
            "manual": {
                "inputs": {
                    "method": "POST",
                    "schema": {}
                },
                "kind": "Http",
                "type": "Request"
            }
        }
    },
    "parameters": {
        "$connections": {

            "value": {
                "onedrive": { ... },
                "videoindexer-v2": { ... }
            }
        }
    }
}

Кстати, Ваш вариант использования почти описан в сообщении в блоге от Microsoft (здесь они получают индекс, а не подписи): https://azure.microsoft.com/en-us/blog/logic-apps-flow-connectors-will-make-automating-video-indexer-simpler-than-ever/

0 голосов
/ 23 марта 2020

Непосредственно с помощью Logi c Разъем приложения Я не думаю, что это возможно, но вы можете получить его напрямую, используя REST API. Выполните запрос и в соответствии с ответом добавьте новую задачу, которая будет соединителем onedrive:

https://docs.microsoft.com/en-us/azure/connectors/connectors-native-http

https://docs.microsoft.com/en-us/connectors/onedrive/

API REST:

curl -v -X GET "https://api.videoindexer.ai/{location}/Accounts/{accountId}/Videos/{videoId}/Captions?indexId={string}&format=Vtt&language={string}&accessToken={string}"
-H "x-ms-client-request-id: "
-H "Ocp-Apim-Subscription-Key: {subscription key}"

--data-ascii "{body}" 

РЕДАКТИРОВАТЬ: эквивалентно int c#. Вам нужно будет использовать его на веб-сервере (Azure Функции будут великолепны):

using System;
using System.Net.Http.Headers;
using System.Text;
using System.Net.Http;
using System.Web;

namespace CSHttpClientSample
{
    static class Program
    {
        static void Main()
        {
            MakeRequest();
            Console.WriteLine("Hit ENTER to exit...");
            Console.ReadLine();
        }

        static async void MakeRequest()
        {
            var client = new HttpClient();
            var queryString = HttpUtility.ParseQueryString(string.Empty);

            // Request headers
            client.DefaultRequestHeaders.Add("x-ms-client-request-id", "");
            client.DefaultRequestHeaders.Add("Ocp-Apim-Subscription-Key", "{subscription key}");

            // Request parameters
            queryString["indexId"] = "{string}";
            queryString["format"] = "Vtt";
            queryString["language"] = "{string}";
            queryString["accessToken"] = "{string}";
            var uri = "https://api.videoindexer.ai/{location}/Accounts/{accountId}/Videos/{videoId}/Captions?" + queryString;

            var response = await client.GetAsync(uri);
        }
    }
}   

Вам необходимо передать ответ на задачу Onedrive в своем рабочем процессе.

https://api-portal.videoindexer.ai/docs/services/operations/operations/Get-video-captions

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...