Workflow: Stopanderror Awss3 Automation

Workflow Details

Download Workflow
{
    "meta": {
        "instanceId": "9e331a89ae45a204c6dee51c77131d32a8c962ec20ccf002135ea60bd285dba9"
    },
    "nodes": [
        {
            "id": "d72750fc-6415-4da6-977a-46d025a91ef9",
            "name": "When clicking \u2018Test workflow\u2019",
            "type": "n8n-nodes-base.manualTrigger",
            "position": [
                -900,
                900
            ],
            "parameters": [],
            "typeVersion": 1
        },
        {
            "id": "b00e7434-f83e-438e-a47b-12d4a2c4fe5b",
            "name": "List Invoices",
            "type": "n8n-nodes-base.splitOut",
            "position": [
                180,
                900
            ],
            "parameters": {
                "options": [],
                "fieldToSplitOut": "data"
            },
            "typeVersion": 1
        },
        {
            "id": "c142f60b-dbbd-444a-b39b-365e9eb1ff58",
            "name": "Inject s3 Subpath",
            "type": "n8n-nodes-base.set",
            "position": [
                820,
                640
            ],
            "parameters": {
                "options": [],
                "assignments": {
                    "assignments": [
                        {
                            "id": "dca623a6-834c-440f-990a-25bfd9afa2b3",
                            "name": "_s3_year",
                            "type": "string",
                            "value": "={{ DateTime.fromSeconds($json.created).format(\"yyyy\") }}"
                        },
                        {
                            "id": "55ab18e0-b2ef-486d-898d-97f671d5049b",
                            "name": "_s3_folder",
                            "type": "string",
                            "value": "={{ $(\"Clean and Escape ENV\").first().json.subFolder }}"
                        },
                        {
                            "id": "7f998728-a70e-4495-8d34-3ba72a71986b",
                            "name": "_s3_month",
                            "type": "string",
                            "value": "={{ DateTime.fromSeconds($json.created).format(\"MM\") }}"
                        }
                    ]
                },
                "includeOtherFields": true
            },
            "typeVersion": 3.399999999999999911182158029987476766109466552734375
        },
        {
            "id": "4cdd4338-7225-442b-8df6-44bebfe6d5e9",
            "name": "Set-Subpath",
            "type": "n8n-nodes-base.set",
            "position": [
                1000,
                640
            ],
            "parameters": {
                "options": [],
                "assignments": {
                    "assignments": [
                        {
                            "id": "f2969361-8ed9-453b-8c71-e5b3c962af20",
                            "name": "_s3_path",
                            "type": "string",
                            "value": "={{ ($json._s3_folder ? $json._s3_folder+\"\/\" : \"\")+$json._s3_year+\"\/\"+$json._s3_month+\"\/\"+$binary.data.fileName  }}"
                        }
                    ]
                },
                "includeOtherFields": true
            },
            "typeVersion": 3.399999999999999911182158029987476766109466552734375
        },
        {
            "id": "4965110b-0516-4a5d-9b04-8ccbb337f9d5",
            "name": "We do only Invoice Objects",
            "type": "n8n-nodes-base.if",
            "position": [
                360,
                900
            ],
            "parameters": {
                "options": [],
                "conditions": {
                    "options": {
                        "leftValue": "",
                        "caseSensitive": true,
                        "typeValidation": "strict"
                    },
                    "combinator": "and",
                    "conditions": [
                        {
                            "id": "2bdd8550-526c-4833-872e-b1028019a88a",
                            "operator": {
                                "name": "filter.operator.equals",
                                "type": "string",
                                "operation": "equals"
                            },
                            "leftValue": "={{ $json.object }}",
                            "rightValue": "invoice"
                        }
                    ]
                }
            },
            "typeVersion": 2
        },
        {
            "id": "def30f79-593f-48b3-b46f-29c5329a59ae",
            "name": "It shouldn't be something else",
            "type": "n8n-nodes-base.stopAndError",
            "position": [
                580,
                1042.3086136912688743905164301395416259765625
            ],
            "parameters": {
                "errorMessage": "Unexpected or missing Invoice Obj"
            },
            "typeVersion": 1
        },
        {
            "id": "927c4bbd-5a57-4929-aebb-b187690108ac",
            "name": "ENV*",
            "type": "n8n-nodes-base.set",
            "position": [
                -500,
                900
            ],
            "parameters": {
                "options": [],
                "assignments": {
                    "assignments": [
                        {
                            "id": "b2927be9-2b00-4ab8-8938-56b1a0c2e134",
                            "name": "year",
                            "type": "number",
                            "value": "={{ $now.minus(1,\"month\").format(\"yyyy\") }}"
                        },
                        {
                            "id": "89e0c6ee-7b67-405a-b933-5a511cdea94b",
                            "name": "month",
                            "type": "number",
                            "value": "={{ $now.minus(1,\"month\").format(\"MM\") }}"
                        },
                        {
                            "id": "35a218d2-cd20-4388-8bc6-926752289df5",
                            "name": "subFolder",
                            "type": "string",
                            "value": "invoices"
                        },
                        {
                            "id": "7d18829a-018d-4814-987e-cdbee04896b3",
                            "name": "bucketName",
                            "type": "string",
                            "value": "myBucket"
                        }
                    ]
                }
            },
            "typeVersion": 3.399999999999999911182158029987476766109466552734375
        },
        {
            "id": "dd75af83-6e0a-4685-a3bd-1622e2c800de",
            "name": "Download Invoice PDF from Stripe",
            "type": "n8n-nodes-base.httpRequest",
            "position": [
                580,
                640
            ],
            "parameters": {
                "url": "={{ $json.invoice_pdf }}",
                "options": []
            },
            "typeVersion": 4.20000000000000017763568394002504646778106689453125
        },
        {
            "id": "30c4090d-043c-4b3b-b86c-df1e10544b2e",
            "name": "Sticky Note",
            "type": "n8n-nodes-base.stickyNote",
            "position": [
                -600,
                802.3086136912688743905164301395416259765625
            ],
            "parameters": {
                "color": 4,
                "width": 305.70726534715657862761872820556163787841796875,
                "height": 670.930632268405361173790879547595977783203125,
                "content": "## \ud83d\udc47  Configure here\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n`folderName` *(optional)* = Subfolder for your Invoices, otherwise it will create in root. e.g: \"invoices\"\n\n`bucketName` *(required)* = the S3 Bucket Name, where invoices will be synced in\n\n`year` (automatic or hardcore) = \nthe expression makes sure it will be exporting \"last month\". Or define a custom year for manual export.\n\n`month` (automatic or hardcore) = \nthe expression makes sure it will be exporting \"last month\". Or define a custom month for manual export.\n\n\n**EVERYTHING** greater then the **provided date** will be exported. The Day will be always the first of month."
            },
            "typeVersion": 1
        },
        {
            "id": "4134f369-84de-4019-a014-1d823ec77668",
            "name": "Sticky Note1",
            "type": "n8n-nodes-base.stickyNote",
            "position": [
                780,
                480
            ],
            "parameters": {
                "color": 5,
                "width": 362.35145961194660912951803766191005706787109375,
                "height": 336.0317580768505649757571518421173095703125,
                "content": "## Build Pathes\n\n*yourFolder\/invoiceYear\/invoiceMonth\/fileName*\n\ne.g.: invoices\/2024\/12\/invoice-number-123.pdf"
            },
            "typeVersion": 1
        },
        {
            "id": "c8ecef82-ef73-4920-b9fa-16220009f7d9",
            "name": "Sticky Note2",
            "type": "n8n-nodes-base.stickyNote",
            "position": [
                1203.3986516558870789594948291778564453125,
                482.2657677705911964949336834251880645751953125
            ],
            "parameters": {
                "width": 283.049587641240350421867333352565765380859375,
                "height": 329.9325827943702051925356499850749969482421875,
                "content": "## Upload to Bucket\n\n**\u26a0\ufe0f You might want to check Storage Class, ACL, etc.**"
            },
            "typeVersion": 1
        },
        {
            "id": "a0505cc0-8312-46f2-970d-bfabff881ced",
            "name": "Every Month the First Day of the Month",
            "type": "n8n-nodes-base.scheduleTrigger",
            "position": [
                -900,
                1102.3086136912688743905164301395416259765625
            ],
            "parameters": {
                "rule": {
                    "interval": [
                        {
                            "field": "months"
                        }
                    ]
                }
            },
            "typeVersion": 1.1999999999999999555910790149937383830547332763671875
        },
        {
            "id": "53ee7468-f478-4c10-8767-1aa7967b3225",
            "name": "Sticky Note3",
            "type": "n8n-nodes-base.stickyNote",
            "position": [
                -100,
                820
            ],
            "parameters": {
                "width": 232,
                "height": 256,
                "content": "### Use Stripe Predefined Credential"
            },
            "typeVersion": 1
        },
        {
            "id": "6055b93d-0462-4d1a-974a-7d31143e6b79",
            "name": "Note3",
            "type": "n8n-nodes-base.stickyNote",
            "position": [
                -1360,
                780
            ],
            "parameters": {
                "width": 367.1509824198550404616980813443660736083984375,
                "height": 485.66522445338995339625398628413677215576171875,
                "content": "## Instructions\n\nThis automation syncs monthly your Invoice PDF from Stripe to a (AWS) S3 Bucket of your choice with the following subPaths (Key):\n\n*yourFolder\/invoiceYear\/invoiceMonth\/fileName*\n\n\nFill in your **Credentials and Settings** in the Nodes marked with _\"*\"_.\n\nYou can adjust this Workflow to your needs. You can also override the `year`and `month` in the ENV* Node for manual syncs.\n\n![Image](https:\/\/let-the-work-flow.com\/logo-64.png)\nEnjoy the Workflow! \u2764\ufe0f \nhttps:\/\/let-the-work-flow.com\nWorkflow Automation & Development"
            },
            "typeVersion": 1
        },
        {
            "id": "c5e5946c-c74f-435f-9664-491bbbca00f2",
            "name": "Get all Invoices*",
            "type": "n8n-nodes-base.httpRequest",
            "position": [
                -40,
                900
            ],
            "parameters": {
                "url": "https:\/\/api.stripe.com\/v1\/invoices",
                "options": [],
                "sendQuery": true,
                "authentication": "predefinedCredentialType",
                "queryParameters": {
                    "parameters": [
                        {
                            "name": "limit",
                            "value": "100"
                        },
                        {
                            "name": "created[gte]",
                            "value": "={{ DateTime.fromISO($json.year+\"-\"+$json.month+\"-01T00:00:00\").toSeconds() }}"
                        }
                    ]
                },
                "nodeCredentialType": "stripeApi"
            },
            "typeVersion": 4.20000000000000017763568394002504646778106689453125
        },
        {
            "id": "5ed183d2-3001-40ef-9dc6-897c6789209a",
            "name": "Upload to S3 Bucket*",
            "type": "n8n-nodes-base.awsS3",
            "position": [
                1280,
                640
            ],
            "parameters": {
                "fileName": "={{ $json._s3_path }}",
                "operation": "upload",
                "bucketName": "={{ $(\"Clean and Escape ENV\").first().json.bucketName }}",
                "additionalFields": {
                    "storageClass": "intelligentTiering"
                }
            },
            "typeVersion": 2
        },
        {
            "id": "04b57622-64b2-4c62-b84b-61d49c3171fb",
            "name": "Clean and Escape ENV",
            "type": "n8n-nodes-base.set",
            "position": [
                -240,
                900
            ],
            "parameters": {
                "options": [],
                "assignments": {
                    "assignments": [
                        {
                            "id": "2d053eee-92a2-44ee-ad34-b1ad87728285",
                            "name": "bucketName",
                            "type": "string",
                            "value": "={{ $json.bucketName.trim().replace(\/\\\\\/g, '')  }}"
                        },
                        {
                            "id": "ccd36bf6-91f3-44af-8b57-3002041c9829",
                            "name": "subFolder",
                            "type": "string",
                            "value": "={{ $json.subFolder.trim().replace(\/\\\\\/g, '')  }}"
                        },
                        {
                            "id": "0fb9451f-afc1-4b70-9ec3-f3ac7187c2db",
                            "name": "month",
                            "type": "string",
                            "value": "={{ $json.month.toString().padStart(2,\"0\") }}"
                        },
                        {
                            "id": "eda1110d-329b-4d12-a089-253ac189aea4",
                            "name": "year",
                            "type": "number",
                            "value": "={{ parseInt($json.year) }}"
                        }
                    ]
                },
                "includeOtherFields": true
            },
            "typeVersion": 3.399999999999999911182158029987476766109466552734375
        }
    ],
    "pinData": [],
    "connections": {
        "ENV*": {
            "main": [
                [
                    {
                        "node": "Clean and Escape ENV",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "Set-Subpath": {
            "main": [
                [
                    {
                        "node": "Upload to S3 Bucket*",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "List Invoices": {
            "main": [
                [
                    {
                        "node": "We do only Invoice Objects",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "Get all Invoices*": {
            "main": [
                [
                    {
                        "node": "List Invoices",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "Inject s3 Subpath": {
            "main": [
                [
                    {
                        "node": "Set-Subpath",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "Clean and Escape ENV": {
            "main": [
                [
                    {
                        "node": "Get all Invoices*",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "We do only Invoice Objects": {
            "main": [
                [
                    {
                        "node": "Download Invoice PDF from Stripe",
                        "type": "main",
                        "index": 0
                    }
                ],
                [
                    {
                        "node": "It shouldn't be something else",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "Download Invoice PDF from Stripe": {
            "main": [
                [
                    {
                        "node": "Inject s3 Subpath",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "When clicking \u2018Test workflow\u2019": {
            "main": [
                [
                    {
                        "node": "ENV*",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        },
        "Every Month the First Day of the Month": {
            "main": [
                [
                    {
                        "node": "ENV*",
                        "type": "main",
                        "index": 0
                    }
                ]
            ]
        }
    }
}
Back to Workflows

Related Workflows

Splitout Webhook Create Webhook
View
Remote IOT Sensor monitoring via MQTT and InfluxDB
View
Email Summary Agent
View
Code Review workflow
View
Manual Htmlextract Automation Webhook
View
Emailreadimap Nextcloud Send
View
Monitor_security_advisories
View
MONDAY GET FULL ITEM
View
Stickynote Send Webhook
View
Orlen
View