API REST Cloud Functions: создание нового действия из zip-файла
Я пытаюсь создать функцию nodejs из zip-файла и через REST API, используя следующий curl:
curl --request PUT --url 'https://my:credentials@openwhisk.eu-gb.bluemix.net/api/v1/namespaces/mynamespace/actions/my_action_name?overwrite=true' --header 'accept: application/json' --header 'content-type: application/json' --data '{"annotations":[{"key":"exec","value":"nodejs:10"},{"key":"web-export","value":true}],"exec":{"kind":"nodejs:10","init":"./action.zip"},"parameters":[{"key":"message","value":"Hello World"}]}'
В результате я получаю ошибку:
"error":"The request content was malformed:\n'code' must be a string or attachment object defined in 'exec' for 'nodejs:10' actions"
Можно ли получить пример того, как создать новое действие из zip-файла и через REST API? Спасибо.
2 ответа
Вы должны кодировать base64.zip-файл, а затем передать его как code
параметр. Я написал сценарий оболочки (bash) для кодирования, а также создал действие под названием "действие". Сохранить скрипт как create.sh
и выполнить скрипт ./create.sh
#!/bin/sh
ACTION=action
ZIP=$ACTION.zip
base64 $ZIP | echo "\"$(cat)\"" | jq "{namespace:\"_\", name:\"$ACTION\", exec:{kind:\"nodejs:10\", code:., binary:true, main:\"main\"}}" | curl -X PUT -H "Content-Type:application/json" -d @- https://USERNAME:PASSWORD@openwhisk.ng.bluemix.net/api/v1/namespaces/_/actions/$ACTION?overwrite=true
Полный код
код app.js или index.js
function myAction(args) {
const leftPad = require("left-pad")
const lines = args.lines || [];
return { padded: lines.map(l => leftPad(l, 30, ".")) }
}
exports.main = myAction;
package.json
{
"name": "node",
"version": "1.0.0",
"description": "",
"main": "app.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
"license": "ISC",
"dependencies": {
"left-pad" : "1.1.3"
}
}
Бежать npm install
и заархивировать файл zip -r action.zip *
,
Чтобы проверить действие
ibmcloud fn action invoke --result action --param lines "[\"and now\", \"for something completely\", \"different\" ]"
API REST для создания или обновления действий Cloud Functions документирован в документации по API IBM Cloud Functions. Хороший способ узнать точный синтаксис curl / request - использовать CLI IBM Cloud Functions в подробном режиме (-v
). CLI - это просто оболочка для REST API, и в подробном режиме выводятся все детали REST.
Вот соответствующая часть для того, что может быть напечатано:
Req Body
Body exceeds 1000 bytes and will be truncated
{"namespace":"_","name":"mytest/myaction","exec":{"kind":"nodejs:8","code":"UEsDBBQAAAAIAHJPhEzjlkxc8wYAAH8VAAALABwAX19tYWluX18ucHlVVAkAA+iFxFrohcRadXgLAAEE9AEAAAT0AQAAxVhtb9s2EP6uX8HRCCLBipb002DA69YkbYo17dZ0GwbDMGSKlrXJokfSToNh/313R+rNL2labJiK1iJ578/x7tTBgJ7A/QzYq8IuN3NmdbpYFIIZm9rC2EKYmiIYsB+1ynW6Ykqz1y9u2WWpNhl7uamELVTFrGJClaUUtha2LeQ9S6uMiVJVspYNgnDPWKVhb5lalqU2ZUXFUqZlmaKwtKTNeWpkzKp0JcsHdj
Вам нужно будет установить binary
поле к истине и включать содержимое почтового индекса как code
, Документы curl предлагают использовать @filename для ссылки на ваш zip-файл:
Если вы хотите, чтобы содержимое читалось из файла, используйте <@filename> в качестве содержимого.