Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@actionsflow/trigger-google_form

Package Overview
Dependencies
Maintainers
1
Versions
52
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@actionsflow/trigger-google_form

Actionsflow trigger google_form

  • 1.10.0
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
77
increased by1440%
Maintainers
1
Weekly downloads
 
Created
Source

@actionsflow/trigger-google_form

This 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.

View trigger on Github

Prerequisites

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.

    var WEBHOOK_URL =
      "https://webhook.actionsflow.workers.dev/<owner>/<repo>/<workflow-file-name>/google_form?__token=<your-github-personal-token>";
    
    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);
    }
    
  2. 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.

Add a trigger

Add a trigger

Usage

on:
  google_form:

Options

There is nothing can be specified. You can use General Config for Actionsflow Trigger for more customization.

Outputs

This trigger's outputs will be the body of the aws sns message body, you can see it here

An outputs example:

{
  "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:

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

Keywords

FAQs

Package last updated on 30 Nov 2021

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc