[MAJOR][FIRSTCOMMIT] Added basic routes, controllers, repos to kanban service (no postgres yet)
This commit is contained in:
52
lib/repos/BoardRepo.js
Normal file
52
lib/repos/BoardRepo.js
Normal file
@@ -0,0 +1,52 @@
|
||||
"use strict";
|
||||
var __importDefault = (this && this.__importDefault) || function (mod) {
|
||||
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||
};
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
const MockOrm_1 = __importDefault(require("./MockOrm"));
|
||||
async function getBoardsByUserId(userId) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
return db.boards.filter((board) => board.userId === userId);
|
||||
}
|
||||
async function getBoardByUserId(userId, boardId) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
return db.boards.find((board) => board.userId === userId && board.id === boardId) || null;
|
||||
}
|
||||
async function createBoard(userId, board) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
board.id = Date.now();
|
||||
board.userId = userId;
|
||||
board.createdAt = new Date().toISOString();
|
||||
board.updatedAt = board.createdAt;
|
||||
db.boards.push(board);
|
||||
await MockOrm_1.default.saveDb(db);
|
||||
return board;
|
||||
}
|
||||
async function updateBoard(userId, boardId, boardData) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
const board = db.boards.find((b) => b.userId === userId && b.id === boardId);
|
||||
if (board) {
|
||||
Object.assign(board, boardData, { updatedAt: new Date().toISOString() });
|
||||
await MockOrm_1.default.saveDb(db);
|
||||
return board;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
async function deleteBoard(userId, boardId) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
const idx = db.boards.findIndex((b) => b.userId === userId && b.id === boardId);
|
||||
if (idx !== -1) {
|
||||
db.boards.splice(idx, 1);
|
||||
await MockOrm_1.default.saveDb(db);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
exports.default = {
|
||||
getBoardsByUserId,
|
||||
getBoardByUserId,
|
||||
createBoard,
|
||||
updateBoard,
|
||||
deleteBoard,
|
||||
};
|
||||
//# sourceMappingURL=BoardRepo.js.map
|
||||
1
lib/repos/BoardRepo.js.map
Normal file
1
lib/repos/BoardRepo.js.map
Normal file
@@ -0,0 +1 @@
|
||||
{"version":3,"file":"BoardRepo.js","sourceRoot":"","sources":["../../src/repos/BoardRepo.ts"],"names":[],"mappings":";;;;;AACA,wDAA4B;AAE5B,KAAK,UAAU,iBAAiB,CAAC,MAAc;IAC9C,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,OAAO,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,KAAa,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,KAAK,MAAM,CAAC,CAAC;AACrE,CAAC;AAED,KAAK,UAAU,gBAAgB,CAAC,MAAc,EAAE,OAAe;IAC9D,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,OAAO,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAa,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,KAAK,MAAM,IAAI,KAAK,CAAC,EAAE,KAAK,OAAO,CAAC,IAAI,IAAI,CAAC;AACnG,CAAC;AAED,KAAK,UAAU,WAAW,CAAC,MAAc,EAAE,KAAa;IACvD,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,KAAK,CAAC,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACtB,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;IACtB,KAAK,CAAC,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;IAC3C,KAAK,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC;IAClC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtB,MAAM,iBAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IACrB,OAAO,KAAK,CAAC;AACd,CAAC;AAED,KAAK,UAAU,WAAW,CAAC,MAAc,EAAE,OAAe,EAAE,SAA0B;IACrF,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,MAAM,KAAK,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,IAAI,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC,CAAC;IACrF,IAAI,KAAK,EAAE,CAAC;QACX,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;QACzE,MAAM,iBAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACrB,OAAO,KAAK,CAAC;IACd,CAAC;IACD,OAAO,IAAI,CAAC;AACb,CAAC;AAED,KAAK,UAAU,WAAW,CAAC,MAAc,EAAE,OAAe;IACzD,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,MAAM,GAAG,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,IAAI,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC,CAAC;IACxF,IAAI,GAAG,KAAK,CAAC,CAAC,EAAE,CAAC;QAChB,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QACzB,MAAM,iBAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACrB,OAAO,IAAI,CAAC;IACb,CAAC;IACD,OAAO,KAAK,CAAC;AACd,CAAC;AAED,kBAAe;IACd,iBAAiB;IACjB,gBAAgB;IAChB,WAAW;IACX,WAAW;IACX,WAAW;CACX,CAAC"}
|
||||
27
lib/repos/MockOrm.js
Normal file
27
lib/repos/MockOrm.js
Normal file
@@ -0,0 +1,27 @@
|
||||
"use strict";
|
||||
var __importDefault = (this && this.__importDefault) || function (mod) {
|
||||
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||
};
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
const jsonfile_1 = __importDefault(require("jsonfile"));
|
||||
// **** Variables **** //
|
||||
const DB_FILE_NAME = 'database.json';
|
||||
// **** Functions **** //
|
||||
/**
|
||||
* Fetch the json from the file.
|
||||
*/
|
||||
function openDb() {
|
||||
return jsonfile_1.default.readFile(__dirname + '/' + DB_FILE_NAME);
|
||||
}
|
||||
/**
|
||||
* Update the file.
|
||||
*/
|
||||
function saveDb(db) {
|
||||
return jsonfile_1.default.writeFile((__dirname + '/' + DB_FILE_NAME), db);
|
||||
}
|
||||
// **** Export default **** //
|
||||
exports.default = {
|
||||
openDb,
|
||||
saveDb,
|
||||
};
|
||||
//# sourceMappingURL=MockOrm.js.map
|
||||
1
lib/repos/MockOrm.js.map
Normal file
1
lib/repos/MockOrm.js.map
Normal file
@@ -0,0 +1 @@
|
||||
{"version":3,"file":"MockOrm.js","sourceRoot":"","sources":["../../src/repos/MockOrm.ts"],"names":[],"mappings":";;;;;AAEA,wDAAgC;AAOhC,yBAAyB;AAEzB,MAAM,YAAY,GAAG,eAAe,CAAC;AAYrC,yBAAyB;AAEzB;;GAEG;AACH,SAAS,MAAM;IACb,OAAO,kBAAQ,CAAC,QAAQ,CAAC,SAAS,GAAG,GAAG,GAAG,YAAY,CAAiB,CAAC;AAC3E,CAAC;AAED;;GAEG;AACH,SAAS,MAAM,CAAC,EAAO;IACrB,OAAO,kBAAQ,CAAC,SAAS,CAAC,CAAC,SAAS,GAAG,GAAG,GAAG,YAAY,CAAC,EAAE,EAAE,CAAC,CAAC;AAClE,CAAC;AAGD,8BAA8B;AAE9B,kBAAe;IACb,MAAM;IACN,MAAM;CACE,CAAC"}
|
||||
52
lib/repos/TaskRepo.js
Normal file
52
lib/repos/TaskRepo.js
Normal file
@@ -0,0 +1,52 @@
|
||||
"use strict";
|
||||
var __importDefault = (this && this.__importDefault) || function (mod) {
|
||||
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||
};
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
const MockOrm_1 = __importDefault(require("./MockOrm"));
|
||||
async function getTasksByBoardId(boardId) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
return db.tasks.filter((task) => task.boardId === boardId);
|
||||
}
|
||||
async function getTaskByBoardId(boardId, taskId) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
return db.tasks.find((task) => task.boardId === boardId && task.id === taskId) || null;
|
||||
}
|
||||
async function createTask(boardId, task) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
task.id = Date.now();
|
||||
task.boardId = boardId;
|
||||
task.createdAt = new Date().toISOString();
|
||||
task.updatedAt = task.createdAt;
|
||||
db.tasks.push(task);
|
||||
await MockOrm_1.default.saveDb(db);
|
||||
return task;
|
||||
}
|
||||
async function updateTask(boardId, taskId, taskData) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
const task = db.tasks.find((t) => t.boardId === boardId && t.id === taskId);
|
||||
if (task) {
|
||||
Object.assign(task, taskData, { updatedAt: new Date().toISOString() });
|
||||
await MockOrm_1.default.saveDb(db);
|
||||
return task;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
async function deleteTask(boardId, taskId) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
const idx = db.tasks.findIndex((t) => t.boardId === boardId && t.id === taskId);
|
||||
if (idx !== -1) {
|
||||
db.tasks.splice(idx, 1);
|
||||
await MockOrm_1.default.saveDb(db);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
exports.default = {
|
||||
getTasksByBoardId,
|
||||
getTaskByBoardId,
|
||||
createTask,
|
||||
updateTask,
|
||||
deleteTask,
|
||||
};
|
||||
//# sourceMappingURL=TaskRepo.js.map
|
||||
1
lib/repos/TaskRepo.js.map
Normal file
1
lib/repos/TaskRepo.js.map
Normal file
@@ -0,0 +1 @@
|
||||
{"version":3,"file":"TaskRepo.js","sourceRoot":"","sources":["../../src/repos/TaskRepo.ts"],"names":[],"mappings":";;;;;AACA,wDAA4B;AAE5B,KAAK,UAAU,iBAAiB,CAAC,OAAe;IAC/C,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,OAAO,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAW,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,KAAK,OAAO,CAAC,CAAC;AACnE,CAAC;AAED,KAAK,UAAU,gBAAgB,CAAC,OAAe,EAAE,MAAc;IAC9D,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,OAAO,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAW,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,KAAK,OAAO,IAAI,IAAI,CAAC,EAAE,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC;AAC/F,CAAC;AAED,KAAK,UAAU,UAAU,CAAC,OAAe,EAAE,IAAW;IACrD,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACrB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACvB,IAAI,CAAC,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;IAC1C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;IAChC,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpB,MAAM,iBAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IACrB,OAAO,IAAI,CAAC;AACb,CAAC;AAED,KAAK,UAAU,UAAU,CAAC,OAAe,EAAE,MAAc,EAAE,QAAwB;IAClF,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,MAAM,IAAI,GAAG,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,OAAO,IAAI,CAAC,CAAC,EAAE,KAAK,MAAM,CAAC,CAAC;IACnF,IAAI,IAAI,EAAE,CAAC;QACV,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;QACvE,MAAM,iBAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACrB,OAAO,IAAI,CAAC;IACb,CAAC;IACD,OAAO,IAAI,CAAC;AACb,CAAC;AAED,KAAK,UAAU,UAAU,CAAC,OAAe,EAAE,MAAc;IACxD,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,MAAM,GAAG,GAAG,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,OAAO,IAAI,CAAC,CAAC,EAAE,KAAK,MAAM,CAAC,CAAC;IACvF,IAAI,GAAG,KAAK,CAAC,CAAC,EAAE,CAAC;QAChB,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QACxB,MAAM,iBAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACrB,OAAO,IAAI,CAAC;IACb,CAAC;IACD,OAAO,KAAK,CAAC;AACd,CAAC;AAED,kBAAe;IACd,iBAAiB;IACjB,gBAAgB;IAChB,UAAU;IACV,UAAU;IACV,UAAU;CACV,CAAC"}
|
||||
52
lib/repos/board.repo.js
Normal file
52
lib/repos/board.repo.js
Normal file
@@ -0,0 +1,52 @@
|
||||
"use strict";
|
||||
var __importDefault = (this && this.__importDefault) || function (mod) {
|
||||
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||
};
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
const MockOrm_1 = __importDefault(require("./MockOrm"));
|
||||
async function getBoardsByUserId(userId) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
return db.boards.filter((board) => board.userId === userId);
|
||||
}
|
||||
async function getBoardByUserId(userId, boardId) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
return db.boards.find((board) => board.userId === userId && board.id === boardId) || null;
|
||||
}
|
||||
async function createBoard(userId, board) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
board.id = Date.now();
|
||||
board.userId = userId;
|
||||
board.createdAt = new Date().toISOString();
|
||||
board.updatedAt = board.createdAt;
|
||||
db.boards.push(board);
|
||||
await MockOrm_1.default.saveDb(db);
|
||||
return board;
|
||||
}
|
||||
async function updateBoard(userId, boardId, boardData) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
const board = db.boards.find((b) => b.userId === userId && b.id === boardId);
|
||||
if (board) {
|
||||
Object.assign(board, boardData, { updatedAt: new Date().toISOString() });
|
||||
await MockOrm_1.default.saveDb(db);
|
||||
return board;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
async function deleteBoard(userId, boardId) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
const idx = db.boards.findIndex((b) => b.userId === userId && b.id === boardId);
|
||||
if (idx !== -1) {
|
||||
db.boards.splice(idx, 1);
|
||||
await MockOrm_1.default.saveDb(db);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
exports.default = {
|
||||
getBoardsByUserId,
|
||||
getBoardByUserId,
|
||||
createBoard,
|
||||
updateBoard,
|
||||
deleteBoard,
|
||||
};
|
||||
//# sourceMappingURL=board.repo.js.map
|
||||
1
lib/repos/board.repo.js.map
Normal file
1
lib/repos/board.repo.js.map
Normal file
@@ -0,0 +1 @@
|
||||
{"version":3,"file":"board.repo.js","sourceRoot":"","sources":["../../src/repos/board.repo.ts"],"names":[],"mappings":";;;;;AACA,wDAA4B;AAE5B,KAAK,UAAU,iBAAiB,CAAC,MAAc;IAC9C,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,OAAO,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,KAAa,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,KAAK,MAAM,CAAC,CAAC;AACrE,CAAC;AAED,KAAK,UAAU,gBAAgB,CAAC,MAAc,EAAE,OAAe;IAC9D,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,OAAO,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAa,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,KAAK,MAAM,IAAI,KAAK,CAAC,EAAE,KAAK,OAAO,CAAC,IAAI,IAAI,CAAC;AACnG,CAAC;AAED,KAAK,UAAU,WAAW,CAAC,MAAc,EAAE,KAAa;IACvD,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,KAAK,CAAC,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACtB,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;IACtB,KAAK,CAAC,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;IAC3C,KAAK,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC;IAClC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtB,MAAM,iBAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IACrB,OAAO,KAAK,CAAC;AACd,CAAC;AAED,KAAK,UAAU,WAAW,CAAC,MAAc,EAAE,OAAe,EAAE,SAA0B;IACrF,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,MAAM,KAAK,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,IAAI,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC,CAAC;IACrF,IAAI,KAAK,EAAE,CAAC;QACX,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;QACzE,MAAM,iBAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACrB,OAAO,KAAK,CAAC;IACd,CAAC;IACD,OAAO,IAAI,CAAC;AACb,CAAC;AAED,KAAK,UAAU,WAAW,CAAC,MAAc,EAAE,OAAe;IACzD,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,MAAM,GAAG,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,IAAI,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC,CAAC;IACxF,IAAI,GAAG,KAAK,CAAC,CAAC,EAAE,CAAC;QAChB,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QACzB,MAAM,iBAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACrB,OAAO,IAAI,CAAC;IACb,CAAC;IACD,OAAO,KAAK,CAAC;AACd,CAAC;AAED,kBAAe;IACd,iBAAiB;IACjB,gBAAgB;IAChB,WAAW;IACX,WAAW;IACX,WAAW;CACX,CAAC"}
|
||||
52
lib/repos/task.repo.js
Normal file
52
lib/repos/task.repo.js
Normal file
@@ -0,0 +1,52 @@
|
||||
"use strict";
|
||||
var __importDefault = (this && this.__importDefault) || function (mod) {
|
||||
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||
};
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
const MockOrm_1 = __importDefault(require("./MockOrm"));
|
||||
async function getTasksByBoardId(boardId) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
return db.tasks.filter((task) => task.boardId === boardId);
|
||||
}
|
||||
async function getTaskByBoardId(boardId, taskId) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
return db.tasks.find((task) => task.boardId === boardId && task.id === taskId) || null;
|
||||
}
|
||||
async function createTask(boardId, task) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
task.id = Date.now();
|
||||
task.boardId = boardId;
|
||||
task.createdAt = new Date().toISOString();
|
||||
task.updatedAt = task.createdAt;
|
||||
db.tasks.push(task);
|
||||
await MockOrm_1.default.saveDb(db);
|
||||
return task;
|
||||
}
|
||||
async function updateTask(boardId, taskId, taskData) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
const task = db.tasks.find((t) => t.boardId === boardId && t.id === taskId);
|
||||
if (task) {
|
||||
Object.assign(task, taskData, { updatedAt: new Date().toISOString() });
|
||||
await MockOrm_1.default.saveDb(db);
|
||||
return task;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
async function deleteTask(boardId, taskId) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
const idx = db.tasks.findIndex((t) => t.boardId === boardId && t.id === taskId);
|
||||
if (idx !== -1) {
|
||||
db.tasks.splice(idx, 1);
|
||||
await MockOrm_1.default.saveDb(db);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
exports.default = {
|
||||
getTasksByBoardId,
|
||||
getTaskByBoardId,
|
||||
createTask,
|
||||
updateTask,
|
||||
deleteTask,
|
||||
};
|
||||
//# sourceMappingURL=task.repo.js.map
|
||||
1
lib/repos/task.repo.js.map
Normal file
1
lib/repos/task.repo.js.map
Normal file
@@ -0,0 +1 @@
|
||||
{"version":3,"file":"task.repo.js","sourceRoot":"","sources":["../../src/repos/task.repo.ts"],"names":[],"mappings":";;;;;AACA,wDAA4B;AAE5B,KAAK,UAAU,iBAAiB,CAAC,OAAe;IAC/C,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,OAAO,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAW,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,KAAK,OAAO,CAAC,CAAC;AACnE,CAAC;AAED,KAAK,UAAU,gBAAgB,CAAC,OAAe,EAAE,MAAc;IAC9D,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,OAAO,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAW,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,KAAK,OAAO,IAAI,IAAI,CAAC,EAAE,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC;AAC/F,CAAC;AAED,KAAK,UAAU,UAAU,CAAC,OAAe,EAAE,IAAW;IACrD,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACrB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACvB,IAAI,CAAC,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;IAC1C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;IAChC,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpB,MAAM,iBAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IACrB,OAAO,IAAI,CAAC;AACb,CAAC;AAED,KAAK,UAAU,UAAU,CAAC,OAAe,EAAE,MAAc,EAAE,QAAwB;IAClF,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,MAAM,IAAI,GAAG,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,OAAO,IAAI,CAAC,CAAC,EAAE,KAAK,MAAM,CAAC,CAAC;IACnF,IAAI,IAAI,EAAE,CAAC;QACV,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;QACvE,MAAM,iBAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACrB,OAAO,IAAI,CAAC;IACb,CAAC;IACD,OAAO,IAAI,CAAC;AACb,CAAC;AAED,KAAK,UAAU,UAAU,CAAC,OAAe,EAAE,MAAc;IACxD,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,MAAM,GAAG,GAAG,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,OAAO,IAAI,CAAC,CAAC,EAAE,KAAK,MAAM,CAAC,CAAC;IACvF,IAAI,GAAG,KAAK,CAAC,CAAC,EAAE,CAAC;QAChB,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QACxB,MAAM,iBAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACrB,OAAO,IAAI,CAAC;IACb,CAAC;IACD,OAAO,KAAK,CAAC;AACd,CAAC;AAED,kBAAe;IACd,iBAAiB;IACjB,gBAAgB;IAChB,UAAU;IACV,UAAU;IACV,UAAU;CACV,CAAC"}
|
||||
82
lib/repos/user.repo.js
Normal file
82
lib/repos/user.repo.js
Normal file
@@ -0,0 +1,82 @@
|
||||
"use strict";
|
||||
var __importDefault = (this && this.__importDefault) || function (mod) {
|
||||
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||
};
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
const misc_1 = require("@src/util/misc");
|
||||
const MockOrm_1 = __importDefault(require("./MockOrm"));
|
||||
// **** Functions **** //
|
||||
/**
|
||||
* Get one user.
|
||||
*/
|
||||
async function getOne(email) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
for (const user of db.users) {
|
||||
if (user.email === email) {
|
||||
return user;
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
/**
|
||||
* See if a user with the given id exists.
|
||||
*/
|
||||
async function persists(id) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
for (const user of db.users) {
|
||||
if (user.id === id) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
/**
|
||||
* Get all users.
|
||||
*/
|
||||
async function getAll() {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
return db.users;
|
||||
}
|
||||
/**
|
||||
* Add one user.
|
||||
*/
|
||||
async function add(user) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
user.id = (0, misc_1.getRandomInt)();
|
||||
db.users.push(user);
|
||||
return MockOrm_1.default.saveDb(db);
|
||||
}
|
||||
/**
|
||||
* Update a user.
|
||||
*/
|
||||
async function update(user) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
for (let i = 0; i < db.users.length; i++) {
|
||||
if (db.users[i].id === user.id) {
|
||||
db.users[i] = user;
|
||||
return MockOrm_1.default.saveDb(db);
|
||||
}
|
||||
}
|
||||
}
|
||||
/**
|
||||
* Delete one user.
|
||||
*/
|
||||
async function delete_(id) {
|
||||
const db = await MockOrm_1.default.openDb();
|
||||
for (let i = 0; i < db.users.length; i++) {
|
||||
if (db.users[i].id === id) {
|
||||
db.users.splice(i, 1);
|
||||
return MockOrm_1.default.saveDb(db);
|
||||
}
|
||||
}
|
||||
}
|
||||
// **** Export default **** //
|
||||
exports.default = {
|
||||
getOne,
|
||||
persists,
|
||||
getAll,
|
||||
add,
|
||||
update,
|
||||
delete: delete_,
|
||||
};
|
||||
//# sourceMappingURL=user.repo.js.map
|
||||
1
lib/repos/user.repo.js.map
Normal file
1
lib/repos/user.repo.js.map
Normal file
@@ -0,0 +1 @@
|
||||
{"version":3,"file":"user.repo.js","sourceRoot":"","sources":["../../src/repos/user.repo.ts"],"names":[],"mappings":";;;;;AACA,yCAA8C;AAC9C,wDAA4B;AAG5B,yBAAyB;AAEzB;;GAEG;AACH,KAAK,UAAU,MAAM,CAAC,KAAa;IACjC,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,KAAK,MAAM,IAAI,IAAI,EAAE,CAAC,KAAK,EAAE,CAAC;QAC5B,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,EAAE,CAAC;YACzB,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED;;GAEG;AACH,KAAK,UAAU,QAAQ,CAAC,EAAU;IAChC,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,KAAK,MAAM,IAAI,IAAI,EAAE,CAAC,KAAK,EAAE,CAAC;QAC5B,IAAI,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED;;GAEG;AACH,KAAK,UAAU,MAAM;IACnB,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,OAAO,EAAE,CAAC,KAAK,CAAC;AAClB,CAAC;AAED;;GAEG;AACH,KAAK,UAAU,GAAG,CAAC,IAAW;IAC5B,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,IAAI,CAAC,EAAE,GAAG,IAAA,mBAAY,GAAE,CAAC;IACzB,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpB,OAAO,iBAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;AACxB,CAAC;AAED;;GAEG;AACH,KAAK,UAAU,MAAM,CAAC,IAAW;IAC/B,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACzC,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,EAAE,CAAC;YAC/B,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;YACnB,OAAO,iBAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,CAAC;IACH,CAAC;AACH,CAAC;AAED;;GAEG;AACH,KAAK,UAAU,OAAO,CAAC,EAAU;IAC/B,MAAM,EAAE,GAAG,MAAM,iBAAG,CAAC,MAAM,EAAE,CAAC;IAC9B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACzC,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC;YAC1B,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YACtB,OAAO,iBAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,CAAC;IACH,CAAC;AACH,CAAC;AAGD,8BAA8B;AAE9B,kBAAe;IACb,MAAM;IACN,QAAQ;IACR,MAAM;IACN,GAAG;IACH,MAAM;IACN,MAAM,EAAE,OAAO;CACP,CAAC"}
|
||||
Reference in New Issue
Block a user