Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

To be able to authorise to Google using Google Auth, and perform actions related to Google Calendar, Google Drive, and Google Sheets, such as adding Google Calendar events, uploading files to Google Drive, retrieving file lists, and performing CRUD operations on Google Sheets.

Get Started

Prerequisites

Google Cloud Console

1. Google Cloud Console Setup

...

Figure 5: Google Cloud Console Add Test User

API Domain/IP Whitelist

To ensure the successful operation of this plugin, it is essential to whitelist the domains or IP addresses of the host. Typically, this involves adding the IP address or domain name of your Joget application server to the whitelist. To access this section of Joget, go to Settings → General Settings and scroll down till you see API Domain/IP Whitelist section.

Image Added

Figure 6: API Domain/IP Whitelist


NameDescription
API Domain Whitelist (Separated by ';')

Domain whitelist to allow API calls to Joget Workflow. Separated by semicolon.

Info
titleExample

"localhost;www.joget.org;dev.joget.org”, or "*" to allow from everywhere.

Warning

In a production environment, do not use "*".

Doing so will allow anyone to call all JSON APIs from the Joget server.

API IP Whitelist (Separated by ';')

IP address whitelist to allow API calls to Joget. Separated by semicolon.

Info
titleExample

"localhost; 192.168.101.10; www.joget.org;dev.joget.org ”, or "*" to allow from everywhere.

Warning

In a production environment, do not use "*".

Doing so will allow anyone to call all JSON APIs from the Joget server.



Steps

Where to get the plugin

...

1. You can choose to import the demo app. For demo app, go to Joget Home or All Apps and click on Import App to import the downloaded demo app (refer to another KB - Import Joget App for more details). Please add your Google Client ID and Google Client Secret to the App Variable to allow the plugin to run without any issues.

Figure 67: Add Google Client ID and Google Client Secret

...

1. Create a form and drag the Google Auth element into the form. Fill in the plugin configurations by referring to Google Auth Properties.

Figure 78: Google Auth Create Form

...

2. In the UI, you can see a button which is the Google Auth element. Once you click on it, a popup will appear to authorise your Google identity.

Figure 89: Google Auth Authentication

...

3. After successful authentication, a message will appear which shows that the popup window will close automatically in 10 seconds. You can check that the bearerToken in the app variable has been updated with the latest value. Now you will be able to communicate to the Google services such as Google Calendar, Google Drive and Google Sheets.

Figure 910: Google Auth Authentication Successful

...

1. Create a form with two Text Fields for Calendar ID and Event Title, and two Date Picker fields for Start Date and End Date.

Figure 1011: Google Calendar Create Form

...

2. On the right upper corner, click on Generate App > Generate CRUD.

Figure 1112: Google Calendar Generate CRUD

...

3. Go to Settings > Post Form Submission Processing, and attach the Google Calendar Add Event post processing tool. 

Figure 1213: Google Calendar Post Processing Tool

...

4. Fill in the plugin configurations. For more information, please refer to Google Calendar Add Event Properties.

Figure 1314: Google Calendar Fill Plugin Configurations

...

5. Run the UI. Go to Manage Google Calendar and add a new record. Fill in the Calendar ID with your authorised email, the event title, start date and end date.

Figure 1415: Google Calendar Add New Record

...

6. You can go to Google Calendar and check the calendar. You can see that the record added in Joget has been added to the calendar.

Figure 1516: Google Calendar Check Added Calendar

...

1. Create a form and drag the Google Drive File Upload element into the form. No complicated configurations needed, just label and ID of the field.

Figure 1617: Google Drive Create New Form

...

2. On the right upper corner, click on Generate App > Generate CRUD.

Figure 1718: Google Drive Generate CRUD

...

3. Go to the UI. Click on Manage Google Drive and add a new record.

Figure 1819: Google Drive Add New Record

...

4. Go to Google Drive. You can see that your file has been added.

Figure 1920: File created in Google Drive

...

1. Create a new list, select the Google Drive Datalist Binder at the Select Source of Data. No configurations will be needed.

Figure 2021: Google Drive Create New List

...

2. Drag the columns into the table. Save and add this list into the UI.

Figure 2122: Google Drive Drag Column into List

...

3. Run the UI. You can now see the list of files you have in Google Drive, including the files shared to you, and the files which are still in the Trash.

Figure 2223: Google Drive Datalist Binder UI

...

1. Create a form to add new Google Sheets and add a text field which will hold the spreadsheet name data.

Figure 2324: Google Sheets Create New Form to Add New Spreadsheet

...

2. Go to Settings > Save Data To and attach the Google Sheets Form Binder.

Figure 2425: Google Sheets Attach Form Binder

...

3. Fill in the plugin configurations. For more information, you can refer to Google Sheets Form Binder Properties. Attach this form to the UI without CRUD.

Figure 2526: Google Sheets Plugin Configurations for New

...

4. Create another form to modify the data of existing Google Sheets. Add two text fields, a select box (two options: Vertical, Horizontal) and a form grid to hold the spreadsheet data (Refer to 5.)

Figure 2627: Google Sheets Create New Form to Modify Data

...

5. Create a form to hold the values of the form grid in 4. for Spreadsheet Data.

Figure 2728: Google Sheets Create New Form for Modify Data Form Grid

...

6. Go to Settings > Save Data To and attach the Google Sheets Form Binder.

Figure 2829: Google Sheets Attach Form Binder

...

7. Fill in the plugin configurations. For more information, you can refer to Google Sheets Form Binder Properties. Attach this form to the UI without CRUD.

Figure 2930: Google Sheets Plugin Configurations for Modify

...

8. Create a new list. Attach the Google Drive Datalist Binder to retrieve all the Google Drive files, and add a button to easily filter out the Google Sheets files to modify it. Add hyperlink value of modify_google_sheets (the name of the form to modify Google Sheets added to the UI) to the button, and add hyperlink parameters to link to the correct record. To filter out the Google Sheets files, add Visibility Control to the button when field mimeType equals to the value of application/vnd.google-apps.spreadsheet. Add the list into the UI.

Figure 3031: Google Sheets Create New List

...

9. Run the UI. Click on the Create New Google Sheet to create a new Google Sheet.

Figure 3132: Google Sheets Create New Spreadsheet

...

10. Click on Manage Google Sheets. You can see that the spreadsheet files has the modify button. The newly created spreadsheet file is now in the list. Click on the modify button.

Figure 3233: Google Sheets List from Google Drive

...

In Google Drive it is also there. The file has no data yet. 

Figure 3334: Google Drive with New Spreadsheet

...

11. Modify the data by adding values in the Spreadsheet Data.

Figure 3435: Google Sheets Modify Data

...

12. You can see that the values has been added to the Google Sheet.

Figure 3536: Google Sheets Data Modified

...

Configure Google Auth

Figure 3637: Plugin Configurations for Google Auth

...

Configure Google Calendar Add Event

Figure 3738: Plugin Configurations for Google Calendar Add Event

...

Configure Google Sheets Form Binder

Figure 3839: Plugin Configurations for Google Sheets Form Binder - Action Type New


Figure 3940: Plugin Configurations for Google Sheets Form Binder - Action Type Modify Data

...