
SheetModifiedTrigger
SheetModifiedTrigger
yaml
type: "io.kestra.plugin.googleworkspace.sheets.SheetModifiedTrigger"Examples
yaml
id: monitor_spreadsheet
namespace: company.team
tasks:
- id: log_changes
type: io.kestra.plugin.core.log.Log
message: |
{% if trigger.count > 0 %}
Spreadsheet '{{ trigger.modifications[0].spreadsheetTitle }}' was modified by {{ trigger.modifications[0].lastModifyingUser }}.
Detected {{ trigger.count }} modification(s).
{% else %}
No modifications detected in spreadsheet.
{% endif %}
triggers:
- id: watch_sheet
type: io.kestra.plugin.googleworkspace.sheets.SheetModifiedTrigger
interval: PT5M
spreadsheetId: "1U4AoiUrqiVaSIVcm_TwDc9RoKOdCULNGWxuC1vmDT_A"
serviceAccount: "{{ secret('GCP_SERVICE_ACCOUNT_JSON') }}"
yaml
id: monitor_orders_sheet
namespace: company.team
tasks:
- id: process_changes
type: io.kestra.plugin.core.debug.Return
format: |
{% if trigger.count > 0 %}
Changes detected in sheet:
- Modified at: {{ trigger.modifications[0].modifiedTime }}
- Modified by: {{ trigger.modifications[0].lastModifyingUser }}
- Revision ID: {{ trigger.modifications[0].revisionId }}
{% else %}
No modifications detected in Orders sheet.
{% endif %}
triggers:
- id: watch_orders
type: io.kestra.plugin.googleworkspace.sheets.SheetModifiedTrigger
interval: PT2M
spreadsheetId: "1U4AoiUrqiVaSIVcm_TwDc9RoKOdCULNGWxuC1vmDT_A"
serviceAccount: "{{ secret('GCP_SERVICE_ACCOUNT_JSON') }}"
sheetName: "Orders"
includeDetails: true
yaml
id: track_new_revisions
namespace: company.team
tasks:
- id: notify
type: io.kestra.plugin.notifications.slack.SlackIncomingWebhook
url: "{{ secret('SLACK_WEBHOOK') }}"
payload: |
{
"text": "{% if trigger.count > 0 %}Spreadsheet '{{ trigger.modifications[0].spreadsheetTitle }}' was modified by {{ trigger.modifications[0].lastModifyingUser }}{% else %}No changes detected{% endif %}"
}
triggers:
- id: watch
type: io.kestra.plugin.googleworkspace.sheets.SheetModifiedTrigger
interval: PT1M
spreadsheetId: "{{ vars.spreadsheet_id }}"
serviceAccount: "{{ secret('GCP_SERVICE_ACCOUNT_JSON') }}"
on: CREATE
includeDetails: true
Properties
spreadsheetId*Requiredstring
allowConcurrentNon-dynamicboolean
Default
falseconditionsNon-dynamic
Definitions
Condition to allow events between two specific datetime values.
type*Requiredobject
afterstring
Format
date-timebeforestring
Format
date-timedatestring
Default
{{ trigger.date }}Condition to allow events on a particular day of the week.
dayOfWeek*Requiredstring
Possible Values
MONDAYTUESDAYWEDNESDAYTHURSDAYFRIDAYSATURDAYSUNDAYtype*Requiredobject
datestring
Default
{{ trigger.date }}Condition to execute tasks on a specific day of the week relative to the current month (first, last, ...)
dayInMonth*Requiredstring
Possible Values
FIRSTLASTSECONDTHIRDFOURTHdayOfWeek*Requiredstring
Possible Values
MONDAYTUESDAYWEDNESDAYTHURSDAYFRIDAYSATURDAYSUNDAYtype*Requiredobject
datestring
Default
{{ trigger.date }}Condition for a specific flow of an execution.
flowId*Requiredstring
namespace*Requiredstring
type*Requiredobject
Condition that checks labels of an execution.
labels*Requiredarrayobject
type*Requiredobject
Condition for an execution namespace.
namespace*Requiredstring
type*Requiredobject
comparisonstring
Possible Values
EQUALSPREFIXSUFFIXprefixbooleanstring
Default
falseCondition based on the outputs of an upstream execution.
expression*Requiredbooleanstring
type*Requiredobject
Condition based on execution status.
type*Requiredobject
inarray
SubTypestring
Possible Values
CREATEDSUBMITTEDRUNNINGPAUSEDRESTARTEDKILLINGSUCCESSWARNINGFAILEDKILLEDCANCELLEDQUEUEDRETRYINGRETRIEDSKIPPEDBREAKPOINTRESUBMITTEDnotInarray
SubTypestring
Possible Values
CREATEDSUBMITTEDRUNNINGPAUSEDRESTARTEDKILLINGSUCCESSWARNINGFAILEDKILLEDCANCELLEDQUEUEDRETRYINGRETRIEDSKIPPEDBREAKPOINTRESUBMITTEDCondition based on variable expression.
expression*Requiredstring
type*Requiredobject
Condition for a specific flow. Note that this condition is deprecated, use `io.kestra.plugin.core.condition.ExecutionFlow` instead.
flowId*Requiredstring
namespace*Requiredstring
type*Requiredobject
Condition for a flow namespace.
namespace*Requiredstring
type*Requiredobject
prefixboolean
Default
falseCondition that matches if any taskRun has retry attempts.
type*Requiredobject
inarray
SubTypestring
Possible Values
CREATEDSUBMITTEDRUNNINGPAUSEDRESTARTEDKILLINGSUCCESSWARNINGFAILEDKILLEDCANCELLEDQUEUEDRETRYINGRETRIEDSKIPPEDBREAKPOINTRESUBMITTEDnotInarray
SubTypestring
Possible Values
CREATEDSUBMITTEDRUNNINGPAUSEDRESTARTEDKILLINGSUCCESSWARNINGFAILEDKILLEDCANCELLEDQUEUEDRETRYINGRETRIEDSKIPPEDBREAKPOINTRESUBMITTEDRun a flow if the list of preconditions is met in a time window.
conditions*Requiredobject
id*Requiredstring
Validation RegExp
^[a-zA-Z0-9][a-zA-Z0-9_-]*Min length
1type*Requiredobject
resetOnSuccessboolean
Default
truetimeWindow
Default
{
"type": "DURATION_WINDOW"
}io.kestra.core.models.triggers.TimeWindow
deadlinestring
Format
partial-timeendTimestring
Format
partial-timestartTimestring
Format
partial-timetypestring
Default
DURATION_WINDOWPossible Values
DAILY_TIME_DEADLINEDAILY_TIME_WINDOWDURATION_WINDOWSLIDING_WINDOWwindowstring
Format
durationwindowAdvancestring
Format
durationwindowDeprecatedstring
Format
durationwindowAdvanceDeprecatedstring
Format
durationCondition to exclude other conditions.
conditions*Required
Min items
1type*Requiredobject
Condition to have at least one condition validated.
conditions*Required
Min items
1type*Requiredobject
Condition to allow events on public holidays.
type*Requiredobject
countrystring
datestring
Default
{{ trigger.date}}subDivisionstring
Condition to allow events between two specific times.
type*Requiredobject
afterstring
Format
timebeforestring
Format
timedatestring
Default
{{ trigger.date }}Condition to allow events on weekend.
type*Requiredobject
datestring
Default
{{ trigger.date }}includeDetailsbooleanstring
Default
falseintervalNon-dynamicstring
Default
PT5MFormat
durationonstring
Default
CREATE_OR_UPDATEPossible Values
CREATEUPDATECREATE_OR_UPDATErangestring
scopesarray
SubTypestring
Default
["https://www.googleapis.com/auth/spreadsheets.readonly","https://www.googleapis.com/auth/drive.metadata.readonly"]serviceAccountstring
sheetNamestring
stateKeystring
stateTtlstring
Format
durationstopAfterNon-dynamicarray
SubTypestring
Possible Values
CREATEDSUBMITTEDRUNNINGPAUSEDRESTARTEDKILLINGSUCCESSWARNINGFAILEDKILLEDCANCELLEDQUEUEDRETRYINGRETRIEDSKIPPEDBREAKPOINTRESUBMITTEDOutputs
countinteger
modificationsarray
Definitions
io.kestra.plugin.googleworkspace.sheets.SheetModifiedTrigger-ModificationOutput
changeDetails
io.kestra.plugin.googleworkspace.sheets.SheetModifiedTrigger-ChangeDetails
affectedRangestring
columnCountinteger
hasDataboolean
rowCountinteger
lastModifyingUserstring
modifiedTimestring
Format
date-timerevisionIdstring
sheetNamestring
spreadsheetIdstring
spreadsheetTitlestring