services | platforms | author |
---|---|---|
media-services,functions |
dotnet |
shigeyf |
This project contains examples of using Azure Functions with Azure Media Services. The project includes several folders of sample Azure Functions for use with Azure Media Services that show workflows related to ingesting content directly from blob storage, encoding, and writing content back to blob storage.
Create a Media Services account in your subscription if don't have it already.
Create a Service Principal and save the password. It will be needed in step 4. To do so, go to the API tab in the account (follow this article)
To enable streaming, go to the Azure portal, select the Azure Media Services account which has been created, and start the default streaming endpoint.
4.1. Fork this repo to your own repo
4.2. Deploy Azure Functions and select the "201-logic-app-workflow-1" Project (IMPORTANT!)
Follow the guidelines in the git tutorial for details on how to fork the project and use Git properly with this project.
Note : if you never provided your GitHub account in the Azure portal before, the continous integration probably will probably fail and you won't see the functions. In that case, you need to setup it manually. Go to your azure functions deployment / Functions app settings / Configure continous integration. Select GitHub as a source and configure it to use your fork.
- Please consider Consumption Plan or App Service Plan if you will deploy manually
- Consumption Plan – Timeout of function will be 5 mins
- App Service Plan (Dedicated Plan) – There is no timeout (if AlwaysOn is enabled)
- If a deployment target resource group already contains an App Service Plan (Dedicated Plan), Azure Functions app will be contained in that App Service Plan (Dedicated Plan)
4.3. Check App Settings of Azure Functions @ Azure Portal
-
Plaese makes sure if the following environment Key/Value pairs in the "App Settings" of your Azure Functions are correctly configured
Key Value Description Project Set the project name to "201-logic-app-workflow-1". This will bind the continous integration to this functions folder. AMSAADTenantDomain Your AMS Azure AD Tenant Domain AMSRESTAPIEndpoint Your AMS REST API Endpoint AMSClientId Your AMS Service Principal App Id AMSClientSecret Your AMS Service Principal App Secret MediaServicesStorageAccountName Your Media Services Storage Account Name MediaServicesStorageAccountKey Your Media Services Storage Account Key
4.4. Check if Azure Functions are deployed from your Github repo into your Azure Function App @ Azure Portal
- If not, please do "Sync" manually from "Configure continusous integration" in Function app settings
- This deployment script will create a Logic App which is using the Azure Functions deployed above
- Please refer the next section if you will deploy manually
- Upload a source asset to a source container of your Azure Blob Storage account (specified with SourceStorageAccountName parameter in the deployment parameters)
- Create IngestAssetConfig JSON file or use a sample file.
- Run workflow
- Upload IngestAssetConfig JSON file to /inputs folder of your Azure Blob Storage account (specified with SourceStorageAccountName parameter in the deployment parameters)
- Workflow will be automatically triggered in cevery onfigured duration (default - 1 minutes)
Some sample IngestAssetConfig JSON files are contained in sample-configs folder.
- Example #1 - Single bitrate media file with encoding to a multi-bitrate asset
{
"IngestSource": {
"SourceContainerName": "bigbuckbunny-1080p24p"
},
"IngestAsset": {
"AssetName": "BigBuckBunny_1080p24p",
"AssetFiles": [
{
"FileName": "big_buck_bunny_1080p_h264.mov",
"IsPrimary": true
}
],
"AssetCreationOption": "None"
},
"IngestAssetEncoding": {
"Encoding": true,
"Encoder": "MES",
"EncodingConfiguration": "H264 Multiple Bitrate 1080p"
}
}
- Example #2 – Smooth Asset
{
"IngestSource": {
"SourceContainerName": "bigbuckbunny-720p-smooth"
},
"IngestAsset": {
"AssetName": "BigBuckBunny_720_Smooth",
"AssetFiles": [
{
"FileName": "BigBuckBunny.ism",
"IsPrimary": true
},
{ "FileName": "BigBuckBunny.ismc“ },
{ "FileName": "BigBuckBunny_230.ismv” },
{ "FileName": "BigBuckBunny_331.ismv“ },
{ "FileName": "BigBuckBunny_477.ismv“ },
{ "FileName": "BigBuckBunny_688.ismv“ },
{ "FileName": "BigBuckBunny_991.ismv“ },
{ "FileName": "BigBuckBunny_1427.ismv“ },
{ "FileName": "BigBuckBunny_2056.ismv“ },
{ "FileName": "BigBuckBunny_2962.ismv“ },
{ "FileName": "BigBuckBunny_Thumb.jpg“ }
],
"AssetCreationOption": "None"
},
"IngestAssetEncoding": {
"Encoding": "false"
}
}
- Example #3 – PlayReady Protected Smooth Asset
{
"IngestSource": {
"SourceContainerName": "superspeedway-720p-smooth"
},
"IngestAsset": {
"AssetName": "SuperSpeedway_720_Smooth",
"AssetFiles": [
{
"FileName": "SuperSpeedway_720.ism",
"IsPrimary": true
},
{ "FileName": "SuperSpeedway_720.ismc“ },
{ "FileName": "SuperSpeedway_720_230.ismv” },
{ "FileName": "SuperSpeedway_720_331.ismv“ },
{ "FileName": "SuperSpeedway_720_477.ismv“ },
{ "FileName": "SuperSpeedway_720_688.ismv“ },
{ "FileName": "SuperSpeedway_720_991.ismv“ },
{ "FileName": "SuperSpeedway_720_1427.ismv“ },
{ "FileName": "SuperSpeedway_720_2056.ismv“ },
{ "FileName": "SuperSpeedway_720_2962.ismv“ },
{ "FileName": "SuperSpeedway_720_Thumb.jpg“ }
],
"AssetCreationOption": "CommonEncryptionProtected"
},
"IngestAssetEncoding": {
"Encoding": "false"
} ,
"IngestAssetPublish": {
"StartDate": "2018-01-01",
"EndDate": "2018-12-31"
}
}
This media workflow sample functions are implemented as a set of Azure Functions. These functions are sequentially arranged and called in the Azure Logic Apps as a workflow. Many pre-defined APIs for Logic Apps which are already provided from Microsoft and 3rd party partners can be combined for your workflow.
Here is an example of media workflow with Azure Logic Apps.
Use "OneDrive - When a file is created" action.
- Specify a watch folder to where IngestAssetConfig JSON file is uploaded
- Specify a frequecy to watch the specified watch folder
- Note that when multiple JSON files will be uploaded then multiple workflows will be triggered
Use Azure Function - WF-1-CreateAsset-ImportAssetFromIngestAssetConfig
- Specify "OneDrive – File content" as "FileContent" input
- Specify "OneDrive – File name" as "FileName" input
- Specify Azure Blob Storage Account Name for your source assets as "SourceStorageAccountName" input
- Specify Azure Blob Storage Account Key as "SourceStorageAccountKey" input
Use "Until" loop with WF-1-CreateAsset-MonitorCopyBlob
- Wait until when WF-1-CreateAsset-MonitorCopyBlob - "CopyStatus" is equal to "2"
- Specify "WF-1-CreateAsset-ImportAssetFromIngestAssetConfig – DestinationContainer" as "DestinationContainer" input
Use Azure Function WF-1-CreateAsset-UpdateFinal
- Specify "WF-1-CreateAsset-ImportAssetFromIngestAssetConfig – AssetId" as "AssetId" input
- Specify "OneDrive – File content" as "IngestAssetConfigJson" input
Use "Condition"
- Use "WF-1-CreateAsset-UpdateFinal – MediaProcessRequired" as "Condition" parameter
- IF "MediaProcessRequired" is greater than "0", goto Step 6
- IF NO, goto Step 7
Use WF-2-ProcessAsset-SubmitEncodingJob
- Specify "WF-1-CreateAsset-UpdateFinal – AssetId" as "AssetId" input
- Specify "OneDrive – File content" as "IngestAssetConfigJson" input
Use "Until" loop with WF-2-ProcessAsset-MonitorJob
- Wait until when WF-2-ProcessAsset-SubmitEncodingJob - "JobState" is greater than "2"
- Specify "WF-2-ProcessAsset-SubmitEncodingJob – JobId" as "JobId"
Use "Condition"
- Use "WF-2-ProcessAsset-MonitorJob – JobState" as "Condition" parameter
- IF "JobState" is equal to "3", goto Step 6-4
Use WF-5-PublishAsset
- Specify "WF-2-ProcessAsset-SubmitEncodingJob – OutputAssetId" as "OutputAssetId" input
- Specify "OneDrive – File content" as "IngestAssetConfigJson" input
Use "Outlook.com - Send an email" to send an email
Use WF-5-PublishAsset
- Specify "WF-1-CreateAsset-ImportAssetFromIngestAssetConfig – AssetId" as "AssetId" input
- Specify "OneDrive – File content" as "IngestAssetConfigJson" input
Use "Outlook.com - Send an email" to send an email
This workflow implementation provides a simple workflow for media file(s) ingesting, encoding, and publishing as VOD assets. Current implemented functions (@2017/01/31) is as follows:
- WF-1 – Ingest Asset to AMS accounts with IngestAssetConfig JSON configuration
- WF-1-CreateAsset-ImportAssetFromIngestAssetConfig – Create AMS asset and copy source assets from a source blob container to a destination blob container asynchrounously
- WF-1-CreateAsset-MonitorCopyBlob – Monitor async blob copy until finishing
- WF-1-CreateAsset-UpdateFinal – Add asset files to AMS asset
- WF-2 – Encode Asset
- WF-2-ProcessAsset-SubmitEncodingJob – Submit AMS encoding job
- WF-2-ProcessAsset-MonitorJob – Monitor encoding job until finishing
- WF-5 – Publish Asset
- WF-5-PublishAsset – Publish AMS asset
This workflow requires an input JSON data (IngestAssetConfig) for ingesting media asset as a workflow configuration information:
IngestAssetConfig (v1) containes:
- IngestSource
- Asset source location
- IngestAsset
- Asset & Asset files info
- IngestAssetEncoding - Asset Encoding options
- IngestAssetPublish
- Asset Publishing options
{
"IngestSource": {
"SourceContainerName": "<source_container_name>"
},
"IngestAsset": {
"AssetName": "<asset_name>",
"AssetFiles": [
{
"FileName": "<asset_file_1>",
"IsPrimary": true
},
{
"FileName": "<asset_file_2>"
}
],
"AssetCreationOption": "<option>"
},
"IngestAssetEncoding": {
"Encoding": true,
"Encoder": "<encoder_name>",
"EncodingConfiguration": "<encoding_configuration>"
},
"IngestAssetPublish": {
"StartDate": "<YYYY-MM-DD>",
"EndDate": "<YYYY-MM-DD>"
}
}
- SourceContainerName [REQUIRED] – Azure Blob Storage container name for source asset
- AssetName [REQUIRED] – Asset friendly name to be created
- AssetFiles [REQUIRED] – Files registered to Asset as AssetFiles
- Filename [REQUIRED] – File name of Asset Files
- IsPrimary [OPTIONAL] – Primary flag of Asset Files in Asset (default = false)
- AssetCreationOption [OPTIONAL] – Asset Option for Asset
- Current supported options in this sample workflow implementation
- "None" (default)
- "CommonEncryptionProtected"
- "EnvelopeEncryptionProtected"
- Current supported options in this sample workflow implementation
- Encoding [OPTIONAL] – Process encoding job for Asset (default = false)
- Encoder [OPTIONAL] – Encoder name to be used for encoding job; the following encoder processor can be specified:
- "MES" : Media Encoder Standard
- "MEPW" : Media Encoder Premium workflow
- EncodingConfiguration [OPTIONAL] – Encoder parameter string (or pre-defined preset name)
- StartDate [OPTIONAL] – "YYYY-MM-DD" format date starting to publish (a future date will be required)
- EndDate [REQUIRED] – "YYYY-MM-DD" format date finishing to publish (a future date will be required)
- Azure Function Template - C# Generic Webhook
- Input – JSON format data
- FileName : IngestAssetConfig filename for target asset
- FileContent : IngestAssetConfig JSON for target asset
- SourceStorageAccountName : Azure Blob Storage Account Name for source assets
- SourceStorageAccountKey : Azure Blob Storage Account Key for source assets
- Output – JSON format data
- AssetId : Created AMS Asset Id (e.g. nb:cid:UUID:2f7e6884-2637-42f8-a336-97dc04942e69)
- SourceContainer : Azure Blob Storage container name of target asset
- DestinationContainer : Azure Blob Storage container name of created AMS asset
- Function Details
- Create an AMS Asset for target asset (and blob container on Azure Storage account managed by AMS) – based on IngetAsset data of IngestAssetConfig JSON
- Copy Azure Storage blobs from source container to target container – based on IngetSource data and IngetAsset data of IngestAssetConfig JSON
- Azure Function Template - C# Generic Webhook
- Input – JSON format data
- DestinationContainer : Azure Blob Storage container name of created AMS asset
- Delay (Optional) : Delay to return the result (default 15,000 ms)
- Output – JSON format data
- CopyStatus : Status of Azure Storage blob copy operations
- Function Details
- Check blob copy operations of each blob in target container
- Return CopyStatus
- Return CopyStatus.Success if all blob copy operations has been successfully done
- Return CopyStatus.Pending if one of blob copy operations is still doing
- Caution
- Azure Functions with Consumption plan has 5 mins timeout. You must not pass 300,000 ms or more value as “Delay” input
- Azure Function Template - C# Generic Webhook
- Input – JSON format data
- AssetId : Created AMS Asset Id
- IngestAssetConfigJson : IngestAssetConfig JSON for target asset
- Output – JSON format data
- MediaProcessRequired : Media Process must be done before publishing
- Function Details
- Add AMS AssetFile(s) (associated blob(s)) to target AMS asset (indicated AssetId) in AMS account (after blob copy operations has been done) – based on IngetAsset data of IngestAssetConfig JSON
- Return MediaProcessRequired flag
- Return 0 if no media processing (including encoding) will not be required before publishing
- Return 1 if media processing (including encoding) will be required before publishing
- Azure Function Template - C# Generic Webhook
- Input – JSON format data
- AssetId : Created AMS Asset Id
- IngestAssetConfigJson : IngestAssetConfig JSON for target asset
- Output – JSON format data
- JobId : AMS Job Id for encoding
- OutputAssetId : AMS Asset Id of encoding output asset
- Function Details
- Submit AMS encoding job for target AMS asset – based on IngetAssetEncoding data of IngestAssetConfig JSON
- Caution
- Azure Functions with Consumption plan has 5 mins timeout. You must not pass 300,000 ms or more value as Delay input
-
Azure Function Template - C# Generic Webhook
-
Input – JSON format data
- JobId : Created AMS Job Id
- Delay (Optional) : Delay to return the result (default 15,000 ms)
-
Output – JSON format data
- JobId : Created AMS Job Id
- JobState : Job State of AMS Job Id’s job
-
IJob.State is as follows:
Job State State Value Queued 0 Scheduled 1 Processing 2 Finished 3 Error 4 Canceled 5 Canceling 6
-
-
Function Details
- Check and Return IJob.State of AMS Job
-
Caution
- Azure Functions with Consumption plan has 5 mins timeout. You must not pass 300,000 ms or more value as Delay input
- Azure Function Template - C# Generic Webhook
- Input – JSON format data
- AssetId : AMS Asset Id for publishing (Imported or Encoded AMS asset)
- IngestAssetConfigJson : IngestAssetConfig JSON for target asset
- Output – JSON format data
- StreamingUrl : Published URL for streaming target asset
- Function Details
- Create streaming locator for target asset with specified Start/End date of publishing – based on IngetAssetPublish data of IngestAssetConfig JSON