feat: complete day 14

This commit is contained in:
Ayobami
2025-07-18 20:12:09 +01:00
parent 7d9350c3df
commit 9113ba4c74
12 changed files with 437 additions and 43 deletions
+74
View File
@@ -0,0 +1,74 @@
const fs = require("fs");
const path = require("path");
class ControllerBuilder {
static build() {
const config = require("./configuration.json");
const controllerDir = path.join(__dirname, "release/controllers");
// Create release/controllers directory
if (!fs.existsSync(controllerDir))
fs.mkdirSync(controllerDir, { recursive: true });
config.model.forEach((model) => {
const controllerCode = `const express = require('express');
const router = express.Router();
const model = require('../models/${model.name}.model.js');
// CREATE
router.post('/', async (req, res) => {
try {
const data = await model.create(req.body);
res.status(201).json(data);
} catch (error) {
res.status(400).json({ error: error.message });
}
});
// READ ALL
router.get('/', async (req, res) => {
try {
const data = await model.findAll();
res.json(data);
} catch (error) {
res.status(500).json({ error: error.message });
}
});
// UPDATE
router.put('/:id', async (req, res) => {
try {
const updated = await model.update(req.body, {
where: { id: req.params.id }
});
if (updated[0] === 0) return res.status(404).json({ error: 'Not found' });
res.json(await model.findByPk(req.params.id));
} catch (error) {
res.status(400).json({ error: error.message });
}
});
// DELETE
router.delete('/:id', async (req, res) => {
try {
const deleted = await model.destroy({
where: { id: req.params.id }
});
if (!deleted) return res.status(404).json({ error: 'Not found' });
res.status(204).send();
} catch (error) {
res.status(500).json({ error: error.message });
}
});
module.exports = router;`;
fs.writeFileSync(
path.join(controllerDir, `${model.name}.controller.js`),
controllerCode
);
});
}
}
module.exports = ControllerBuilder;
+34 -9
View File
@@ -1,13 +1,38 @@
let fs = require('fs'); const fs = require("fs");
const path = require("path");
function Model_builder() { class ModelBuilder {
let config = fs.readFileSync('configuration.json'); static build() {
const config = require("./configuration.json");
const modelDir = path.join(__dirname, "release/models");
this.build = function () { // Create release/models directory
//generate files and put it into release folder if (!fs.existsSync(modelDir)) fs.mkdirSync(modelDir, { recursive: true });
//Copy initialize files into release folder
//TODO config.model.forEach((model) => {
const modelCode = `const { DataTypes } = require('sequelize');
module.exports = (sequelize) => {
return sequelize.define('${model.name}', {
${model.field
.map(
(field) => `
${field[0]}: {
type: DataTypes.${field[1].toUpperCase()},
allowNull: ${field[3] === "required" ? "false" : "true"}
}`
)
.join(",")}
}, {
timestamps: true
});
};`;
fs.writeFileSync(
path.join(modelDir, `${model.name}.model.js`),
modelCode
);
});
} }
return this;
} }
module.exports = ModelBuilder;
+34 -34
View File
@@ -1,37 +1,37 @@
{ {
"model": [ "model": [
{ {
"name": "location", "name": "location",
"field: [ "field": [
["id", "integer", "ID", "required"], ["id", "integer", "ID", "required"],
["name", "string", "Name", "required"], ["name", "string", "Name", "required"],
["status", "integer", "Status", "required"], ["status", "integer", "Status", "required"]
]
},
{
"name": "email",
"field": [
["id", "integer", "ID", "required"],
["email", "string", "Email", "required"],
["status", "integer", "Status", "required"]
]
},
{
"name": "sms",
"field": [
["id", "integer", "ID", "required"],
["phone", "string", "Phone", "required"],
["status", "integer", "Status", "required"]
]
},
{
"name": "user",
"field": [
["id", "integer", "ID", "required"],
["name", "string", "Name", "required"],
["email", "string", "Email", "required"],
["status", "integer", "Status", "required"]
]
}
] ]
},
{
"name": "email",
"field: [
["id", "integer", "ID", "required"],
["email", "string", "Email", "required"],
["status", "integer", "Status", "required"],
]
},
{
"name": "sms",
"field: [
["id", "integer", "ID", "required"],
["phone", "string", "Phone", "required"],
["status", "integer", "Status", "required"],
]
},
{
"name": "user",
"field: [
["id", "integer", "ID", "required"],
["name", "string", "Name", "required"],
["email", "string", "Email", "required"],
["status", "integer", "Status", "required"],
]
}
]
} }
+7
View File
@@ -0,0 +1,7 @@
const Model_builder = require("./Model_builder");
const Controller_builder = require("./Controller_builder");
Model_builder.build();
Controller_builder.build();
console.log("Model and controller files generated in /release");
@@ -0,0 +1,51 @@
const express = require('express');
const router = express.Router();
const model = require('../models/email.model.js');
// CREATE
router.post('/', async (req, res) => {
try {
const data = await model.create(req.body);
res.status(201).json(data);
} catch (error) {
res.status(400).json({ error: error.message });
}
});
// READ ALL
router.get('/', async (req, res) => {
try {
const data = await model.findAll();
res.json(data);
} catch (error) {
res.status(500).json({ error: error.message });
}
});
// UPDATE
router.put('/:id', async (req, res) => {
try {
const updated = await model.update(req.body, {
where: { id: req.params.id }
});
if (updated[0] === 0) return res.status(404).json({ error: 'Not found' });
res.json(await model.findByPk(req.params.id));
} catch (error) {
res.status(400).json({ error: error.message });
}
});
// DELETE
router.delete('/:id', async (req, res) => {
try {
const deleted = await model.destroy({
where: { id: req.params.id }
});
if (!deleted) return res.status(404).json({ error: 'Not found' });
res.status(204).send();
} catch (error) {
res.status(500).json({ error: error.message });
}
});
module.exports = router;
@@ -0,0 +1,51 @@
const express = require('express');
const router = express.Router();
const model = require('../models/location.model.js');
// CREATE
router.post('/', async (req, res) => {
try {
const data = await model.create(req.body);
res.status(201).json(data);
} catch (error) {
res.status(400).json({ error: error.message });
}
});
// READ ALL
router.get('/', async (req, res) => {
try {
const data = await model.findAll();
res.json(data);
} catch (error) {
res.status(500).json({ error: error.message });
}
});
// UPDATE
router.put('/:id', async (req, res) => {
try {
const updated = await model.update(req.body, {
where: { id: req.params.id }
});
if (updated[0] === 0) return res.status(404).json({ error: 'Not found' });
res.json(await model.findByPk(req.params.id));
} catch (error) {
res.status(400).json({ error: error.message });
}
});
// DELETE
router.delete('/:id', async (req, res) => {
try {
const deleted = await model.destroy({
where: { id: req.params.id }
});
if (!deleted) return res.status(404).json({ error: 'Not found' });
res.status(204).send();
} catch (error) {
res.status(500).json({ error: error.message });
}
});
module.exports = router;
@@ -0,0 +1,51 @@
const express = require('express');
const router = express.Router();
const model = require('../models/sms.model.js');
// CREATE
router.post('/', async (req, res) => {
try {
const data = await model.create(req.body);
res.status(201).json(data);
} catch (error) {
res.status(400).json({ error: error.message });
}
});
// READ ALL
router.get('/', async (req, res) => {
try {
const data = await model.findAll();
res.json(data);
} catch (error) {
res.status(500).json({ error: error.message });
}
});
// UPDATE
router.put('/:id', async (req, res) => {
try {
const updated = await model.update(req.body, {
where: { id: req.params.id }
});
if (updated[0] === 0) return res.status(404).json({ error: 'Not found' });
res.json(await model.findByPk(req.params.id));
} catch (error) {
res.status(400).json({ error: error.message });
}
});
// DELETE
router.delete('/:id', async (req, res) => {
try {
const deleted = await model.destroy({
where: { id: req.params.id }
});
if (!deleted) return res.status(404).json({ error: 'Not found' });
res.status(204).send();
} catch (error) {
res.status(500).json({ error: error.message });
}
});
module.exports = router;
@@ -0,0 +1,51 @@
const express = require('express');
const router = express.Router();
const model = require('../models/user.model.js');
// CREATE
router.post('/', async (req, res) => {
try {
const data = await model.create(req.body);
res.status(201).json(data);
} catch (error) {
res.status(400).json({ error: error.message });
}
});
// READ ALL
router.get('/', async (req, res) => {
try {
const data = await model.findAll();
res.json(data);
} catch (error) {
res.status(500).json({ error: error.message });
}
});
// UPDATE
router.put('/:id', async (req, res) => {
try {
const updated = await model.update(req.body, {
where: { id: req.params.id }
});
if (updated[0] === 0) return res.status(404).json({ error: 'Not found' });
res.json(await model.findByPk(req.params.id));
} catch (error) {
res.status(400).json({ error: error.message });
}
});
// DELETE
router.delete('/:id', async (req, res) => {
try {
const deleted = await model.destroy({
where: { id: req.params.id }
});
if (!deleted) return res.status(404).json({ error: 'Not found' });
res.status(204).send();
} catch (error) {
res.status(500).json({ error: error.message });
}
});
module.exports = router;
+20
View File
@@ -0,0 +1,20 @@
const { DataTypes } = require('sequelize');
module.exports = (sequelize) => {
return sequelize.define('email', {
id: {
type: DataTypes.INTEGER,
allowNull: false
},
email: {
type: DataTypes.STRING,
allowNull: false
},
status: {
type: DataTypes.INTEGER,
allowNull: false
}
}, {
timestamps: true
});
};
+20
View File
@@ -0,0 +1,20 @@
const { DataTypes } = require('sequelize');
module.exports = (sequelize) => {
return sequelize.define('location', {
id: {
type: DataTypes.INTEGER,
allowNull: false
},
name: {
type: DataTypes.STRING,
allowNull: false
},
status: {
type: DataTypes.INTEGER,
allowNull: false
}
}, {
timestamps: true
});
};
+20
View File
@@ -0,0 +1,20 @@
const { DataTypes } = require('sequelize');
module.exports = (sequelize) => {
return sequelize.define('sms', {
id: {
type: DataTypes.INTEGER,
allowNull: false
},
phone: {
type: DataTypes.STRING,
allowNull: false
},
status: {
type: DataTypes.INTEGER,
allowNull: false
}
}, {
timestamps: true
});
};
+24
View File
@@ -0,0 +1,24 @@
const { DataTypes } = require('sequelize');
module.exports = (sequelize) => {
return sequelize.define('user', {
id: {
type: DataTypes.INTEGER,
allowNull: false
},
name: {
type: DataTypes.STRING,
allowNull: false
},
email: {
type: DataTypes.STRING,
allowNull: false
},
status: {
type: DataTypes.INTEGER,
allowNull: false
}
}, {
timestamps: true
});
};