{
  "id": "0GCQ1fO3d5MBdKmi",
  "meta": {
    "instanceId": "fddb3e91967f1012c95dd02bf5ad21f279fc44715f47a7a96a33433621caa253"
  },
  "name": "template-demo-chatgpt-image-1-with-drive-and-sheet copy",
  "tags": [],
  "nodes": [
    {
      "id": "7d78d4e3-cbb3-4f32-82d9-73c9d7f6c892",
      "name": "When clicking 'Test workflow'",
      "type": "n8n-nodes-base.manualTrigger",
      "disabled": true,
      "position": [
        -480,
        -245
      ],
      "parameters": {},
      "typeVersion": 1
    },
    {
      "id": "b32b61bb-c837-4697-9742-a1bb2854b628",
      "name": "HTTP Request",
      "type": "n8n-nodes-base.httpRequest",
      "position": [
        -260,
        -120
      ],
      "parameters": {
        "url": "https://api.openai.com/v1/images/generations",
        "method": "POST",
        "options": {},
        "sendBody": true,
        "authentication": "predefinedCredentialType",
        "bodyParameters": {
          "parameters": [
            {
              "name": "model",
              "value": "gpt-image-1"
            },
            {
              "name": "prompt",
              "value": "={{ $json.chatInput }}"
            },
            {
              "name": "output_format",
              "value": "jpeg"
            },
            {
              "name": "quality",
              "value": "low"
            },
            {
              "name": "output_compression",
              "value": "={{parseInt('80')}}"
            },
            {
              "name": "size",
              "value": "1024x1024"
            },
            {
              "name": "n",
              "value": "={{parseInt('1')}}"
            },
            {
              "name": "moderation",
              "value": "low"
            }
          ]
        },
        "nodeCredentialType": "openAiApi"
      },
      "credentials": {
        "openAiApi": {
          "id": "GgwYNKMKKqKJICYO",
          "name": "OpenAi account - Image"
        }
      },
      "typeVersion": 4.2
    },
    {
      "id": "0ead70d0-9e3b-4f19-afee-b5d4a7b532e9",
      "name": "Google Drive",
      "type": "n8n-nodes-base.googleDrive",
      "position": [
        860,
        -20
      ],
      "parameters": {
        "name": "=chatgpt_created_by_n8n_{{ $('HTTP Request').item.json.created }}",
        "driveId": {
          "__rl": true,
          "mode": "list",
          "value": "My Drive"
        },
        "options": {},
        "folderId": {
          "__rl": true,
          "mode": "list",
          "value": "1sIbMHDtcOafBVdCq0gTEuGvnT63s8Fdy",
          "cachedResultUrl": "https://drive.google.com/drive/folders/1sIbMHDtcOafBVdCq0gTEuGvnT63s8Fdy",
          "cachedResultName": "n8n-demo-gpt_image_1"
        },
        "inputDataFieldName": "=data"
      },
      "credentials": {
        "googleDriveOAuth2Api": {
          "id": "iQdqjdvLVh5ldUIq",
          "name": "Personal-Google Drive account"
        }
      },
      "typeVersion": 3
    },
    {
      "id": "a76c4340-9f34-49d1-a831-1ba4515933ee",
      "name": "Split Out",
      "type": "n8n-nodes-base.splitOut",
      "position": [
        -40,
        -120
      ],
      "parameters": {
        "options": {
          "includeBinary": true
        },
        "fieldToSplitOut": "data"
      },
      "typeVersion": 1
    },
    {
      "id": "c8090e15-b9b9-4999-89f0-97d45e6176d6",
      "name": "Convert to File",
      "type": "n8n-nodes-base.convertToFile",
      "position": [
        640,
        -20
      ],
      "parameters": {
        "options": {
          "fileName": "={{ $now.format("yyyyMMddHHmmSSS") }}"
        },
        "operation": "toBinary",
        "sourceProperty": "b64_json"
      },
      "typeVersion": 1.1
    },
    {
      "id": "692a71fb-6fe3-4728-a588-f9283f5ab968",
      "name": "Loop Over Items",
      "type": "n8n-nodes-base.splitInBatches",
      "position": [
        200,
        -20
      ],
      "parameters": {
        "options": {
          "reset": false
        },
        "batchSize": "=1"
      },
      "executeOnce": false,
      "typeVersion": 3
    },
    {
      "id": "dfa88c15-4d38-4670-9c5a-4e52a9ce9d33",
      "name": "Edit Fields-file_name",
      "type": "n8n-nodes-base.set",
      "position": [
        420,
        -20
      ],
      "parameters": {
        "options": {},
        "assignments": {
          "assignments": [
            {
              "id": "10e6d39e-c44c-4db4-bf88-806b2f36c09f",
              "name": "file_name",
              "type": "string",
              "value": "={{ $now.format("yyyyMMddHHmmSSS") }}"
            },
            {
              "id": "c2610584-aafa-4d90-8977-399e49015c32",
              "name": "b64_json",
              "type": "string",
              "value": "={{ $json.b64_json }}"
            }
          ]
        }
      },
      "typeVersion": 3.4
    },
    {
      "id": "c34c1a91-2601-4750-8134-d31cf377c349",
      "name": "Edit Fields1",
      "type": "n8n-nodes-base.set",
      "position": [
        1080,
        -20
      ],
      "parameters": {
        "options": {},
        "assignments": {
          "assignments": [
            {
              "id": "dcfa49d6-a8ed-43a2-9aaa-86751f34e61d",
              "name": "id",
              "type": "string",
              "value": "={{ $json.id }}"
            },
            {
              "id": "d2f7f22d-9453-4b61-bd46-fb3e8d5ad4d8",
              "name": "webViewLink",
              "type": "string",
              "value": "={{ $json.webViewLink }}"
            },
            {
              "id": "b8cf5a41-e354-416e-b548-8d1a274873e0",
              "name": "thumbnailLink",
              "type": "string",
              "value": "={{ $json.thumbnailLink }}"
            },
            {
              "id": "76c11a24-087c-4a6c-a5b4-8901e9436786",
              "name": "file_name",
              "type": "string",
              "value": "={{ $('Edit Fields-file_name').item.json.file_name }}"
            }
          ]
        }
      },
      "typeVersion": 3.4
    },
    {
      "id": "6bd8f7dc-1006-4d7f-b3eb-0a3aaa1b9a84",
      "name": "Google Sheets",
      "type": "n8n-nodes-base.googleSheets",
      "position": [
        1300,
        -20
      ],
      "parameters": {
        "columns": {
          "value": {
            "image": "={{ $json.webViewLink }}",
            "prompt": "={{ $('When chat message received').item.json.chatInput }}",
            "image_thumb": "==IMAGE("{{ $('Edit Fields1').item.json.thumbnailLink }}")"
          },
          "schema": [
            {
              "id": "prompt",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "prompt",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "image",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "image",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "image_thumb",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "image_thumb",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            }
          ],
          "mappingMode": "defineBelow",
          "matchingColumns": [],
          "attemptToConvertTypes": false,
          "convertFieldsToString": false
        },
        "options": {
          "cellFormat": "USER_ENTERED"
        },
        "operation": "append",
        "sheetName": {
          "__rl": true,
          "mode": "list",
          "value": "gid=0",
          "cachedResultUrl": "https://docs.google.com/spreadsheets/d/11K1tui8itMzcSZqHOmzvFnM0G-ihn1uiLUZ_o478j88/edit#gid=0",
          "cachedResultName": "u5de5u4f5cu88681"
        },
        "documentId": {
          "__rl": true,
          "mode": "list",
          "value": "11K1tui8itMzcSZqHOmzvFnM0G-ihn1uiLUZ_o478j88",
          "cachedResultUrl": "https://docs.google.com/spreadsheets/d/11K1tui8itMzcSZqHOmzvFnM0G-ihn1uiLUZ_o478j88/edit?usp=drivesdk",
          "cachedResultName": "n8n-chatgpt-image-1-model"
        }
      },
      "credentials": {
        "googleSheetsOAuth2Api": {
          "id": "tufEzuSTEveV3tuA",
          "name": "(Personal)Google Sheets account"
        }
      },
      "typeVersion": 4.5
    },
    {
      "id": "8ee28143-d9e7-4d14-929f-c9b6592c366e",
      "name": "When chat message received",
      "type": "@n8n/n8n-nodes-langchain.chatTrigger",
      "position": [
        -480,
        -45
      ],
      "webhookId": "f64b2006-672a-4ad6-8c30-428b76f5a332",
      "parameters": {
        "options": {}
      },
      "typeVersion": 1.1
    },
    {
      "id": "1e687fde-8465-4490-8738-c9832904f2b5",
      "name": "Google Sheets1",
      "type": "n8n-nodes-base.googleSheets",
      "position": [
        700,
        -400
      ],
      "parameters": {
        "columns": {
          "value": {
            "prompt": "={{ $('When chat message received').item.json.chatInput }}",
            "datetime": "={{ $('HTTP Request').item.json.created.toDateTime('s').format('yyyy-MM-dd HH:mm:ss') }}",
            "input token": "={{ $('HTTP Request').item.json.usage.input_tokens }}",
            "output token": "={{ $('HTTP Request').item.json.usage.output_tokens }}",
            "input estimated price": "={{    (     ($('HTTP Request').item.json.usage.input_tokens || 0) * 10 / 1000000   ).toFixed(6)  }}",
            "total estimated price": "={{ n  (n    (($('HTTP Request').item.json.usage.input_tokens || 0) * 10 / 1000000) +n    (($('HTTP Request').item.json.usage.output_tokens || 0) * 40 / 1000000)n  ).toFixed(6)n}}",
            "output estimated price": "={{    (     ($('HTTP Request').item.json.usage.output_tokens || 0) * 40 / 1000000   ).toFixed(6)  }}"
          },
          "schema": [
            {
              "id": "prompt",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "prompt",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "datetime",
              "type": "string",
              "display": true,
              "removed": false,
              "required": false,
              "displayName": "datetime",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "input token",
              "type": "string",
              "display": true,
              "removed": false,
              "required": false,
              "displayName": "input token",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "input estimated price",
              "type": "string",
              "display": true,
              "removed": false,
              "required": false,
              "displayName": "input estimated price",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "output token",
              "type": "string",
              "display": true,
              "removed": false,
              "required": false,
              "displayName": "output token",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "output estimated price",
              "type": "string",
              "display": true,
              "removed": false,
              "required": false,
              "displayName": "output estimated price",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "total estimated price",
              "type": "string",
              "display": true,
              "removed": false,
              "required": false,
              "displayName": "total estimated price",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            }
          ],
          "mappingMode": "defineBelow",
          "matchingColumns": [],
          "attemptToConvertTypes": false,
          "convertFieldsToString": false
        },
        "options": {},
        "operation": "append",
        "sheetName": {
          "__rl": true,
          "mode": "list",
          "value": 929800828,
          "cachedResultUrl": "https://docs.google.com/spreadsheets/d/11K1tui8itMzcSZqHOmzvFnM0G-ihn1uiLUZ_o478j88/edit#gid=929800828",
          "cachedResultName": "usage"
        },
        "documentId": {
          "__rl": true,
          "mode": "list",
          "value": "11K1tui8itMzcSZqHOmzvFnM0G-ihn1uiLUZ_o478j88",
          "cachedResultUrl": "https://docs.google.com/spreadsheets/d/11K1tui8itMzcSZqHOmzvFnM0G-ihn1uiLUZ_o478j88/edit?usp=drivesdk",
          "cachedResultName": "n8n-chatgpt-image-1-model"
        }
      },
      "credentials": {
        "googleSheetsOAuth2Api": {
          "id": "tufEzuSTEveV3tuA",
          "name": "(Personal)Google Sheets account"
        }
      },
      "typeVersion": 4.5
    },
    {
      "id": "5e1f6dd3-6c1a-4838-86c7-2a3c0cf05c3d",
      "name": "Aggregate",
      "type": "n8n-nodes-base.aggregate",
      "position": [
        480,
        -400
      ],
      "parameters": {
        "options": {},
        "aggregate": "aggregateAllItemData"
      },
      "typeVersion": 1
    },
    {
      "id": "f14edb71-0778-40dc-9f2d-4cfc72b8a351",
      "name": "Sticky Note4",
      "type": "n8n-nodes-base.stickyNote",
      "position": [
        -540,
        -600
      ],
      "parameters": {
        "color": 7,
        "width": 340,
        "height": 240,
        "content": "## Created by darrell_tw_ nnAn engineer now focus on AI and Automationnn### contact me with following:n[X](https://x.com/darrell_tw_)n[Threads](https://www.threads.net/@darrell_tw_)n[Instagram](https://www.instagram.com/darrell_tw_/)n[Website](https://www.darrelltw.com/)"
      },
      "typeVersion": 1
    },
    {
      "id": "6bbe2346-287b-491d-bf20-a76d39a6e297",
      "name": "Sticky Note",
      "type": "n8n-nodes-base.stickyNote",
      "position": [
        -540,
        -340
      ],
      "parameters": {
        "width": 660,
        "height": 480,
        "content": "## Use Chat to input prompts for image generation"
      },
      "typeVersion": 1
    },
    {
      "id": "8dd6607a-16cf-424d-902a-04c43e68f424",
      "name": "Sticky Note1",
      "type": "n8n-nodes-base.stickyNote",
      "position": [
        160,
        -200
      ],
      "parameters": {
        "color": 2,
        "width": 1260,
        "height": 420,
        "content": "## Process image array data with LoopnRegardless of single or multiple imagesnThey will be in the data[] arraynJust use Loop to process themnnImages will be uploaded to Drive and saved as a row in the Sheet with links and thumbnails"
      },
      "typeVersion": 1
    },
    {
      "id": "f8d0819a-e38a-4f7a-aa79-594ebca465a0",
      "name": "Sticky Note2",
      "type": "n8n-nodes-base.stickyNote",
      "position": [
        400,
        -480
      ],
      "parameters": {
        "color": 6,
        "width": 480,
        "height": 260,
        "content": "## After processing, save Cost to Sheet"
      },
      "typeVersion": 1
    }
  ],
  "active": false,
  "pinData": {},
  "settings": {
    "executionOrder": "v1"
  },
  "versionId": "cf533114-4aa9-4b06-8247-3c06f9dcbc79",
  "connections": {
    "Aggregate": {
      "main": [
        [
          {
            "node": "Google Sheets1",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Split Out": {
      "main": [
        [
          {
            "node": "Loop Over Items",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Edit Fields1": {
      "main": [
        [
          {
            "node": "Google Sheets",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Google Drive": {
      "main": [
        [
          {
            "node": "Edit Fields1",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "HTTP Request": {
      "main": [
        [
          {
            "node": "Split Out",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Google Sheets": {
      "main": [
        [
          {
            "node": "Loop Over Items",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Convert to File": {
      "main": [
        [
          {
            "node": "Google Drive",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Loop Over Items": {
      "main": [
        [
          {
            "node": "Aggregate",
            "type": "main",
            "index": 0
          }
        ],
        [
          {
            "node": "Edit Fields-file_name",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Edit Fields-file_name": {
      "main": [
        [
          {
            "node": "Convert to File",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "When chat message received": {
      "main": [
        [
          {
            "node": "HTTP Request",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "When clicking 'Test workflow'": {
      "main": [
        [
          {
            "node": "HTTP Request",
            "type": "main",
            "index": 0
          }
        ]
      ]
    }
  }
}