Workflow: Code Filter Monitor

Workflow Details

Download Workflow
{
    "id": "XY0cZQwrhzOkisSt",
    "meta": {
        "instanceId": "660cf2c29eb19fa42319afac3bd2a4a74c6354b7c006403f6cba388968b63f5d",
        "templateCredsSetupCompleted": true
    },
    "name": "Monitor Competitor Pricing",
    "tags": [
        {
            "id": "a8B9vqj0vNLXcKVQ",
            "name": "template",
            "createdAt": "2025-04-04T15:38:37.785Z",
            "updatedAt": "2025-04-04T15:38:37.785Z"
        }
    ],
    "nodes": [
        {
            "id": "056f47d7-5a06-4714-beb5-c53ffb663ed1",
            "name": "When clicking \u2018Test workflow\u2019",
            "type": "n8n-nodes-base.manualTrigger",
            "position": [
                0,
                -180
            ],
            "parameters": [],
            "typeVersion": 1
        },
        {
            "id": "a8e5d613-bf15-4ebf-9191-4a17e86baba1",
            "name": "Get Pricing URLs",
            "type": "n8n-nodes-base.googleSheets",
            "position": [
                220,
                -180
            ],
            "parameters": {
                "options": [],
                "sheetName": {
                    "__rl": true,
                    "mode": "list",
                    "value": "gid=0",
                    "cachedResultUrl": "https:\/\/docs.google.com\/spreadsheets\/d\/1MER5ftlYyfPZR-N9ZwwVT7Ea0wwqQYxln8l1HuBqjhA\/edit#gid=0",
                    "cachedResultName": "Sheet1"
                },
                "documentId": {
                    "__rl": true,
                    "mode": "list",
                    "value": "1MER5ftlYyfPZR-N9ZwwVT7Ea0wwqQYxln8l1HuBqjhA",
                    "cachedResultUrl": "https:\/\/docs.google.com\/spreadsheets\/d\/1MER5ftlYyfPZR-N9ZwwVT7Ea0wwqQYxln8l1HuBqjhA\/edit?usp=drivesdk",
                    "cachedResultName": "Copy of Monitor Pricing"
                }
            },
            "credentials": {
                "googleSheetsOAuth2Api": {
                    "id": "CwpCAR1HwgHZpRtJ",
                    "name": "Google Drive"
                }
            },
            "typeVersion": 4.5
        },
        {
            "id": "7ee84bd6-cc49-46cd-bde2-04ec53773bb8",
            "name": "Check pricing",
            "type": "n8n-nodes-base.airtop",
            "position": [
                440,
                -260
            ],
            "parameters": {
                "url": "={{ $json[\"Pricing URL\"] }}",
                "prompt": "=This is a pricing page. Please summarize it concisely by including every plan. For each plan, list the price and the top 3 features it includes. Compare the current plan to the previous plan described here: \n[{{ $json.Pricing }}].\n\nRETURN ONLY 3 FIELDS:\n1. `pricing_summary` - A textual description of the pricing, including the  plan's name, price, and top 3 features.\n2. `differences_summary` - If there are significant differences in the PRICES between the previous plan and the current one, summarize the differences concisely in a textual description, focusing only on the changes in prices.\n3. `status` - In a status field, return [DIFF] if the new plan and pricing are substantially different from the previous one, [SIMILAR] if they are similar, or [NEW] if the previous pricing is empty.\n\n- important, do not guess or estimate, just report things that are clearly mentioned in pricing page\n",
                "resource": "extraction",
                "operation": "query",
                "sessionMode": "new",
                "additionalFields": {
                    "outputSchema": "{\n  \"type\": \"object\",\n  \"properties\": {\n    \"pricing_summary\": {\n      \"type\": \"string\",\n      \"description\": \"A textual description of the pricing, including the plan's name, price, and top 3 features.\"\n    },\n    \"differences_summary\": {\n      \"type\": \"string\",\n      \"description\": \"A concise summary of the differences between the previous and current plans, focusing on changes.\"\n    },\n    \"status\": {\n      \"type\": \"string\",\n      \"description\": \"Indicates if the new plan is substantially different from the previous one.\"\n    }\n  },\n  \"required\": [\n    \"pricing_summary\",\n    \"differences_summary\",\n    \"status\"\n  ],\n  \"additionalProperties\": false,\n  \"$schema\": \"http:\/\/json-schema.org\/draft-07\/schema#\"\n}"
                }
            },
            "credentials": {
                "airtopApi": {
                    "id": "byhouJF8RLH5DkmY",
                    "name": "Airtop"
                }
            },
            "typeVersion": 1
        },
        {
            "id": "b6c89c9e-d87c-427d-a214-f5540036d3fd",
            "name": "Parse response",
            "type": "n8n-nodes-base.code",
            "position": [
                880,
                -180
            ],
            "parameters": {
                "mode": "runOnceForEachItem",
                "jsCode": "const response = JSON.parse($json.data.modelResponse)\n\nreturn { json: {\n  ...response,\n  row_number: $json['row_number'],\n  \"Pricing URL\": $json[\"Pricing URL\"]\n}}"
            },
            "typeVersion": 2
        },
        {
            "id": "7783075b-3ae3-4032-9506-16d24e9f25f6",
            "name": "Merge",
            "type": "n8n-nodes-base.merge",
            "position": [
                660,
                -180
            ],
            "parameters": {
                "mode": "combine",
                "options": [],
                "combineBy": "combineByPosition"
            },
            "typeVersion": 3.100000000000000088817841970012523233890533447265625
        },
        {
            "id": "7466f2a8-8b72-48f5-94a4-c150e6bc5584",
            "name": "Update pricing",
            "type": "n8n-nodes-base.googleSheets",
            "position": [
                1320,
                -280
            ],
            "parameters": {
                "columns": {
                    "value": {
                        "Time": "={{ $now }}",
                        "Pricing": "={{ $json.pricing_summary }}",
                        "row_number": "={{ $json.row_number }}",
                        "Pricing URL": "="
                    },
                    "schema": [
                        {
                            "id": "Pricing URL",
                            "type": "string",
                            "display": true,
                            "required": false,
                            "displayName": "Pricing URL",
                            "defaultMatch": false,
                            "canBeUsedToMatch": true
                        },
                        {
                            "id": "Pricing",
                            "type": "string",
                            "display": true,
                            "required": false,
                            "displayName": "Pricing",
                            "defaultMatch": false,
                            "canBeUsedToMatch": true
                        },
                        {
                            "id": "Time",
                            "type": "string",
                            "display": true,
                            "required": false,
                            "displayName": "Time",
                            "defaultMatch": false,
                            "canBeUsedToMatch": true
                        },
                        {
                            "id": "row_number",
                            "type": "string",
                            "display": true,
                            "removed": false,
                            "readOnly": true,
                            "required": false,
                            "displayName": "row_number",
                            "defaultMatch": false,
                            "canBeUsedToMatch": true
                        }
                    ],
                    "mappingMode": "defineBelow",
                    "matchingColumns": [
                        "row_number"
                    ],
                    "attemptToConvertTypes": false,
                    "convertFieldsToString": false
                },
                "options": [],
                "operation": "update",
                "sheetName": {
                    "__rl": true,
                    "mode": "list",
                    "value": "gid=0",
                    "cachedResultUrl": "https:\/\/docs.google.com\/spreadsheets\/d\/1MER5ftlYyfPZR-N9ZwwVT7Ea0wwqQYxln8l1HuBqjhA\/edit#gid=0",
                    "cachedResultName": "Sheet1"
                },
                "documentId": {
                    "__rl": true,
                    "mode": "list",
                    "value": "1MER5ftlYyfPZR-N9ZwwVT7Ea0wwqQYxln8l1HuBqjhA",
                    "cachedResultUrl": "https:\/\/docs.google.com\/spreadsheets\/d\/1MER5ftlYyfPZR-N9ZwwVT7Ea0wwqQYxln8l1HuBqjhA\/edit?usp=drivesdk",
                    "cachedResultName": "Copy of Monitor Pricing"
                }
            },
            "credentials": {
                "googleSheetsOAuth2Api": {
                    "id": "CwpCAR1HwgHZpRtJ",
                    "name": "Google Drive"
                }
            },
            "typeVersion": 4.5
        },
        {
            "id": "3c2d84a5-1080-4e49-a43e-f643e454e463",
            "name": "Notify pricing change",
            "type": "n8n-nodes-base.slack",
            "position": [
                1320,
                -80
            ],
            "webhookId": "539892f2-e877-4dd5-85e7-d10e1be6daf1",
            "parameters": {
                "text": "={{ $json[\"Pricing URL\"] + \" - \" + $json.differences_summary }}",
                "select": "channel",
                "channelId": {
                    "__rl": true,
                    "mode": "list",
                    "value": "C087FK3J0MC",
                    "cachedResultName": "pricing-changes"
                },
                "otherOptions": []
            },
            "credentials": {
                "slackApi": {
                    "id": "NgjAmOgS9xRg1RlU",
                    "name": "Slack account"
                }
            },
            "typeVersion": 2.29999999999999982236431605997495353221893310546875
        },
        {
            "id": "174132d5-3273-4b8b-a51f-ccbce9f21f93",
            "name": "Filter out similar",
            "type": "n8n-nodes-base.filter",
            "position": [
                1100,
                -180
            ],
            "parameters": {
                "options": [],
                "conditions": {
                    "options": {
                        "version": 2,
                        "leftValue": "",
                        "caseSensitive": true,
                        "typeValidation": "strict"
                    },
                    "combinator": "and",
                    "conditions": [
                        {
                            "id": "5142d433-519e-4e9d-ab8e-3a97d1177b51",
                            "operator": {
                                "type": "string",
                                "operation": "notContains"
                            },
                            "leftValue": "={{ $json.status }}",
                            "rightValue": "SIMILAR"
                        }
                    ]
                }
            },
            "typeVersion": 2.20000000000000017763568394002504646778106689453125
        }
    ],
    "active": false,
    "pinData": [],
    "settings": {
        "executionOrder": "v1"
    },
    "versionId": "c6b3fa69-c354-44b6-b472-1b530fca23e7",
    "connections": {
        "Merge": {
            "main": [
                [
                    {
                        "node": "Parse response",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "Check pricing": {
            "main": [
                [
                    {
                        "node": "Merge",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "Parse response": {
            "main": [
                [
                    {
                        "node": "Filter out similar",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "Get Pricing URLs": {
            "main": [
                [
                    {
                        "node": "Check pricing",
                        "type": "main",
                        "index": 0
                    },
                    {
                        "node": "Merge",
                        "type": "main",
                        "index": 1
                    }
                ]
            ]
        },
        "Filter out similar": {
            "main": [
                [
                    {
                        "node": "Update pricing",
                        "type": "main",
                        "index": 0
                    },
                    {
                        "node": "Notify pricing change",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "When clicking \u2018Test workflow\u2019": {
            "main": [
                [
                    {
                        "node": "Get Pricing URLs",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        }
    }
}
Back to Workflows

Related Workflows

Analyze_email_headers_for_IPs_and_spoofing__3
View
Telegram Gmail Create Triggered
View
template-demo-chatgpt-image-1-with-drive-and-sheet copy
View
OpenSea NFT Agent Tool
View
HTTP Stickynote Automate Webhook
View
Manual Debughelper Create Triggered
View
Manual Tapfiliate Automate Triggered
View
Travel Planning Agent with Couchbase Vector Search, Gemini 2.0 Flash and OpenAI
View
AI-Driven WooCommerce Product Importer with SEO
View
Wait Splitout Create Webhook
View