import { Sequelize } from 'sequelize'; import dotenv from 'dotenv'; dotenv.config(); let sequelize = createConnection(); // Supply Line Models import supplyLine from './supplyLine/supplyLine.js'; import volumePrices from './supplyLine/volumePrices.js'; // Conf Models import clientConfig from './conf/clientConfig.js'; import sequenceNumber from './conf/sequenceNumber.js'; // Supplier Models import suppliers from './supplier/suppliers.js'; import connections from './supplier/connections.js'; // TradeItem Models import tradeItem from './tradeItem/tradeItem.js'; import botanicalNames from './tradeItem/botanicalNames.js'; import countryOfOriginIsoCodes from './tradeItem/countryOfOriginIsoCodes.js'; import packageModel from './tradeItem/package.js'; import packingConfigurations from './tradeItem/packingConfigurations.js'; import photos from './tradeItem/photos.js'; import seasonalPeriod from './tradeItem/seasonalPeriod.js'; import characteristics from './tradeItem/characteristics.js'; /** * Contains all the models that are related to the application. * * @example * models.@modelName@.findAll(); * * @example * models.tradeItem.findAll().then((data) => { * console.log(data); * }); * * @example * models.tradeItem.create({ * tradeItemName: 'Test', * foo: 'bar', * }); * * * @type {Object.} */ let models = { sequelize: sequelize, tradeItem: tradeItem(sequelize), packingConfigurations: packingConfigurations(sequelize), photos: photos(sequelize), characteristics: characteristics(sequelize), countryOfOriginIsoCodes: countryOfOriginIsoCodes(sequelize), package: packageModel(sequelize), seasonalPeriod: seasonalPeriod(sequelize), clientConfig: clientConfig(sequelize), botanicalNames: botanicalNames(sequelize), supplyLines: supplyLine(sequelize), volumePrices: volumePrices(sequelize), suppliers: suppliers(sequelize), sequenceNumber: sequenceNumber(sequelize), connections: connections(sequelize), }; models.characteristics.belongsTo(models.tradeItem, { foreignKey: 'tradeItemFk', as: 'tradeItem_Fk', targetKey: 'tradeItemId', }); models.seasonalPeriod.belongsTo(models.tradeItem, { foreignKey: 'tradeItemFk', as: 'tradeItem_Fk', targetKey: 'tradeItemId', }); models.photos.belongsTo(models.tradeItem, { foreignKey: 'tradeItemFk', as: 'tradeItem_Fk', targetKey: 'tradeItemId', }); models.photos.hasMany(models.seasonalPeriod, { foreignKey: 'photoFk', as: 'seasonalPeriod_Fk', targetKey: 'photoId', }); models.seasonalPeriod.belongsTo(models.photos, { foreignKey: 'photoFk', as: 'photo_Fk', targetKey: 'photoId', }); models.packingConfigurations.belongsTo(models.tradeItem, { foreignKey: 'tradeItemFk', as: 'tradeItem_Fk', targetKey: 'tradeItemId', }); models.packingConfigurations.hasMany(models.package, { foreignKey: 'packingConfigurationFk', as: 'package_Fk', targetKey: 'packingConfigurationId', }); models.package.belongsTo(models.packingConfigurations, { foreignKey: 'packingConfigurationFk', as: 'packingConfiguration_Fk', targetKey: 'packingConfigurationId', }); models.botanicalNames.belongsTo(models.tradeItem, { foreignKey: 'tradeItemFk', as: 'tradeItem_Fk', targetKey: 'tradeItemId', }); models.countryOfOriginIsoCodes.belongsTo(models.tradeItem, { foreignKey: 'tradeItemFk', as: 'tradeItem_Fk', targetKey: 'tradeItemId', }); models.volumePrices.belongsTo(models.supplyLines, { foreignKey: 'supplyLineFk', as: 'supplyLine_Fk', targetKey: 'supplyLineId', }); models.supplyLines.belongsTo(models.tradeItem, { foreignKey: 'tradeItemFk', as: 'tradeItem_Fk', targetKey: 'tradeItemId', }); if (process.env.FORCE_SYNC == true) { console.log('Forcing the models...'); await sequelize.sync({ force: true }); } else { console.log('Altering the models...'); await sequelize.sync({ alter: true }); } if (process.env.SECRETS) { await models.clientConfig.create({ clientId: process.env.CLIENT_ID, clientSecret: process.env.CLIENT_SECRET, }); } /** * Creates the connection to the database. * * @example * let sequelize = createConnection(); * * @returns {Sequelize} Sequelize instance with the connection to the database. */ function createConnection() { console.log('Creating the connection...'); return new Sequelize(process.env.DB_SCHEMA, process.env.DB_USER, process.env.DB_PWD, { host: process.env.DB_HOST, dialect: process.env.DB_DIALECT, logging: false, pool: { max: 40, min: 0, acquire: 60000, idle: 10000, }, }); } export { models } ;