Workflow: Aggregate Gmail Send

Workflow Details

Download Workflow
{
    "nodes": [
        {
            "id": "8141ffad-df2a-403b-a869-799c036f9733",
            "name": "Gmail trigger",
            "type": "n8n-nodes-base.gmailTrigger",
            "position": [
                -600,
                580
            ],
            "parameters": {
                "simple": false,
                "filters": [],
                "options": [],
                "pollTimes": {
                    "item": [
                        {
                            "mode": "everyMinute"
                        }
                    ]
                }
            },
            "credentials": {
                "gmailOAuth2": {
                    "id": "uBcIMfsTtKjexw7I",
                    "name": "Gmail (workfloowstutorial@gmail.com)"
                }
            },
            "typeVersion": 1
        },
        {
            "id": "6d9aa398-e2de-4fd0-b939-2a12d0c9fe14",
            "name": "Get message content",
            "type": "n8n-nodes-base.gmail",
            "position": [
                -340,
                580
            ],
            "parameters": {
                "simple": false,
                "options": [],
                "messageId": "={{ $json.id }}",
                "operation": "get"
            },
            "credentials": {
                "gmailOAuth2": {
                    "id": "uBcIMfsTtKjexw7I",
                    "name": "Gmail (workfloowstutorial@gmail.com)"
                }
            },
            "typeVersion": 2.100000000000000088817841970012523233890533447265625
        },
        {
            "id": "cd86bc09-8c7f-4c85-9cb3-6dbd42420672",
            "name": "Set label values",
            "type": "n8n-nodes-base.set",
            "position": [
                300,
                580
            ],
            "parameters": {
                "fields": {
                    "values": [
                        {
                            "name": "labels",
                            "type": "arrayValue",
                            "arrayValue": "={{ $json.labels }}"
                        }
                    ]
                },
                "options": []
            },
            "typeVersion": 3.20000000000000017763568394002504646778106689453125
        },
        {
            "id": "329435a6-51d1-416e-9aa9-5fe9a8dce74f",
            "name": "Get all labels",
            "type": "n8n-nodes-base.gmail",
            "position": [
                580,
                460
            ],
            "parameters": {
                "resource": "label",
                "returnAll": true
            },
            "credentials": {
                "gmailOAuth2": {
                    "id": "uBcIMfsTtKjexw7I",
                    "name": "Gmail (workfloowstutorial@gmail.com)"
                }
            },
            "typeVersion": 2.100000000000000088817841970012523233890533447265625
        },
        {
            "id": "7ae2dd15-472d-4a4b-b036-f80ebd7e3c28",
            "name": "Split out assigned labels",
            "type": "n8n-nodes-base.splitOut",
            "position": [
                580,
                700
            ],
            "parameters": {
                "options": [],
                "fieldToSplitOut": "labels"
            },
            "typeVersion": 1
        },
        {
            "id": "744c7afa-75b1-4b3b-8ccb-e2106c01f387",
            "name": "Merge corresponding labels",
            "type": "n8n-nodes-base.merge",
            "position": [
                860,
                580
            ],
            "parameters": {
                "mode": "combine",
                "options": [],
                "mergeByFields": {
                    "values": [
                        {
                            "field1": "name",
                            "field2": "labels"
                        }
                    ]
                },
                "outputDataFrom": "input1"
            },
            "typeVersion": 2.100000000000000088817841970012523233890533447265625
        },
        {
            "id": "e47424dc-f43e-41a9-b1e5-ab3e08cbf395",
            "name": "Aggregate label IDs",
            "type": "n8n-nodes-base.aggregate",
            "position": [
                1120,
                580
            ],
            "parameters": {
                "options": [],
                "fieldsToAggregate": {
                    "fieldToAggregate": [
                        {
                            "renameField": true,
                            "outputFieldName": "label_ids",
                            "fieldToAggregate": "id"
                        }
                    ]
                }
            },
            "typeVersion": 1
        },
        {
            "id": "22ba8297-8efc-463e-8ae0-385fd94a205f",
            "name": "Add labels to message",
            "type": "n8n-nodes-base.gmail",
            "position": [
                1340,
                580
            ],
            "parameters": {
                "labelIds": "={{ $json.label_ids }}",
                "messageId": "={{ $('Gmail trigger').item.json[\"id\"] }}",
                "operation": "addLabels"
            },
            "credentials": {
                "gmailOAuth2": {
                    "id": "uBcIMfsTtKjexw7I",
                    "name": "Gmail (workfloowstutorial@gmail.com)"
                }
            },
            "typeVersion": 2.100000000000000088817841970012523233890533447265625
        },
        {
            "id": "7ebb1aad-00ad-43fa-9e07-e5f324864a74",
            "name": "Assign labels for message",
            "type": "@n8n\/n8n-nodes-langchain.chainLlm",
            "position": [
                -80,
                580
            ],
            "parameters": {
                "prompt": "={{ $json.text }}",
                "messages": {
                    "messageValues": [
                        {
                            "message": "Your task is to categorize the message according to the following labels.\n\nPartnership - email about sponsored content, cooperation etc.\nInquiry - email about products, services.\nNotification - email that doesn't require response. \n\nOne email can have more than one label. Return only label names in JSON format, nothing else. Do not make things up. "
                        }
                    ]
                }
            },
            "typeVersion": 1.3000000000000000444089209850062616169452667236328125
        },
        {
            "id": "2f82db6a-422c-4697-a629-cc782d88209d",
            "name": "Sticky Note",
            "type": "n8n-nodes-base.stickyNote",
            "position": [
                -1100,
                400
            ],
            "parameters": {
                "color": 4,
                "width": 420.48030407740151304096798412501811981201171875,
                "height": 240.57943708322733300519757904112339019775390625,
                "content": "## Add AI labels to Gmail messages\nWith this workflow you can automatically set labels for your Gmail message according to its content. \n\nIn this workflow available are 3 labels: \"Partnership\", \"Inquiry\" and \"Notification\". Feel free to adjust labels according to your needs. \n\n**Please remember to set label names both in your Gmail account and workflow.**"
            },
            "typeVersion": 1
        },
        {
            "id": "4a10fb2b-aebb-4735-bbdb-7f07f1136d95",
            "name": "Sticky Note1",
            "type": "n8n-nodes-base.stickyNote",
            "position": [
                -1100,
                660
            ],
            "parameters": {
                "width": 421.0932411886661839162115938961505889892578125,
                "height": 257.4291637871459670350304804742336273193359375,
                "content": "## \u26a0\ufe0f Note\n\n1. Complete video guide for this workflow is available [on my YouTube](https:\/\/youtu.be\/a8Dhj3Zh9vQ). \n2. Remember to add your credentials and configure nodes (covered in the video guide).\n3. If you like this workflow, please subscribe to [my YouTube channel](https:\/\/www.youtube.com\/@workfloows) and\/or [my newsletter](https:\/\/workfloows.com\/).\n\n**Thank you for your support!**"
            },
            "typeVersion": 1
        },
        {
            "id": "76e62351-d502-4377-9df2-fe92df00fe03",
            "name": "Sticky Note2",
            "type": "n8n-nodes-base.stickyNote",
            "position": [
                -660,
                400
            ],
            "parameters": {
                "width": 238.46025985846739558837725780904293060302734375,
                "height": 348.58737253491608498734422028064727783203125,
                "content": "### Gmail Trigger\nReceive data from Gmail about new incoming message. \n\n\u26a0\ufe0f Set polling interval according to your needs."
            },
            "typeVersion": 1
        },
        {
            "id": "c10702db-211f-4638-bcf0-fbbe18251cb7",
            "name": "Sticky Note4",
            "type": "n8n-nodes-base.stickyNote",
            "position": [
                60,
                780
            ],
            "parameters": {
                "width": 241.53974014153226335110957734286785125732421875,
                "height": 319.3323098457962032625800929963588714599609375,
                "content": "###\n\n\n\n\n\n\n\n\n\n\n### JSON schema\nEdit JSON schema and label names according to your needs.\n\n\u26a0\ufe0f **Label names in system prompt and JSON schema should be the same.**"
            },
            "typeVersion": 1
        },
        {
            "id": "cb6e3573-3d4d-4313-a97e-86a017438399",
            "name": "Sticky Note5",
            "type": "n8n-nodes-base.stickyNote",
            "position": [
                800,
                420
            ],
            "parameters": {
                "width": 226.14233872620644660855759866535663604736328125,
                "height": 347.04763239338308267178945243358612060546875,
                "content": "### Merge labels\nCombine labels retrieved from Gmail account and assigned by AI together."
            },
            "typeVersion": 1
        },
        {
            "id": "8cfb4341-98e6-4944-b26c-15e39184f468",
            "name": "Sticky Note6",
            "type": "n8n-nodes-base.stickyNote",
            "position": [
                1060,
                420
            ],
            "parameters": {
                "width": 452.48413953150185307094943709671497344970703125,
                "height": 347.04763239338308267178945243358612060546875,
                "content": "### Aggregarte labels and add to message\nCreate array of label IDs and add to the desired email message in Gmail."
            },
            "typeVersion": 1
        },
        {
            "id": "bb9766e8-0b72-47f8-9a8e-0b291609e814",
            "name": "Sticky Note7",
            "type": "n8n-nodes-base.stickyNote",
            "position": [
                -400,
                400
            ],
            "parameters": {
                "width": 238.46025985846739558837725780904293060302734375,
                "height": 348.58737253491608498734422028064727783203125,
                "content": "### Get message content\nBased on Gmail message ID retrieve body content of the email and pass it to AI chain."
            },
            "typeVersion": 1
        },
        {
            "id": "48630cbd-8336-4577-928e-37341f09ef9b",
            "name": "Sticky Note8",
            "type": "n8n-nodes-base.stickyNote",
            "position": [
                -140,
                400
            ],
            "parameters": {
                "width": 378.57661273793564760126173496246337890625,
                "height": 348.58737253491608498734422028064727783203125,
                "content": "### Assign labels\nLet the AI decide which labels suit the best content of the message.\n\n\u26a0\ufe0f **Remember to edit system prompt** - modify label names and instructions according to your needs."
            },
            "typeVersion": 1
        },
        {
            "id": "60a9d75e-1564-4b1d-b3f2-acc2e3bf2411",
            "name": "JSON Parser",
            "type": "@n8n\/n8n-nodes-langchain.outputParserStructured",
            "position": [
                140,
                800
            ],
            "parameters": {
                "jsonSchema": "{\n \"type\": \"object\",\n \"properties\": {\n \"labels\": {\n \"type\": \"array\",\n \"items\": {\n \"type\": \"string\",\n \"enum\": [\"Inquiry\", \"Partnership\", \"Notification\"]\n }\n }\n },\n \"required\": [\"labels\"]\n}\n"
            },
            "typeVersion": 1
        },
        {
            "id": "2bdf3fed-8a7f-411a-bad4-266bfea5cede",
            "name": "OpenAI Chat",
            "type": "@n8n\/n8n-nodes-langchain.lmChatOpenAi",
            "position": [
                -120,
                800
            ],
            "parameters": {
                "model": "gpt-4-turbo-preview",
                "options": {
                    "temperature": 0,
                    "responseFormat": "json_object"
                }
            },
            "credentials": {
                "openAiApi": {
                    "id": "jazew1WAaSRrjcHp",
                    "name": "OpenAI (workfloows@gmail.com)"
                }
            },
            "typeVersion": 1
        }
    ],
    "active": false,
    "pinData": [],
    "settings": {
        "executionOrder": "v1"
    },
    "connections": {
        "JSON Parser": {
            "ai_outputParser": [
                [
                    {
                        "node": "Assign labels for message",
                        "type": "ai_outputParser",
                        "index": 0
                    }
                ]
            ]
        },
        "OpenAI Chat": {
            "ai_languageModel": [
                [
                    {
                        "node": "Assign labels for message",
                        "type": "ai_languageModel",
                        "index": 0
                    }
                ]
            ]
        },
        "Gmail trigger": {
            "main": [
                [
                    {
                        "node": "Get message content",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "Get all labels": {
            "main": [
                [
                    {
                        "node": "Merge corresponding labels",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "Set label values": {
            "main": [
                [
                    {
                        "node": "Get all labels",
                        "type": "main",
                        "index": 0
                    },
                    {
                        "node": "Split out assigned labels",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "Aggregate label IDs": {
            "main": [
                [
                    {
                        "node": "Add labels to message",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "Get message content": {
            "main": [
                [
                    {
                        "node": "Assign labels for message",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "Assign labels for message": {
            "main": [
                [
                    {
                        "node": "Set label values",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "Split out assigned labels": {
            "main": [
                [
                    {
                        "node": "Merge corresponding labels",
                        "type": "main",
                        "index": 1
                    }
                ]
            ]
        },
        "Merge corresponding labels": {
            "main": [
                [
                    {
                        "node": "Aggregate label IDs",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        }
    }
}
Back to Workflows

Related Workflows

Wait HTTP Create Webhook
View
Email verification with Icypeas (single)
View
Remote IOT Sensor monitoring via MQTT and InfluxDB
View
HTTP Manual Automation Webhook
View
Receive updates when an event occurs in TheHive
View
Splitout Manual Import Webhook
View
HTTP Telegram Create Webhook
View
Wait Limit Import Webhook
View
Automate Etsy Data Mining with Bright Data Scrape & Google Gemini
View
Signl4 Interval Create Scheduled
View