Get network info from DB
This commit is contained in:
parent
b45b05f033
commit
45e6679293
|
@ -3,6 +3,9 @@
|
||||||
"version": "2.17.1",
|
"version": "2.17.1",
|
||||||
"description": "Servidor do Portal de TI do IFMS",
|
"description": "Servidor do Portal de TI do IFMS",
|
||||||
"main": "src/index.js",
|
"main": "src/index.js",
|
||||||
|
"prisma": {
|
||||||
|
"seed": "node prisma/seed.js"
|
||||||
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"start": "node --tls-min-v1.0 dist/index.js",
|
"start": "node --tls-min-v1.0 dist/index.js",
|
||||||
"dev": "nodemon --tls-min-v1.0 --ext js,graphql src/index.js --exec 'babel-node'",
|
"dev": "nodemon --tls-min-v1.0 --ext js,graphql src/index.js --exec 'babel-node'",
|
||||||
|
@ -11,6 +14,7 @@
|
||||||
"prisma:dev": "prisma migrate dev",
|
"prisma:dev": "prisma migrate dev",
|
||||||
"prisma:deploy": "prisma migrate deploy",
|
"prisma:deploy": "prisma migrate deploy",
|
||||||
"prisma:generate": "prisma generate",
|
"prisma:generate": "prisma generate",
|
||||||
|
"seed": "node prisma/seed.js",
|
||||||
"build": "babel src --out-dir dist --copy-files --source-maps"
|
"build": "babel src --out-dir dist --copy-files --source-maps"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
|
|
78
server/prisma/seed.js
Normal file
78
server/prisma/seed.js
Normal file
|
@ -0,0 +1,78 @@
|
||||||
|
const { PrismaClient } = require('@prisma/client')
|
||||||
|
const prisma = new PrismaClient()
|
||||||
|
|
||||||
|
async function seed() {
|
||||||
|
const subNetsInfo = [
|
||||||
|
{
|
||||||
|
shortName: 'RT',
|
||||||
|
name: 'Reitoria',
|
||||||
|
cidr: '10.0.0.0/16'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortName: 'RT',
|
||||||
|
name: 'Reitoria',
|
||||||
|
cidr: '10.1.0.0/16'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortName: 'AQ',
|
||||||
|
name: 'Aquidauana',
|
||||||
|
cidr: '10.2.0.0/16'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortName: 'CG',
|
||||||
|
name: 'Campo Grande',
|
||||||
|
cidr: '10.3.0.0/16'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortName: 'CB',
|
||||||
|
name: 'Corumbá',
|
||||||
|
cidr: '10.4.0.0/16'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortName: 'CX',
|
||||||
|
name: 'Coxim',
|
||||||
|
cidr: '10.5.0.0/16'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortName: 'NA',
|
||||||
|
name: 'Nova Andradina',
|
||||||
|
cidr: '10.6.0.0/16'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortName: 'PP',
|
||||||
|
name: 'Ponta Porã',
|
||||||
|
cidr: '10.7.0.0/16'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortName: 'TL',
|
||||||
|
name: 'Três Lagoas',
|
||||||
|
cidr: '10.8.0.0/16'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortName: 'JD',
|
||||||
|
name: 'Jardim',
|
||||||
|
cidr: '10.9.0.0/16'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortName: 'NV',
|
||||||
|
name: 'Naviraí',
|
||||||
|
cidr: '10.10.0.0/16'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortName: 'DR',
|
||||||
|
name: 'Dourados',
|
||||||
|
cidr: '10.11.0.0/16'
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
console.log('Seeding subnets...')
|
||||||
|
|
||||||
|
await prisma.network.createMany({
|
||||||
|
data: subNetsInfo,
|
||||||
|
skipDuplicates: true
|
||||||
|
})
|
||||||
|
|
||||||
|
console.log('Done!')
|
||||||
|
}
|
||||||
|
|
||||||
|
seed()
|
42
server/src/lib/subnetInfo.js
Normal file
42
server/src/lib/subnetInfo.js
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
import ip from 'ip'
|
||||||
|
import { isIPv4 } from 'net'
|
||||||
|
import prisma from '../prisma'
|
||||||
|
|
||||||
|
let subNetsInfo = []
|
||||||
|
|
||||||
|
async function getSubnetInfoFromDB() {
|
||||||
|
return await prisma.network.findMany()
|
||||||
|
}
|
||||||
|
|
||||||
|
async function getSubNets() {
|
||||||
|
subNetsInfo = await getSubnetInfoFromDB()
|
||||||
|
|
||||||
|
return subNetsInfo.map(subNetInfo => ({
|
||||||
|
...subNetInfo,
|
||||||
|
...ip.cidrSubnet(subNetInfo.cidr)
|
||||||
|
}))
|
||||||
|
}
|
||||||
|
|
||||||
|
export const subNets = []
|
||||||
|
|
||||||
|
getSubNets().then(result => {
|
||||||
|
subNets.push(...result)
|
||||||
|
})
|
||||||
|
|
||||||
|
export function getSubnetInfo(ip) {
|
||||||
|
if (!isIPv4(ip))
|
||||||
|
return {
|
||||||
|
shortName: '__',
|
||||||
|
name: 'Sem rede'
|
||||||
|
}
|
||||||
|
|
||||||
|
const subnet = subNets.find(subnet => subnet.contains(ip))
|
||||||
|
|
||||||
|
if (!subnet)
|
||||||
|
return {
|
||||||
|
shortName: '??',
|
||||||
|
name: 'Rede desconhecida'
|
||||||
|
}
|
||||||
|
|
||||||
|
return subnet
|
||||||
|
}
|
|
@ -1,5 +1,5 @@
|
||||||
import prisma from '../prisma'
|
import prisma from '../prisma'
|
||||||
import { getSubnetInfo } from '../utils/subnetInfo'
|
import { getSubnetInfo } from '../lib/subnetInfo'
|
||||||
|
|
||||||
export const AccessPoint = {
|
export const AccessPoint = {
|
||||||
updatedAt: (parent, data, context, info) => parent.updatedAt?.toISOString(),
|
updatedAt: (parent, data, context, info) => parent.updatedAt?.toISOString(),
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import prisma from '../../prisma'
|
import prisma from '../../prisma'
|
||||||
import { ACCESS_POINTS_UPDATED, pubsub } from '../../pubsub'
|
import { ACCESS_POINTS_UPDATED, pubsub } from '../../pubsub'
|
||||||
import { logError, logInfo } from '../../lib/logger'
|
import { logError, logInfo } from '../../lib/logger'
|
||||||
import { getSubnetInfo } from '../../utils/subnetInfo'
|
import { getSubnetInfo } from '../../lib/subnetInfo'
|
||||||
|
|
||||||
export async function updateAccessPoint(
|
export async function updateAccessPoint(
|
||||||
_,
|
_,
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import prisma from '../../prisma'
|
import prisma from '../../prisma'
|
||||||
import { getSubnetInfo } from '../../utils/subnetInfo'
|
import { getSubnetInfo } from '../../lib/subnetInfo'
|
||||||
|
|
||||||
export async function userPresence(_, { search, onlyServants }) {
|
export async function userPresence(_, { search, onlyServants }) {
|
||||||
if (!search) search = ''
|
if (!search) search = ''
|
||||||
|
|
|
@ -1,99 +0,0 @@
|
||||||
import ip from 'ip'
|
|
||||||
import { isIPv4 } from 'net'
|
|
||||||
|
|
||||||
const subNetsInfo = [
|
|
||||||
{
|
|
||||||
shortName: 'RT',
|
|
||||||
name: 'Reitoria',
|
|
||||||
cidr: '10.0.0.0/16'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
shortName: 'RT',
|
|
||||||
name: 'Reitoria',
|
|
||||||
cidr: '10.1.0.0/16',
|
|
||||||
addresses: [{ name: 'RNP', ip: '200.19.32.4' }]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
shortName: 'AQ',
|
|
||||||
name: 'Aquidauana',
|
|
||||||
cidr: '10.2.0.0/16',
|
|
||||||
addresses: [{ name: 'RNP', ip: '200.19.32.253' }]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
shortName: 'CG',
|
|
||||||
name: 'Campo Grande',
|
|
||||||
cidr: '10.3.0.0/16',
|
|
||||||
addresses: [{ name: 'RNP', ip: '200.19.32.120' }]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
shortName: 'CB',
|
|
||||||
name: 'Corumbá',
|
|
||||||
cidr: '10.4.0.0/16',
|
|
||||||
addresses: [{ name: 'RNP', ip: '200.19.37.2' }]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
shortName: 'CX',
|
|
||||||
name: 'Coxim',
|
|
||||||
cidr: '10.5.0.0/16',
|
|
||||||
addresses: [{ name: 'RNP', ip: '200.19.36.16' }]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
shortName: 'NA',
|
|
||||||
name: 'Nova Andradina',
|
|
||||||
cidr: '10.6.0.0/16',
|
|
||||||
addresses: []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
shortName: 'PP',
|
|
||||||
name: 'Ponta Porã',
|
|
||||||
cidr: '10.7.0.0/16',
|
|
||||||
addresses: [{ name: 'RNP', ip: '200.19.34.254' }]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
shortName: 'TL',
|
|
||||||
name: 'Três Lagoas',
|
|
||||||
cidr: '10.8.0.0/16',
|
|
||||||
addresses: [{ name: 'RNP', ip: '200.19.35.2' }]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
shortName: 'JD',
|
|
||||||
name: 'Jardim',
|
|
||||||
cidr: '10.9.0.0/16',
|
|
||||||
addresses: []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
shortName: 'NV',
|
|
||||||
name: 'Naviraí',
|
|
||||||
cidr: '10.10.0.0/16',
|
|
||||||
addresses: []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
shortName: 'DR',
|
|
||||||
name: 'Dourados',
|
|
||||||
cidr: '10.11.0.0/16',
|
|
||||||
addresses: []
|
|
||||||
}
|
|
||||||
]
|
|
||||||
|
|
||||||
export const subNets = subNetsInfo.map(subNetInfo => ({
|
|
||||||
...subNetInfo,
|
|
||||||
...ip.cidrSubnet(subNetInfo.cidr)
|
|
||||||
}))
|
|
||||||
|
|
||||||
export function getSubnetInfo(ip) {
|
|
||||||
if (!isIPv4(ip))
|
|
||||||
return {
|
|
||||||
shortName: '__',
|
|
||||||
name: 'Sem rede'
|
|
||||||
}
|
|
||||||
|
|
||||||
const subnet = subNets.find(subnet => subnet.contains(ip))
|
|
||||||
|
|
||||||
if (!subnet)
|
|
||||||
return {
|
|
||||||
shortName: '??',
|
|
||||||
name: 'Rede desconhecida'
|
|
||||||
}
|
|
||||||
|
|
||||||
return subnet
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user