feat: initialize multi-platform Family Organizer application with Flutter frontend and Node.js backend services
This commit is contained in:
101
backend/dist/controller/AuthController.js
vendored
Normal file
101
backend/dist/controller/AuthController.js
vendored
Normal file
@@ -0,0 +1,101 @@
|
||||
"use strict";
|
||||
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
||||
if (k2 === undefined) k2 = k;
|
||||
var desc = Object.getOwnPropertyDescriptor(m, k);
|
||||
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
||||
desc = { enumerable: true, get: function() { return m[k]; } };
|
||||
}
|
||||
Object.defineProperty(o, k2, desc);
|
||||
}) : (function(o, m, k, k2) {
|
||||
if (k2 === undefined) k2 = k;
|
||||
o[k2] = m[k];
|
||||
}));
|
||||
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
||||
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
||||
}) : function(o, v) {
|
||||
o["default"] = v;
|
||||
});
|
||||
var __importStar = (this && this.__importStar) || (function () {
|
||||
var ownKeys = function(o) {
|
||||
ownKeys = Object.getOwnPropertyNames || function (o) {
|
||||
var ar = [];
|
||||
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
||||
return ar;
|
||||
};
|
||||
return ownKeys(o);
|
||||
};
|
||||
return function (mod) {
|
||||
if (mod && mod.__esModule) return mod;
|
||||
var result = {};
|
||||
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
||||
__setModuleDefault(result, mod);
|
||||
return result;
|
||||
};
|
||||
})();
|
||||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
||||
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
||||
return new (P || (P = Promise))(function (resolve, reject) {
|
||||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
||||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
||||
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||
});
|
||||
};
|
||||
var __importDefault = (this && this.__importDefault) || function (mod) {
|
||||
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||
};
|
||||
var _a;
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.AuthController = void 0;
|
||||
const data_source_1 = require("../data-source");
|
||||
const User_1 = require("../entity/User");
|
||||
const bcrypt = __importStar(require("bcrypt"));
|
||||
const jwt = __importStar(require("jsonwebtoken"));
|
||||
const dotenv_1 = __importDefault(require("dotenv"));
|
||||
dotenv_1.default.config();
|
||||
class AuthController {
|
||||
}
|
||||
exports.AuthController = AuthController;
|
||||
_a = AuthController;
|
||||
AuthController.register = (req, res) => __awaiter(void 0, void 0, void 0, function* () {
|
||||
const { email, password } = req.body;
|
||||
if (!email || !password) {
|
||||
return res.status(400).send({ message: "Email and password are required" });
|
||||
}
|
||||
const userRepository = data_source_1.AppDataSource.getRepository(User_1.User);
|
||||
// Check if user already exists
|
||||
const existingUser = yield userRepository.findOneBy({ email });
|
||||
if (existingUser) {
|
||||
return res.status(409).send({ message: "User already exists" });
|
||||
}
|
||||
const user = new User_1.User();
|
||||
user.email = email;
|
||||
user.password = bcrypt.hashSync(password, 10);
|
||||
try {
|
||||
yield userRepository.save(user);
|
||||
res.status(201).send({ message: "User created" });
|
||||
}
|
||||
catch (e) {
|
||||
res.status(500).send({ message: "Error creating user" });
|
||||
}
|
||||
});
|
||||
AuthController.login = (req, res) => __awaiter(void 0, void 0, void 0, function* () {
|
||||
const { email, password } = req.body;
|
||||
if (!email || !password) {
|
||||
return res.status(400).send({ message: "Email and password are required" });
|
||||
}
|
||||
const userRepository = data_source_1.AppDataSource.getRepository(User_1.User);
|
||||
let user;
|
||||
try {
|
||||
user = yield userRepository.findOneBy({ email });
|
||||
}
|
||||
catch (error) {
|
||||
return res.status(500).send({ message: "Internal server error" });
|
||||
}
|
||||
if (!user || !bcrypt.compareSync(password, user.password)) {
|
||||
return res.status(401).send({ message: "Invalid credentials" });
|
||||
}
|
||||
// Sign JWT
|
||||
const token = jwt.sign({ userId: user.id, email: user.email }, process.env.JWT_SECRET || "default_secret", { expiresIn: "1h" });
|
||||
res.send({ token });
|
||||
});
|
||||
113
backend/dist/controller/ShoppingItemController.js
vendored
Normal file
113
backend/dist/controller/ShoppingItemController.js
vendored
Normal file
@@ -0,0 +1,113 @@
|
||||
"use strict";
|
||||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
||||
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
||||
return new (P || (P = Promise))(function (resolve, reject) {
|
||||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
||||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
||||
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||
});
|
||||
};
|
||||
var _a;
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.ShoppingItemController = void 0;
|
||||
const data_source_1 = require("../data-source");
|
||||
const ShoppingList_1 = require("../entity/ShoppingList");
|
||||
const ShoppingItem_1 = require("../entity/ShoppingItem");
|
||||
const User_1 = require("../entity/User");
|
||||
class ShoppingItemController {
|
||||
}
|
||||
exports.ShoppingItemController = ShoppingItemController;
|
||||
_a = ShoppingItemController;
|
||||
ShoppingItemController.newItem = (req, res) => __awaiter(void 0, void 0, void 0, function* () {
|
||||
const listId = parseInt(req.params.listId);
|
||||
const { name, quantity } = req.body;
|
||||
const userId = res.locals.jwtPayload.userId;
|
||||
if (!name)
|
||||
return res.status(400).send("Name is required");
|
||||
const listRepository = data_source_1.AppDataSource.getRepository(ShoppingList_1.ShoppingList);
|
||||
let list;
|
||||
try {
|
||||
list = yield listRepository.findOne({ where: { id: listId }, relations: ["owner"] });
|
||||
}
|
||||
catch (e) {
|
||||
return res.status(500).send("Error finding list");
|
||||
}
|
||||
if (!list)
|
||||
return res.status(404).send("List not found");
|
||||
// Optional: Check if user has access to this list (for now list owner only)
|
||||
if (list.owner.id !== userId)
|
||||
return res.status(403).send("No access to this list");
|
||||
const item = new ShoppingItem_1.ShoppingItem();
|
||||
item.name = name;
|
||||
item.quantity = quantity || 1;
|
||||
item.list = list;
|
||||
// createdBy
|
||||
const userRepository = data_source_1.AppDataSource.getRepository(User_1.User);
|
||||
const user = yield userRepository.findOneBy({ id: userId });
|
||||
if (user)
|
||||
item.createdBy = user;
|
||||
const itemRepository = data_source_1.AppDataSource.getRepository(ShoppingItem_1.ShoppingItem);
|
||||
try {
|
||||
yield itemRepository.save(item);
|
||||
res.status(201).send(item);
|
||||
}
|
||||
catch (e) {
|
||||
res.status(500).send("Error creating item");
|
||||
}
|
||||
});
|
||||
ShoppingItemController.editItem = (req, res) => __awaiter(void 0, void 0, void 0, function* () {
|
||||
const id = parseInt(req.params.id);
|
||||
const { name, quantity, isChecked } = req.body;
|
||||
const itemRepository = data_source_1.AppDataSource.getRepository(ShoppingItem_1.ShoppingItem);
|
||||
let item;
|
||||
try {
|
||||
item = yield itemRepository.findOne({ where: { id }, relations: ["list", "list.owner"] });
|
||||
}
|
||||
catch (e) {
|
||||
return res.status(500).send("Error finding item");
|
||||
}
|
||||
if (!item)
|
||||
return res.status(404).send("Item not found");
|
||||
// Check access
|
||||
const userId = res.locals.jwtPayload.userId;
|
||||
if (item.list.owner.id !== userId)
|
||||
return res.status(403).send("No access");
|
||||
if (name !== undefined)
|
||||
item.name = name;
|
||||
if (quantity !== undefined)
|
||||
item.quantity = quantity;
|
||||
if (isChecked !== undefined)
|
||||
item.isChecked = isChecked;
|
||||
try {
|
||||
yield itemRepository.save(item);
|
||||
res.send(item);
|
||||
}
|
||||
catch (e) {
|
||||
res.status(500).send("Error updating item");
|
||||
}
|
||||
});
|
||||
ShoppingItemController.deleteItem = (req, res) => __awaiter(void 0, void 0, void 0, function* () {
|
||||
const id = parseInt(req.params.id);
|
||||
const itemRepository = data_source_1.AppDataSource.getRepository(ShoppingItem_1.ShoppingItem);
|
||||
let item;
|
||||
try {
|
||||
item = yield itemRepository.findOne({ where: { id }, relations: ["list", "list.owner"] });
|
||||
}
|
||||
catch (e) {
|
||||
return res.status(500).send("Error finding item");
|
||||
}
|
||||
if (!item)
|
||||
return res.status(404).send("Item not found");
|
||||
// Check access
|
||||
const userId = res.locals.jwtPayload.userId;
|
||||
if (item.list.owner.id !== userId)
|
||||
return res.status(403).send("No access");
|
||||
try {
|
||||
yield itemRepository.remove(item);
|
||||
res.status(204).send();
|
||||
}
|
||||
catch (e) {
|
||||
res.status(500).send("Error deleting item");
|
||||
}
|
||||
});
|
||||
101
backend/dist/controller/ShoppingListController.js
vendored
Normal file
101
backend/dist/controller/ShoppingListController.js
vendored
Normal file
@@ -0,0 +1,101 @@
|
||||
"use strict";
|
||||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
||||
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
||||
return new (P || (P = Promise))(function (resolve, reject) {
|
||||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
||||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
||||
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||
});
|
||||
};
|
||||
var _a;
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.ShoppingListController = void 0;
|
||||
const data_source_1 = require("../data-source");
|
||||
const ShoppingList_1 = require("../entity/ShoppingList");
|
||||
const User_1 = require("../entity/User");
|
||||
class ShoppingListController {
|
||||
}
|
||||
exports.ShoppingListController = ShoppingListController;
|
||||
_a = ShoppingListController;
|
||||
ShoppingListController.listAll = (req, res) => __awaiter(void 0, void 0, void 0, function* () {
|
||||
const userId = res.locals.jwtPayload.userId;
|
||||
const listRepository = data_source_1.AppDataSource.getRepository(ShoppingList_1.ShoppingList);
|
||||
try {
|
||||
const lists = yield listRepository.find({
|
||||
where: { owner: { id: userId } },
|
||||
relations: ["items"]
|
||||
});
|
||||
res.send(lists);
|
||||
}
|
||||
catch (error) {
|
||||
res.status(500).send("Error fetching lists");
|
||||
}
|
||||
});
|
||||
ShoppingListController.getOneById = (req, res) => __awaiter(void 0, void 0, void 0, function* () {
|
||||
const id = parseInt(req.params.id);
|
||||
const userId = res.locals.jwtPayload.userId;
|
||||
const listRepository = data_source_1.AppDataSource.getRepository(ShoppingList_1.ShoppingList);
|
||||
try {
|
||||
const list = yield listRepository.findOne({
|
||||
where: { id: id, owner: { id: userId } },
|
||||
relations: ["items"]
|
||||
});
|
||||
if (list) {
|
||||
res.send(list);
|
||||
}
|
||||
else {
|
||||
res.status(404).send("List not found");
|
||||
}
|
||||
}
|
||||
catch (error) {
|
||||
res.status(500).send("Error fetching list");
|
||||
}
|
||||
});
|
||||
ShoppingListController.new = (req, res) => __awaiter(void 0, void 0, void 0, function* () {
|
||||
const { name } = req.body;
|
||||
const userId = res.locals.jwtPayload.userId;
|
||||
if (!name) {
|
||||
return res.status(400).send("Name is required");
|
||||
}
|
||||
const list = new ShoppingList_1.ShoppingList();
|
||||
list.name = name;
|
||||
// Assign owner
|
||||
const userRepository = data_source_1.AppDataSource.getRepository(User_1.User);
|
||||
let user;
|
||||
try {
|
||||
user = yield userRepository.findOneBy({ id: userId });
|
||||
}
|
||||
catch (e) {
|
||||
return res.status(500).send("Error finding user");
|
||||
}
|
||||
if (!user)
|
||||
return res.status(404).send("User not found");
|
||||
list.owner = user;
|
||||
const listRepository = data_source_1.AppDataSource.getRepository(ShoppingList_1.ShoppingList);
|
||||
try {
|
||||
yield listRepository.save(list);
|
||||
res.status(201).send(list);
|
||||
}
|
||||
catch (e) {
|
||||
res.status(500).send("Error creating list");
|
||||
}
|
||||
});
|
||||
ShoppingListController.delete = (req, res) => __awaiter(void 0, void 0, void 0, function* () {
|
||||
const id = parseInt(req.params.id);
|
||||
const userId = res.locals.jwtPayload.userId;
|
||||
const listRepository = data_source_1.AppDataSource.getRepository(ShoppingList_1.ShoppingList);
|
||||
try {
|
||||
const list = yield listRepository.findOne({
|
||||
where: { id: id, owner: { id: userId } }
|
||||
});
|
||||
if (!list) {
|
||||
return res.status(404).send("List not found");
|
||||
}
|
||||
yield listRepository.remove(list);
|
||||
res.status(204).send();
|
||||
}
|
||||
catch (e) {
|
||||
res.status(500).send("Error deleting list");
|
||||
}
|
||||
});
|
||||
Reference in New Issue
Block a user