Actionsflow trigger google_form
npm install @actionsflow/trigger-google_form@actionsflow/trigger-google_formThis is a google_form trigger of Actionsflow. Any new response in Google Form will trigger the trigger.
> This is an official trigger, you don't need to install it manually.
You should Create a custom script at google form More->Script Editor
!Create a custom script at google form
1. paste the following script to the editor, change the WEBHOOK_URL to yours.
``javascript
var WEBHOOK_URL =
"https://webhook.actionsflow.workers.dev/
function onFormSubmit(e) {
var response = e.response;
var source = e.source;
var itemResponses = response.getItemResponses();
var definition = {
title: source.getTitle(),
fields: [],
};
const formItems = source.getItems();
for (var i = 0; i < formItems.length; i++) {
const formItem = formItems[i];
definition.fields.push({
id: formItem.getId(),
title: formItem.getTitle(),
type: formItem.getType(),
index: formItem.getIndex(),
});
}
var answers = [];
for (var j = 0; j < itemResponses.length; j++) {
var itemResponse = itemResponses[j];
const formItem = itemResponse.getItem();
answers.push({
response: itemResponse.getResponse(),
field: {
id: formItem.getId(),
title: formItem.getTitle(),
type: formItem.getType(),
index: formItem.getIndex(),
},
});
}
var webhookPayload = {
event_id: response.getId(),
event_type: "form_response",
form_response: {
form_id: source.getId(),
email: response.getRespondentEmail(),
submitted_at: response.getTimestamp().toISOString(),
definition: definition,
answers: answers,
},
};
var options = {
method: "post",
contentType: "application/json",
payload: JSON.stringify(webhookPayload),
};
UrlFetchApp.fetch(WEBHOOK_URL, options);
}
`
1. Add a trigger by selecting Current project's triggers in the Edit menu, and creating a new trigger using the settings given below. Save it.
`yaml`
on:
google_form:
There is nothing can be specified. You can use General Config for Actionsflow Trigger for more customization.
This trigger's outputs will be the body of the aws sns message body, you can see it here
An outputs example:
`json`
{
"event_id": "2_ABaOnud0S_zjpIn9oGqBpmY65p_NsuiBSqvdwPlapEig0GM4EPdeStVqalzlAb3AEovoWgA",
"event_type": "form_response",
"form_response": {
"form_id": "118EoaS7eK2qvWv8tQy3xLKa-MGgRAizQvO5PKVArWG4",
"email": "",
"submitted_at": "2020-09-27T07:54:30.661Z",
"definition": {
"title": "test formt",
"fields": [
{
"id": 440714388,
"title": "question 1",
"type": "MULTIPLE_CHOICE",
"index": 0
},
{
"id": 886865551,
"title": "name",
"type": "TEXT",
"index": 1
}
]
},
"answers": [
{
"response": "Option 2",
"field": {
"id": 440714388,
"title": "question 1",
"type": "MULTIPLE_CHOICE",
"index": 0
}
},
{
"response": "test",
"field": {
"id": 886865551,
"title": "name",
"type": "TEXT",
"index": 1
}
}
]
},
"answers_map": {
"question 1": "Option 2",
"name": "test"
}
}
You can use the outputs like this:
`yaml``
on:
google_form:
jobs:
print:
name: Print
runs-on: ubuntu-latest
steps:
- name: Print Outputs
env:
answer: ${{ toJSON(on.google_form.outputs.answers_map) }}
run: |
echo answer: $answer