Files
old-spike/server/models/energy_datum.js

63 lines
1.6 KiB
JavaScript
Raw Normal View History

2016-02-22 14:36:07 -06:00
import DB from "./../config/database";
import extend from 'extend';
2016-02-23 11:17:50 -06:00
import ApiHelper from './../lib/api_helper';
2016-02-22 14:36:07 -06:00
const NAME = 'EnergyDatum';
/**
* Define your own types here
*/
var EnergyDatum = DB.sequelize.define(NAME, {
id: {
type: DB.Sequelize.INTEGER,
primaryKey: true,
autoIncrement: true // Automatically gets converted to SERIAL for postgres
},
day: {
type: DB.Sequelize.INTEGER,
},
2016-03-08 15:21:16 -06:00
irradiance: DB.Sequelize.FLOAT,
2016-02-22 14:36:07 -06:00
production: DB.Sequelize.FLOAT,
consumption: DB.Sequelize.FLOAT
}, {
paranoid: true,
underscored: true,
tableName: "energy_data",
instanceMethods: {},
classMethods: {
set: ()=>{
EnergyDatum.associate();
},
associate: ()=>{
EnergyDatum.belongsTo(DB.House);
},
2016-03-11 17:38:03 -06:00
exposeForHouseAtDates: (query)=>{
var attributes = ['id', 'production', 'irradiance', 'consumption', 'day'],
params = {};
if (query.houses){
attributes.push('house_id');
params['$or'] = []
query.houses.forEach((house_query)=>{
var house_params = {house_id: house_query.house_id};
extend(house_params, ApiHelper.datesParamToSequelize(house_query.dates, 'day'));
params['$or'].push(house_params);
});
} else {
params.house_id = query.house_id;
extend(params, ApiHelper.datesParamToSequelize(query.dates, 'day'));
}
2016-02-22 14:36:07 -06:00
return EnergyDatum.findAll({
where: params,
2016-03-11 17:38:03 -06:00
attributes: attributes
2016-02-22 14:36:07 -06:00
}).then((energy_data)=>{
2016-03-11 17:38:03 -06:00
return energy_data.map(energy_datum => energy_datum.dataValues);
2016-02-22 14:36:07 -06:00
});
}
}
});
EnergyDatum.NAME = NAME;
module.exports = EnergyDatum;