summaryrefslogtreecommitdiffstats
path: root/server/api/ipranges.js
blob: 2a40763452286e2642cfa56d99eb1d3eb691a912 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
/* global __appdir */
var path = require('path')
var db = require(path.join(__appdir, 'lib', 'sequelize'))
var express = require('express')
const { decorateApp } = require('@awaitjs/express')
var router = decorateApp(express.Router())
const HttpResponse = require(path.join(__appdir, 'lib', 'httpresponse'))
const iphelper = require(path.join(__appdir, 'lib', 'iphelper'))

// ############################################################################
// ###########################  GET requests  #################################

router.getAsync('', async (req, res) => {
  const ipranges = await db.iprange.findAll({ order: [['group', 'name', 'ASC']], include: ['group'] })
  ipranges.forEach(iprange => {
    iprange.startIp = iphelper.toIPv4(iprange.startIp)
    iprange.endIp = iphelper.toIPv4(iprange.endIp)
  })
  res.send(ipranges)
})

router.getAsync('/:id', async (req, res) => {
  if (!(req.params.id > 0)) return HttpResponse.invalidId().send(res)
  const iprange = await db.iprange.findOne({ where: { id: req.params.id }, include: ['group'] })
  if (iprange) {
    iprange.startIp = iphelper.toIPv4(iprange.startIp)
    iprange.endIp = iphelper.toIPv4(iprange.endIp)
    res.status(200).send(iprange)
  } else HttpResponse.notFound(req.params.id).send(res)
})

// ############################################################################
// ##########################  POST requests  #################################

router.postAsync(['', '/:id'], async (req, res) => {
  if (req.query.delete !== undefined && req.query.delete !== 'false') {
    if (!Array.isArray(req.body.ids)) return HttpResponse.invalidBodyValue('ids', 'an array').send(res)
    const count = await db.iprange.destroy({ where: { id: req.body.ids } })
    return HttpResponse.successBatch('deleted', 'client', count).send(res)
  }
  let iprange
  let action = 'updated'
  req.body.startIp = iphelper.toDecimal(req.body.startIp)
  req.body.endIp = iphelper.toDecimal(req.body.endIp)
  if (req.params.id === undefined) {
    iprange = await db.iprange.create(req.body)
    action = 'created'
  } else if (req.params.id > 0) {
    iprange = await db.iprange.findOne({ where: { id: req.params.id } })
    if (!iprange) return HttpResponse.notFound(req.params.id).send(res)
    else await iprange.update(req.body)
  } else {
    return HttpResponse.invalidId().send(res)
  }
  HttpResponse.success(action, 'iprange', iprange.id).send(res)
})

// ############################################################################
// ##########################  DELETE requests  ###############################

router.delete('/:id', async (req, res) => {
  if (!(req.params.id > 0)) return HttpResponse.invalidId().send(res)
  const count = await db.iprange.destroy({ where: { id: req.params.id } })
  if (count) HttpResponse.success('deleted', 'iprange', req.params.id).send(res)
  else HttpResponse.notFound(req.params.id).send(res)
})

// ############################################################################
// ############################################################################

module.exports.router = router