summaryrefslogblamecommitdiffstats
path: root/server/api/permissions.js
blob: ef7c5e85f17ab599beb29a47d199ec1cc79b2bf9 (plain) (tree)
1
2
3
4
5
6
7
8
9
                     

                                                         
 
                      
                                    


                                                                                                       

      
 
                                    
                     



                                         

    
                                          
                                                         

                                       

   
 
                       
                                    

                               
                                                                  



                                     
                                 
                         
 

                                   
                                                                             
                         

                                                              



                                                                       
                                                                  
                         


                                                                            


                                                                       
   
 
/* global __appdir */
var path = require('path')
var db = require(path.join(__appdir, 'lib', 'sequelize'))

module.exports.get = {
  getRoleById: function (req, res) {
    db.role.findOne({ where: { id: req.query.id }, include: ['permissions', 'groups'] }).then(role => {
      if (role) res.send(role)
      else res.status(404).end()
    })
  },

  getRoleList: function (req, res) {
    db.role.findAll({
      attributes: ['id', 'name', 'descr']
    }).then(function (roles) {
      res.status(200).send(roles)
    })
  },

  getPermissionList: function (req, res) {
    db.permission.findAll().then(function (permissions) {
      res.status(200).send(permissions)
    })
  }
}

module.exports.post = {
  deleteRoles: function (req, res) {
    const roleIds = req.body.id

    db.role.destroy({ where: { id: roleIds } }).then(function () {
      res.status(200).send('success')
    })
  },

  saveRole: function (req, res) {
    const role = req.body

    if (role.id === 0) {
      // Insert new role in the db.
      db.role.create({ name: role.name, descr: role.descr }).then(roleDb => {
        var promises = []
        promises.push(roleDb.addPermissions(role.permissions))
        promises.push(roleDb.addGroups(role.groups))
        Promise.all(promises).then(() => { res.send({ id: role.id }) })
      })
    } else {
      // Update an existing role in the db.
      db.role.findOne({ where: { id: role.id } }).then(roleDb => {
        var promises = []
        promises.push(roleDb.update({ name: role.name, descr: role.descr }))
        promises.push(roleDb.setPermissions(role.permissions))
        promises.push(roleDb.setGroups(role.groups))
        Promise.all(promises).then(() => { res.send({ id: role.id }) })
      })
    }
  }
}