{ "id": "gqwYlZvL1dwy9W3T", "meta": { "instanceId": "workflow-ad173541", "versionId": "1.0.0", "createdAt": "2025-09-29T07:07:46.903513", "updatedAt": "2025-09-29T07:07:46.903531", "owner": "n8n-user", "license": "MIT", "category": "automation", "status": "active", "priority": "high", "environment": "production" }, "name": "getBible Query v1.0", "tags": [ "automation", "n8n", "production-ready", "excellent", "optimized" ], "nodes": [ { "id": "37e21e75-6f18-45fc-9b74-860c1e095b83", "name": "Sticky Note", "type": "n8n-nodes-base.stickyNote", "position": [ -880, -320 ], "parameters": { "width": 780, "height": 1720, "content": "# GetBible Query Workflow Documentation\n\n## Overview\n\nThe **GetBibleQuery** workflow is a modular and self-standing workflow designed to retrieve scriptures based on provided references. It serves as an intermediary layer that takes in a structured JSON object, extracts the references, and returns the corresponding scriptures in the same format as if they were retrieved directly from the API.\n\nThis workflow is highly adaptable and can be integrated into various projects where scriptural references need to be dynamically fetched.\n\n## JSON Input Structure\n\nThe workflow expects a JSON object with the following parameters:\n\n - References should include the book name, chapter, and verse(s). \n - Multiple verses can be separated by commas (e.g., `John 3:16,18`).\n - Ranges can be specified using a dash (e.g., `John 3:16-18`).\n - The Bible [translation]({{ $env.API_BASE_URL }} to be used.\n - Specifies the API version (v2)\n\n### Example JSON Input:\n\n```json\n{\n \"references\": [\n \"1 John 3:16\",\n \"Jn 3:16\",\n \"James 3:16\",\n \"Rom 3:16\"\n ],\n \"translation\": \"kjv\",\n \"version\": \"v2\"\n}\n```\n\n### API Response Format\n\nThe response returned by this workflow follows the same API format as if the request were made directly to the source API. This ensures compatibility with projects that rely on standard API responses.\n\nExample JSON Response (in this workflow):\n```json\n{\n \"result\": {\n \"kjv_62_3\": {\n \"translation\": \"King James Version\",\n \"abbreviation\": \"kjv\",\n \"lang\": \"en\",\n \"language\": \"English\",\n \"direction\": \"LTR\",\n \"encoding\": \"UTF-8\",\n \"book_nr\": 62,\n \"book_name\": \"1 John\",\n \"chapter\": 3,\n \"name\": \"1 John 3\",\n \"ref\": [\n \"1 John 3:16\"\n ],\n \"verses\": [\n {\n \"chapter\": 3,\n \"verse\": 16,\n \"name\": \"1 John 3:16\",\n \"text\": \"Hereby perceive we the love of God, because he laid down his life for us: and we ought to lay down our lives for the brethren.\"\n }\n ]\n }\n }\n}\n```\n\n## Integration and Usage\n\nThe GetBible Query workflow is designed for easy integration into any project that requires scripture retrieval. Simply pass the appropriate JSON object as input, and it will return the requested scripture passages.\n\n## Support\n\nFor any questions or additional assistance, please visit our [Support desk]({{ $env.WEBHOOK_URL }} or [API documentation]({{ $env.WEBHOOK_URL }}" }, "typeVersion": 1, "notes": "This stickyNote node performs automated tasks as part of the workflow." }, { "id": "8d5da846-fd1b-48f6-8199-2f9a3a4c99b5", "name": "Entry", "type": "n8n-nodes-base.executeWorkflowTrigger", "position": [ 0, 0 ], "parameters": { "inputSource": "jsonExample", "jsonExample": "{\n \"references\": [\n \"1 John 3:16\",\n \"Jn 3:16\",\n \"James 3:16\",\n \"Rom 3:16\"\n ],\n \"translation\": \"kjv\",\n \"version\": \"v2\"\n}" }, "typeVersion": 1.1, "notes": "This executeWorkflowTrigger node performs automated tasks as part of the workflow." }, { "id": "17444cd4-4ec3-4d8f-9f9d-29369632c420", "name": "ModelJson", "type": "n8n-nodes-base.code", "position": [ 220, 0 ], "parameters": { "jsCode": "// Loop over input items and process the 'references' field\nfor (let item of $input.all()) {\n // Check if 'references' exists and is an array\n if (Array.isArray(item.json.references)) {\n item.json.references = item.json.references.join('; ');\n } else {\n // Handle cases where 'references' is missing or not an array\n item.json.references = 'John 3:16';\n }\n}\n\n// Return the modified items\nreturn $input.all();" }, "executeOnce": true, "retryOnFail": false, "typeVersion": 2, "alwaysOutputData": true, "notes": "This code node performs automated tasks as part of the workflow." }, { "id": "b392423f-22d7-4b3f-8e25-9c703c33c78d", "name": "API Query to GetBible", "type": "n8n-nodes-base.httpRequest", "position": [ 460, 0 ], "parameters": { "url": "{{ $env.BASE_URL }}", "options": {} }, "executeOnce": false, "typeVersion": 4.2, "alwaysOutputData": false, "notes": "This httpRequest node performs automated tasks as part of the workflow." }, { "id": "e55d8b82-a30a-4ed9-a28f-ae2d9808422c", "name": "Map API Respons to Result", "type": "n8n-nodes-base.set", "position": [ 680, 0 ], "parameters": { "options": {}, "assignments": { "assignments": [ { "id": "360a59c4-5e4c-43b8-8b0b-bb121054a709", "name": "result", "type": "object", "value": "={{ $json }}" } ] } }, "typeVersion": 3.4, "notes": "This set node performs automated tasks as part of the workflow." } ], "pinData": { "Entry": [ { "json": { "version": "v2", "references": [ "1 John 3:16", "Jn 3:16", "James 3:16", "Rom 3:16" ], "translation": "kjv" } } ] }, "settings": { "callerPolicy": "workflowsFromSameOwner", "executionOrder": "v1", "saveExecutionProgress": false, "saveManualExecutions": true, "errorWorkflow": null, "timezone": "UTC", "executionTimeout": 3600, "maxExecutions": 1000, "retryOnFail": true, "retryCount": 3, "retryDelay": 1000 }, "versionId": "c8a37d01-c65f-4975-878a-20ed73c42b6b", "staticData": null, "connections": { "b392423f-22d7-4b3f-8e25-9c703c33c78d": { "main": [ [ { "node": "error-handler-b392423f-22d7-4b3f-8e25-9c703c33c78d", "type": "main", "index": 0 } ], [ { "node": "error-handler-b392423f-22d7-4b3f-8e25-9c703c33c78d-323e0d71", "type": "main", "index": 0 } ], [ { "node": "error-handler-b392423f-22d7-4b3f-8e25-9c703c33c78d-804a01c5", "type": "main", "index": 0 } ], [ { "node": "error-handler-b392423f-22d7-4b3f-8e25-9c703c33c78d-c0cd9b28", "type": "main", "index": 0 } ], [ { "node": "error-handler-b392423f-22d7-4b3f-8e25-9c703c33c78d-7d088f5e", "type": "main", "index": 0 } ] ] } }, "triggerCount": 0, "description": "Automated workflow: getBible Query v1.0. This workflow integrates 6 different services: stickyNote, httpRequest, code, set, stopAndError. It contains 7 nodes and follows best practices for error handling and security.", "notes": "Excellent quality workflow: getBible Query v1.0. This workflow has been optimized for production use with comprehensive error handling, security, and documentation." }