Now supporting AI powered code snippet generation! π
Backend Generator CLI is a simple yet powerful command-line tool that helps you quickly scaffold a well-structured backend project. With built-in best practices and customizable code snippets, this tool is designed to streamline your development workflow and help you focus on what matters: building your application.
π Stars | π΄ Forks | π Issues | π Open PRs | π Closed PRs | π οΈ Languages | β Contributors |
---|---|---|---|---|---|---|
- Instant Backend Setup: Generate a clean, well-organized backend project structure with a single command.
- Best Practices Built-in: The generated project follows industry-standard best practices for scalable backend development.
- Custom Code Snippets: Insert predefined code snippets such as API error handling, file uploading, and more using simple CLI commands.
- AI-powered Custom Code Snippets: Generate customizable code snippets using Generative AI with simple CLI commands.
- Modular and Extensible: The tool allows you to customize and expand the project structure to meet your specific needs.
To install the CLI globally, use npm
:
npm install -g backend-generator-cli
After installation, you will have access to two main commands: create-project
to generate the backend structure and generate-snippet
to inject code snippets.
Generate a new backend project with a pre-configured folder structure:
run create-project
This command will create a new backend project structure in your current directory. Here's what the generated structure looks like:
.
βββ src/
β βββ controllers/ # Controllers for handling requests and responses
β βββ db/ # Database connection and configuration
β βββ middlewares/ # Middlewares for handling validation and request processing
β βββ models/ # Data models (e.g., Mongoose models, SQL models)
β βββ routes/ # API route definitions
β βββ utils/ # Utility functions and helpers
β βββ app.js # Main app setup and configuration
β βββ constants.js # Application-wide constants
β βββ index.js # Entry point of the backend server
βββ .env.sample # Sample environment configuration
βββ .gitignore # Git ignore file for version control
βββ .prettierignore # Prettier ignore file
βββ .prettierrc # Prettier configuration
βββ package.json # Project dependencies and scripts
βββ README.md # Documentation
This structure is clean, easy to navigate, and ready to be extended with your own business logic and data models.
Generate and inject predefined code snippets into your project. Snippets are placed in individual files in your current working directory.
Example:
run generate-snippet multer-file-upload
This command will create a new file multer-file-upload.js
in the current working directory, containing a pre-configured snippet for handling file uploads using multer
.
-
express-server
: Sets up express server.Code Snippet:
import express from "express"; const app = express(); const PORT = process.env.PORT || 3000; app.listen(PORT, () => console.log(`Server started at ${PORT}`));
2. **`async-ops-handler`**:
Handles asynchronous operations with error handling.
**Code Snippet**:
```js
const asyncHandler = (requestHandler) => {
return (req, res, next) => {
Promise.resolve(requestHandler(req, res, next)).catch((err) => next(err));
};
};
export { asyncHandler };
```
3. **`custom-api-error`**:
Standardizes error responses for your API.
**Code Snippet**:
```js
class ApiError extends Error {
constructor(statusCode, message = 'Something went wrong', errors = [], stack = '') {
super(message);
this.statusCode = statusCode;
this.message = message;
this.data = null;
this.errors = errors;
if (stack) {
this.stack = stack;
} else {
Error.captureStackTrace(this, this.constructor);
}
}
}
export { ApiError };
```
4. **`custom-api-response`**:
Standardizes successful API responses.
**Code Snippet**:
```js
class ApiResponse {
constructor(statusCode, message = 'success', data) {
this.statusCode = statusCode;
this.message = message;
this.data = data;
this.success = statusCode < 400;
}
}
export { ApiResponse };
```
5. **`multer-file-upload`**:
Sets up a file upload service using `multer`.
**Code Snippet**:
```js
import multer from 'multer';
const storage = multer.diskStorage({
destination: function (req, file, cb) {
cb(null, './public/temp');
},
filename: function (req, file, cb) {
cb(null, file.originalname);
},
});
export const upload = multer({ storage });
-
mongoose-con
: Sets up a connection to your mongodb usingmongoose
.Code Snippet:
import mongoose from 'mongoose'; function connectToDB(URI) { mongoose .connect(URI) .then(() => { console.log('Connection to the db succesful'); }) .catch((err) => { console.error('An error occcured : ', err); }); } export default connectToDB;
-
mongoose-schema
: Sets up a basic schema for your db usingmongoose
.Code Snippet:
import mongoose from 'mongoose'; const schema = new mongoose.Schema({ key: String, }); const model = mongoose.model('Model', schema); export default model;
-
nodemailer
: Sets up email functionality in Node.js projectsCode Snippet:
const nodemailer = require('nodemailer'); require('dotenv').config(); const transporter = nodemailer.createTransport({ service: 'gmail', auth: { user: process.env.EMAIL, pass: process.env.EMAIL_PASSWORD, }, }); const mailOptions = { from: process.env.EMAIL, to: 'recipient@example.com', subject: 'Hello from Nodemailer', text: 'This is a plain text body!', html: '<p>This is an <b>HTML</b> body!</p>', }; transporter.sendMail(mailOptions, (error, info) => { if (error) { return console.log(error); } console.log('Email sent: ' + info.response); });
-
cloudinary-util
Sets up Cloudinary functionality in a Node.js projectCode Snippet:
import { v2 as cloudinary } from 'cloudinary'; import fs from 'fs'; // These values need to be defined in your environment variables (usually in a .env file) cloudinary.config({ cloud_name: process.env.CLOUDINARY_CLOUD_NAME, api_key: process.env.CLOUDINARY_API_KEY, api_secret: process.env.CLOUDINARY_API_SECRET, }); const uploadOnCloudinary = async (localFilePath) => { try { if (!localFilePath) return null; const response = await cloudinary.uploader.upload(localFilePath, { resource_type: 'auto', }); fs.unlinkSync(localFilePath); return response; } catch (error) { fs.unlinkSync(localFilePath); return null; } }; export { uploadOnCloudinary };
With the new AI-powered code generation feature, you can generate customized code snippets. For instance, to generate a code snippet for a specific backend functionality, you can run:
run generate-ai-snippet <snippetName>
Example:
run generate-ai-snippet login-controller
This will generate a code snippet for login-controller using AI that looks like :
Generated Code Snippet for login-controller:
const User = require('../models/User');
const bcrypt = require('bcrypt');
const jwt = require('jsonwebtoken');
module.exports.login = async (req, res) => {
try {
const { email, password } = req.body;
const user = await User.findOne({ email });
if (!user) {
return res.status(401).json({ message: 'Invalid credentials' });
}
const isMatch = await bcrypt.compare(password, user.password);
if (!isMatch) {
return res.status(401).json({ message: 'Invalid credentials' });
}
const token = jwt.sign({ userId: user._id }, process.env.JWT_SECRET, { expiresIn: '1h' });
res.json({ token, user: { _id: user._id, name: user.name, email: user.email } });
} catch (err) {
console.error(err);
res.status(500).json({ message: 'Server error' });
}
};
The code snippet is generated successfuly and may require some modifications to fit your use case.
Hereβs a complete example of a user journey, from project setup to injecting code snippets into the project.
First, install the tool using npm:
npm install -g backend-generator-cli
Navigate to your desired directory and run the following command to generate the project structure:
run create-project
This will create a new backend project with the following structure:
.
βββ src/
β βββ controllers/
β βββ db/
β βββ middlewares/
β βββ models/
β βββ routes/
β βββ utils/
β βββ app.js
β βββ constants.js
β βββ index.js
βββ .env.sample
βββ .gitignore
βββ .prettierignore
βββ .prettierrc
βββ package.json
βββ README.md
Change your working directory to the src/utils
folder:
cd src
cd utils
You are now inside the utils
folder where you will generate the file upload handler snippet.
Next, add a multer
file upload handler by running the following command:
run generate-snippet multer-file-upload
This command will create a new file called multer-file-upload.js
in the src/utils
directory, which is now your current working directory. The content of this file will look like this:
import multer from 'multer';
const storage = multer.diskStorage({
destination: function (req, file, cb) {
cb(null, './public/temp');
},
filename: function (req, file, cb) {
cb(null, file.originalname);
},
});
export const upload = multer({ storage });
Now that the file upload handler has been generated in the utils
folder, you can import and use it in your application. For instance, in src/routes/uploadRoute.js
:
import express from 'express';
import { upload } from '../utils/multer-file-upload';
const router = express.Router();
router.post('/upload', upload.single('file'), (req, res) => {
res.send('File uploaded successfully');
});
export default router;
Make sure that your main app.js
or index.js
includes this route:
import express from 'express';
import uploadRoute from './routes/uploadRoute';
const app = express();
app.use('/api', uploadRoute);
app.listen(3000, () => {
console.log('Server is running on port 3000');
});
Continue building your application by adding your business logic, routes, controllers, and any other necessary components. Feel free to generate additional snippets like custom-api-error
and async-ops-handler
as needed.
This flow demonstrates how you can set up your backend project structure and utilize the code snippets generated by backend-generator-cli
to accelerate your development.
- Add more predefined snippets for common backend use cases.
- Add a controller to get the most in-demand snippets.
- We extend our heartfelt gratitude for your invaluable contribution to our project! Your efforts play a pivotal role in elevating this project to greater heights.
- Make sure you show some love by giving β to our repository.
This project is licensed under the MIT License. See the LICENSE file for more details.