Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[EJEMPLO, NO MERGEAR] JSON en vez de SQLite #5

Open
wants to merge 7 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .env.dist
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
DB_PATH=./data/database.db
JSON_DB_PATH=./data/clubs.json
API_FOOTBALL_DATA=
SESSION_DB_PATH=./data/session.db
SESSION_SECRET=secreto por default (que puede tener espacios y caracteres no alfanuméricos)
Expand Down
9 changes: 2 additions & 7 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@ Un CRUD/ABM (Create, Retrieve, Update, Delete ó Alta, Baja, Modificación) de c

## Diagrama

<img src="./crud_clubes_simple.png">

## Cómo instalar y correr este proyecto

El proyecto se instala con `npm install`
Expand All @@ -29,9 +31,6 @@ Adaptado de https://softwareontheroad.com/ideal-nodejs-project-structure/

| Ruta | explicación |
| -------------------------------- | ----------------------------------------------------------------------------------------------------------------------------- |
| data | contiene las bases de datos de SQLite |
| data/database.db | base de datos principal del proyecto |
| data/session.db | base de datos para guardar las sesiones de nuestro proyecto |
| public | contiene los archivos estáticos que va a servir el navegador, acá se guardan las imágenes subidas |
| src | contiene toda nuestra aplicación |
| src/app.js | punto de entrada de nuestra aplicación |
Expand All @@ -52,10 +51,6 @@ Adaptado de https://softwareontheroad.com/ideal-nodejs-project-structure/
| src/module/club/view | archivos de presentación (interfaz) que se procesarán del lado del servidor (SSR, server side rendering) |
| src/module/club/module.js | archivo de entrada a este módulo que lo inicializa |

## Creando modelos nuevos

Si se crea un modelo de Sequelize nuevo, recordar cargarlo en el archivo `src/cli/init.db.js` para que la sincronización de la base de datos incluya el nuevo modelo.

## Configuración del IDE

El IDE debe soportar Prettier + ESLint, como por ejemplo (vscode)[https://blog.echobind.com/integrating-prettier-eslint-airbnb-style-guide-in-vscode-47f07b5d7d6a]
Binary file removed clubes_crud.jpg
Binary file not shown.
Binary file added crud_clubes_simple.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
21 changes: 18 additions & 3 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 2 additions & 4 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,7 @@
"main": "index.js",
"scripts": {
"start": "node src/app.js",
"schema:sync": "node src/cli/init.db.js",
"dev": "npm run schema:sync && nodemon -e 'js,njk,html' src/app.js",
"dev": "nodemon -e 'js,njk,html' src/app.js",
"test": "jest --coverage",
"test:dev": "jest --watch"
},
Expand Down Expand Up @@ -35,14 +34,13 @@
},
"dependencies": {
"axios": "^0.19.2",
"connect-session-sequelize": "^7.0.1",
"dotenv": "^8.2.0",
"express": "^4.17.1",
"express-session": "^1.17.1",
"multer": "^1.4.2",
"nunjucks": "^3.2.1",
"rsdi": "^1.0.5",
"sequelize": "^6.3.3",
"sqlite3": "^5.0.0"
"uuid": "^8.3.0"
}
}
2 changes: 0 additions & 2 deletions src/app.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ const nunjucks = require('nunjucks');

const configureDependencyInjection = require('./config/di');
const { init: initClubModule } = require('./module/club/module');
const { init: initAreaModule } = require('./module/area/module');

const app = express();
const port = process.env.PORT || 3000;
Expand All @@ -22,7 +21,6 @@ const container = configureDependencyInjection(app);
app.use(container.get('Session'));

initClubModule(app, container);
initAreaModule(app, container);

/**
* @type {import('./module/club/controller/clubController')} controller;
Expand Down
22 changes: 0 additions & 22 deletions src/cli/init.db.js

This file was deleted.

6 changes: 0 additions & 6 deletions src/config/associations.js

This file was deleted.

78 changes: 15 additions & 63 deletions src/config/di.js
Original file line number Diff line number Diff line change
@@ -1,55 +1,21 @@
// configure DI container
const path = require('path');
const uuid = require('uuid');
const fs = require('fs');
const { default: DIContainer, object, get, factory } = require('rsdi');
const { Sequelize } = require('sequelize');
const multer = require('multer');

const session = require('express-session');
const SequelizeStore = require('connect-session-sequelize')(session.Store);
const { ClubController, ClubService, ClubRepository, ClubModel } = require('../module/club/module');
const { AreaController, AreaService, AreaRepository, AreaModel } = require('../module/area/module');
const { ClubController, ClubService, ClubRepository } = require('../module/club/module');

const setupSequelizeModelAssociations = require('./associations');

function configureMainSequelizeDatabase() {
const sequelize = new Sequelize({
dialect: 'sqlite',
storage: process.env.DB_PATH,
});
return sequelize;
}

function configureSessionSequelizeDatabase() {
const sequelize = new Sequelize({
dialect: 'sqlite',
storage: process.env.SESSION_DB_PATH,
});
return sequelize;
}

/**
* @param {DIContainer} container
*/
function configureClubModel(container) {
return ClubModel.setup(container.get('Sequelize'));
function configureMainJSONDatabase() {
return process.env.JSON_DB_PATH;
}

/**
* @param {DIContainer} container
*/
function configureAreaModel(container) {
return AreaModel.setup(container.get('Sequelize'));
}

/**
* @param {DIContainer} container
*/
function configureSession(container) {
function configureSession() {
const ONE_WEEK_IN_SECONDS = 604800000;

const sequelize = container.get('SessionSequelize');
const sessionOptions = {
store: new SequelizeStore({ db: sequelize }),
secret: process.env.SESSION_SECRET,
resave: false,
saveUninitialized: false,
Expand All @@ -73,13 +39,18 @@ function configureMulter() {
return multer({ storage });
}

function configureUuid() {
return uuid.v4;
}

/**
* @param {DIContainer} container
*/
function addCommonDefinitions(container) {
container.addDefinitions({
Sequelize: factory(configureMainSequelizeDatabase),
SessionSequelize: factory(configureSessionSequelizeDatabase),
fs,
uuid: factory(configureUuid),
JSONDatabase: factory(configureMainJSONDatabase),
Session: factory(configureSession),
Multer: factory(configureMulter),
});
Expand All @@ -90,34 +61,15 @@ function addCommonDefinitions(container) {
*/
function addClubModuleDefinitions(container) {
container.addDefinitions({
ClubController: object(ClubController).construct(
get('Multer'),
get('ClubService'),
get('AreaService')
),
ClubController: object(ClubController).construct(get('Multer'), get('ClubService')),
ClubService: object(ClubService).construct(get('ClubRepository')),
ClubRepository: object(ClubRepository).construct(get('ClubModel'), get('AreaModel')),
ClubModel: factory(configureClubModel),
});
}

/**
* @param {DIContainer} container
*/
function addAreaModuleDefinitions(container) {
container.addDefinitions({
AreaController: object(AreaController).construct(get('AreaService')),
AreaService: object(AreaService).construct(get('AreaRepository')),
AreaRepository: object(AreaRepository).construct(get('AreaModel')),
AreaModel: factory(configureAreaModel),
ClubRepository: object(ClubRepository).construct(get('uuid'), get('fs'), get('JSONDatabase')),
});
}

module.exports = function configureDI() {
const container = new DIContainer();
addCommonDefinitions(container);
addAreaModuleDefinitions(container);
addClubModuleDefinitions(container);
setupSequelizeModelAssociations(container.get('ClubModel'), container.get('AreaModel'));
return container;
};
104 changes: 0 additions & 104 deletions src/module/area/controller/areaController.js

This file was deleted.

1 change: 0 additions & 1 deletion src/module/area/controller/error/areaIdNotDefinedError.js

This file was deleted.

6 changes: 0 additions & 6 deletions src/module/area/entity/area.js

This file was deleted.

5 changes: 0 additions & 5 deletions src/module/area/mapper/areaMapper.js

This file was deleted.

Loading