我已经在Rundeck定义了一个Webhook来运行特定作业。此作业定义了3个选项:$ {option.VMName},$ {option.CPU}和$ {option.Memory}。作业本身被定义为本地powershell脚本,并执行为:powershell $ {scriptfile} $ {option.VMName} $ {option.CPU} $ {option.Memory}。这已经过测试并且可以正常工作。
我现在想调用webhook POST URL,以便在定义了这些选项的情况下(通过Web仪表板,使用PowerShell)远程触发作业。我尝试将选项添加到URL的末尾,但未成功:
http://mywebhookuri#myjobname?opt.VMName=$VMName&opt.CPU=$CPU&opt.Memory=$Memory
http://mywebhookuri#myjobname?VMName=$VMName&CPU=$CPU&Memory=$Memory
以下PowerShell代码用于调用Webhook:
$WebHookURI = "http://mywebhookuri#myjobname"
$header = @{}
$header.add("Content-Type","text/plain")
$body = @{} | ConvertTo-Json
$result = Invoke-RestMethod -Method Post -Uri $WebHookURI -Body $body -Headers $header
webhook插件和运行作业用法的文档状态为“该插件收到的JSON可用于提供选项,节点过滤器和运行方式用户”,但未显示明确的例子之一。
如何将这些选项成功传递到Webhook URL?
答案 0 :(得分:2)
为MegaDrive68k接受的答案添加一些细节(因为这本质上是两个问题):
我在Rundeck Webhook定义的“选项”字段中添加了以下内容:
-VMName ${data.field1} -CPU ${data.field2} -Memory ${data.field3}
然后对PowerShell代码进行了如下修改:
$WebHookURI = 'http://mywebhookuri#myjobname'
$header = New-Object "System.Collections.Generic.Dictionary[[String],[String]]"
$header.add("Content-Type", "application/json")
$body = "{`n `"field1`" : `"$VMName`",`n `"field2`" : `"$CPU`",`n `"field3`" : `"$Memory`"`n}"
$result = Invoke-RestMethod -Method 'POST' -Uri $WebHookURI -Body $body -Headers $header
通过这些更改,我能够使用选项成功调用Rundeck Webhook。
答案 1 :(得分:1)
在documentation之后,您需要以this的方式定义选项,然后调用传递JSON数据的方式,我做了一个示例,但使用了cURL:
curl -H "Content-Type: application/json" -X POST -d '{"field1":"hello world"}' http://yourhost:4440/api/34/webhook/3moY0Ru1zxl5gM0tpVlecJ5BN1LPyhsx#New_Hook
这是该职位定义示例:
<joblist>
<job>
<context>
<options preserveOrder='true'>
<option name='opt1' />
</options>
</context>
<defaultTab>nodes</defaultTab>
<description></description>
<executionEnabled>true</executionEnabled>
<id>e97efb53-99a6-4e5a-80b7-a1b055866f43</id>
<loglevel>INFO</loglevel>
<name>HelloWorld</name>
<nodeFilterEditable>false</nodeFilterEditable>
<scheduleEnabled>true</scheduleEnabled>
<sequence keepgoing='false' strategy='node-first'>
<command>
<exec>echo ${option.opt1}</exec>
</command>
</sequence>
<uuid>e97efb53-99a6-4e5a-80b7-a1b055866f43</uuid>
</job>
</joblist>