Create a Secure MongoDB Data Retrieval API with Input Validation and HTTP Responses
Data Extraction from MongoDB
Overview This workflow exposes a public HTTP GET endpoint to read all documents from a MongoDB collection, with:
Strict validation of the collection name
Error handling with proper 4xx codes
Response formatting (e.g., _id → id) and a consistent 2XX JSON envelope
Workflow Steps Webhook Trigger: A public GET endpoint receives requests with the collection name as a parameter.
The workflow begins with a webhook that listens for incoming HTTP GET requests.
The endpoint follows this pattern:
https://{{your-n8n-instance}}/webhook-test/{{uuid>}}/:nameCollection
The :nameCollection parameter is passed directly in the URL and specifies the MongoDB collection to be queried.
Example: https://yourdomain.com/webhook-test/abcd1234/orders
would attempt to fetch all documents from the orders collection.
Validation: The collection name is checked against a set of rules to prevent invalid or unsafe queries.
Before querying the database, the collection name undergoes validation using a regular expression:
^(?!system.)[a-zA-Z0-9._]{1,120}$
Purpose of validation:
Blocks access to MongoDB’s reserved system.* collections.
Prevents injection attacks by ensuring only alphanumeric characters, underscores, and dots are allowed.
Enforces MongoDB’s length restrictions (max 120 characters).
This step ensures the workflow cannot be exploited with malicious input.
Conditional Check: If the validation fails, the workflow stops and returns an error message. If it succeeds, it continues.
The workflow checks if the collection name passes validation.
If valid ✅: proceeds to query MongoDB.
If invalid ❌: immediately returns a structured HTTP 400 response, adhering to RESTful standards:
{ "code": 400, "message": "{{ $json.message }}" }
MongoDB Query: The workflow connects to MongoDB and retrieves all documents from the specified collection.
To use the MongoDB node, a proper database connection must be configured in n8n. This is done through MongoDB Credentials in the node settings:
Create MongoDB Credentials in n8n
Go to n8n → Credentials → New.
Select MongoDB and Fill in the following fields:
Host: The MongoDB server hostname or IP (e.g., cluster0.mongodb.net).
Port: Default is 27017 for local deployments.
Database: Name of the database (e.g., myDatabase).
User: MongoDB username with read permissions.
Password: Corresponding password.
Connection Type: Standard for most cases, or Connection String if using a full URI.
Replica Set / SRV Record: Enable if using MongoDB Atlas or a replica cluster.
Using a Connection String (recommended for MongoDB Atlas)
Example URI:
mongodb+srv://<username>:<password>@cluster0.mongodb.net/myDatabase?retryWrites=true&w=majority
Paste this into the Connection String field when selecting "Connection String" as the type.
Verify the Connection
After saving, test the credentials to confirm n8n can connect successfully to your MongoDB instance.
Configure the MongoDB Node in the Workflow
Operation: Find (to fetch documents).
Collection: Dynamic value passed from the workflow (e.g., {{$json["nameCollection"]}}).
Query: Leave empty to fetch all documents, or define filters if needed.
Result: The MongoDB node will retrieve all documents from the specified collection and pass the dataset as JSON to the next node for processing.
Data Formatting: The retrieved documents are processed to adjust field names.
By default, MongoDB returns its unique identifier as _id.
To align with common API conventions, this step renames _id → id.
This small transformation simplifies downstream usage, making responses more intuitive for client applications.
Response: The cleaned dataset is returned as a structured JSON response to the original request.
The processed dataset is returned as the response to the original HTTP request.
Clients receive a clean JSON payload with the expected format and renamed identifiers.
Example response: [ { "id": "64f13c1e2f1a5e34d9b3e7f0", "name": "John Doe", "email": "john@example.com" }, { "id": "64f13c1e2f1a5e34d9b3e7f1", "name": "Jane Smith", "email": "jane@example.com" } ]
Workflow Summary
Webhook (GET) → Code (Validation) → IF (Validation Check) → MongoDB (Query) → Code (Transform IDs) → Respond to Webhook
Key Benefits ✅ Security-first design: prevents unauthorized access or injection attacks.
✅ Standards compliance: uses HTTP status codes (400) for invalid requests.
✅ Clean API response: transforms MongoDB’s native _id into a more user-friendly id.
✅ Scalability: ready for integration with any frontend, third-party service, or analytics pipeline.
Related Templates
USDT And TRC20 Wallet Tracker API Workflow for n8n
Overview This n8n workflow is specifically designed to monitor USDT TRC20 transactions within a specified wallet. It u...
Automate Daily Keyword Research with Google Sheets, Suggest API & Custom Search
Who's it for This workflow is perfect for SEO specialists, marketers, bloggers, and content creators who want to automa...
Bulk Automated Google Drive Files Sharing and Direct Download Link Generation
This N8N workflow automates the process of sharing files from Google Drive. It includes OAuth2 authentication, batch pro...
🔒 Please log in to import templates to n8n and favorite templates
Workflow Visualization
Loading...
Preparing workflow renderer
Comments (0)
Login to post comments