0

这是从 Azure 门户导出后 .graphrunbook 的(修剪后的)内容。

{ 
    "SchemaVersion" : "1.2", 
    "RunbookDefinition" : "AAA....AAA=" 
}

Runbook 定义可能是基于 XML 或 XAML 的,虽然这看起来像 base64 编码的文本,但将其解码会导致大部分仍然编码/难以辨认。

背景:我正在开发与 ARM 配合使用的 Sync-VsoGitRunbook 的改进版本,不需要任意文件夹层次结构(通过自动确定依赖项),并且还可以部署图形运行手册 - 为什么不呢!这几乎是 Native & Workflow 的全部内容,这些只是要实现的最后一部分。

我目前没有使用任何图形运行手册,但如果/一旦我们这样做,我希望它们符合架构。我还计划在打包/清理代码后开源代码。

4

2 回答 2

2

使用 Azure 自动化图形创作 SDK 是检查和修改 .graphrunbok 文件内容的唯一受支持方式。例如,这样的脚本将为您提供 Runbook 使用的命令列表:

param(
    [Parameter(Mandatory = $true)]
    $RunbookPath,

    $GraphicalAuthoringSDKPath = 'C:\Program Files (x86)\Microsoft Azure Automation Graphical Authoring SDK'
)

function Get-RunbookActivities($Runbook, $ActivityType)
{
    $Runbook.Activities | %{ $_ -as $ActivityType } | ?{ $_ }
}

Add-Type -Path $GraphicalAuthoringSDKPath\Orchestrator.GraphRunbook.Model.dll

$SerializedRunbook = Get-Content $RunbookPath

$Runbook = [Orchestrator.GraphRunbook.Model.Serialization.RunbookSerializer]::Deserialize($SerializedRunbook)

@{
    'Invoked runbooks' = Get-RunbookActivities $Runbook Orchestrator.GraphRunbook.Model.InvokeRunbookActivity |
                            %{ $_.RunbookActivityType.CommandName }

    'Commands' = Get-RunbookActivities $Runbook Orchestrator.GraphRunbook.Model.CommandActivity |
                            %{ "$($_.CommandType.ModuleName)/$($_.CommandType.CommandName)" }

    'Code activity content' = Get-RunbookActivities $Runbook Orchestrator.GraphRunbook.Model.WorkflowScriptActivity |
                            %{ $_.Process }
}

此脚本提供的数据不完整:它仅列出了在运行手册图上显示为框的活动。但是,还有其他方法可以将 PS 代码引入 Runbook(如链接条件、重试条件、活动参数中的 PS 表达式等)。如果您也对这些数据感兴趣,可以改进脚本:存储的所有数据可以使用此 API 检索图形运行手册中的内容。

请从 Chris 提供的链接下载最新版本的 SDK。最新版本包含一些重要的修复。

于 2016-03-16T06:17:51.840 回答
1

使用 Azure 自动化图形创作 SDK。

https://azure.microsoft.com/en-us/updates/public-preview-automation-graphical-authoring-sdk/

于 2016-03-03T16:55:25.273 回答