server/lib/dashboard/dashboard.getBySelector.js
const { Op } = require('sequelize');
const db = require('../../models');
const { NotFoundError } = require('../../utils/coreErrors');
/**
* @description Get a dashboard by selector.
* @param {string} userId - The userId querying.
* @param {string} selector - The selector.
* @returns {Promise} Resolve with a dashboard.
* @example
* gladys.dashboard.getBySelector('main-dashboard');
*/
async function getBySelector(userId, selector) {
const dashboard = await db.Dashboard.findOne({
attributes: ['id', 'name', 'selector', 'type', 'visibility', 'user_id', 'created_at', 'updated_at', 'boxes'],
where: {
// I can see dashboard I created or public dashboard
[Op.or]: [
{
user_id: userId,
},
{
visibility: 'public',
},
],
selector,
},
});
if (dashboard === null) {
throw new NotFoundError('Dashboard not found');
}
return dashboard.get({ plain: true });
}
module.exports = {
getBySelector,
};