create_db.sql 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677
  1. -- Enable required extensions
  2. CREATE EXTENSION IF NOT EXISTS pg_trgm;
  3. CREATE EXTENSION IF NOT EXISTS btree_gin;
  4. -- Access Control List
  5. CREATE TABLE acl (
  6. id SERIAL PRIMARY KEY,
  7. name VARCHAR(30) NOT NULL,
  8. description_english VARCHAR(250) NOT NULL,
  9. description_russian VARCHAR(250) NOT NULL
  10. );
  11. COMMENT ON TABLE acl IS 'Access Control List - roles and permissions';
  12. COMMENT ON COLUMN acl.description_english IS 'Description in English';
  13. COMMENT ON COLUMN acl.description_russian IS 'Description in Russian';
  14. -- Active Directory computer cache
  15. CREATE TABLE ad_comp_cache (
  16. id SERIAL PRIMARY KEY,
  17. name VARCHAR(63) NOT NULL UNIQUE,
  18. last_found TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
  19. );
  20. COMMENT ON TABLE ad_comp_cache IS 'Active Directory computer cache';
  21. COMMENT ON COLUMN ad_comp_cache.name IS 'Computer name in AD';
  22. COMMENT ON COLUMN ad_comp_cache.last_found IS 'Last time this computer was detected';
  23. -- Authentication rules
  24. CREATE TABLE auth_rules (
  25. id SERIAL PRIMARY KEY,
  26. user_id INTEGER,
  27. ou_id INTEGER,
  28. rule_type SMALLINT NOT NULL,
  29. rule VARCHAR(40) UNIQUE,
  30. description VARCHAR(250)
  31. );
  32. COMMENT ON TABLE auth_rules IS 'User authentication and authorization rules';
  33. COMMENT ON COLUMN auth_rules.rule_type IS 'Rule type: 0=allow, 1=deny, etc.';
  34. COMMENT ON COLUMN auth_rules.rule IS 'Rule identifier (unique)';
  35. -- Buildings
  36. CREATE TABLE building (
  37. id SERIAL PRIMARY KEY,
  38. name VARCHAR(50) NOT NULL,
  39. description VARCHAR(250)
  40. );
  41. COMMENT ON TABLE building IS 'Physical buildings/locations';
  42. COMMENT ON COLUMN building.name IS 'Building name';
  43. -- System configuration
  44. CREATE TABLE config (
  45. id SERIAL PRIMARY KEY,
  46. option_id INTEGER,
  47. value VARCHAR(250)
  48. );
  49. COMMENT ON TABLE config IS 'System configuration values';
  50. -- Configuration options
  51. CREATE TABLE config_options (
  52. id SERIAL PRIMARY KEY,
  53. option_name VARCHAR(50) NOT NULL,
  54. description_russian TEXT,
  55. description_english TEXT,
  56. draft SMALLINT NOT NULL DEFAULT 0,
  57. uniq SMALLINT NOT NULL DEFAULT 1,
  58. option_type VARCHAR(100) NOT NULL,
  59. default_value VARCHAR(250),
  60. min_value INTEGER NOT NULL DEFAULT 0,
  61. max_value INTEGER NOT NULL DEFAULT 0
  62. );
  63. COMMENT ON TABLE config_options IS 'Available configuration options';
  64. COMMENT ON COLUMN config_options.option_name IS 'Option name/key';
  65. COMMENT ON COLUMN config_options.draft IS 'Option is in draft state';
  66. COMMENT ON COLUMN config_options.uniq IS 'Option is unique (single value)';
  67. -- Network connections
  68. CREATE TABLE connections (
  69. id BIGSERIAL PRIMARY KEY,
  70. device_id BIGINT NOT NULL,
  71. port_id BIGINT NOT NULL,
  72. auth_id BIGINT NOT NULL,
  73. last_found TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
  74. );
  75. COMMENT ON TABLE connections IS 'Current network connections (MAC-IP-device-port)';
  76. COMMENT ON COLUMN connections.device_id IS 'Network device ID';
  77. COMMENT ON COLUMN connections.port_id IS 'Device port ID';
  78. COMMENT ON COLUMN connections.auth_id IS 'User authentication ID';
  79. COMMENT ON COLUMN connections.last_found IS 'Last connection activity time';
  80. -- System users
  81. CREATE TABLE customers (
  82. id SERIAL PRIMARY KEY,
  83. login VARCHAR(20),
  84. description VARCHAR(100),
  85. password VARCHAR(255),
  86. api_key VARCHAR(255),
  87. rights SMALLINT NOT NULL DEFAULT 3
  88. );
  89. COMMENT ON TABLE customers IS 'System users/administrators';
  90. COMMENT ON COLUMN customers.login IS 'User login';
  91. COMMENT ON COLUMN customers.rights IS 'Access level: 0=view, 1=operator, 2=admin, 3=superadmin';
  92. -- Network devices
  93. CREATE TABLE devices (
  94. id SERIAL PRIMARY KEY,
  95. device_type INTEGER NOT NULL DEFAULT 1,
  96. device_model_id INTEGER DEFAULT 89,
  97. firmware VARCHAR(100),
  98. vendor_id INTEGER NOT NULL DEFAULT 1,
  99. device_name VARCHAR(50),
  100. building_id INTEGER NOT NULL DEFAULT 1,
  101. ip INET DEFAULT NULL,
  102. ip_int BIGINT,
  103. login VARCHAR(50),
  104. password VARCHAR(255),
  105. protocol SMALLINT NOT NULL DEFAULT 0,
  106. control_port INTEGER NOT NULL DEFAULT 23,
  107. port_count INTEGER NOT NULL DEFAULT 0,
  108. SN VARCHAR(80),
  109. description VARCHAR(255),
  110. snmp_version SMALLINT NOT NULL DEFAULT 0,
  111. snmp3_auth_proto VARCHAR(10) NOT NULL DEFAULT 'sha512',
  112. snmp3_priv_proto VARCHAR(10) NOT NULL DEFAULT 'aes128',
  113. snmp3_user_rw VARCHAR(20),
  114. snmp3_user_rw_password VARCHAR(20),
  115. snmp3_user_ro VARCHAR(20),
  116. snmp3_user_ro_password VARCHAR(20),
  117. community VARCHAR(50) NOT NULL DEFAULT 'public',
  118. rw_community VARCHAR(50) NOT NULL DEFAULT 'private',
  119. fdb_snmp_index SMALLINT NOT NULL DEFAULT 0,
  120. discovery SMALLINT NOT NULL DEFAULT 1,
  121. netflow_save SMALLINT NOT NULL DEFAULT 0,
  122. user_acl SMALLINT NOT NULL DEFAULT 0,
  123. dhcp SMALLINT NOT NULL DEFAULT 0,
  124. nagios SMALLINT NOT NULL DEFAULT 0,
  125. active SMALLINT NOT NULL DEFAULT 1,
  126. nagios_status VARCHAR(10) NOT NULL DEFAULT 'UP',
  127. queue_enabled SMALLINT NOT NULL DEFAULT 0,
  128. connected_user_only SMALLINT NOT NULL DEFAULT 1,
  129. user_id INTEGER,
  130. deleted SMALLINT NOT NULL DEFAULT 0,
  131. discovery_locked SMALLINT NOT NULL DEFAULT 0,
  132. locked_timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  133. );
  134. COMMENT ON TABLE devices IS 'Network devices (switches, routers, etc.)';
  135. COMMENT ON COLUMN devices.device_type IS 'Device type ID';
  136. COMMENT ON COLUMN devices.ip IS 'Device management IP address';
  137. COMMENT ON COLUMN devices.snmp_version IS 'SNMP version: 0=disabled, 1=v1, 2=v2c, 3=v3';
  138. COMMENT ON COLUMN devices.discovery IS 'Enable automatic discovery';
  139. COMMENT ON COLUMN devices.active IS 'Device is active and monitored';
  140. -- Device filter instances
  141. CREATE TABLE device_filter_instances (
  142. id SERIAL PRIMARY KEY,
  143. instance_id INTEGER,
  144. device_id INTEGER
  145. );
  146. COMMENT ON TABLE device_filter_instances IS 'Filter instances assigned to devices';
  147. -- Device L3 interfaces
  148. CREATE TABLE device_l3_interfaces (
  149. id SERIAL PRIMARY KEY,
  150. device_id INTEGER,
  151. snmpin INTEGER,
  152. interface_type SMALLINT NOT NULL DEFAULT 0,
  153. name VARCHAR(100)
  154. );
  155. COMMENT ON TABLE device_l3_interfaces IS 'Layer 3 interfaces on devices';
  156. COMMENT ON COLUMN device_l3_interfaces.interface_type IS 'Interface type: 0=unknown, 1=LAN, 2=WAN, 3=DMZ';
  157. -- Device models
  158. CREATE TABLE device_models (
  159. id SERIAL PRIMARY KEY,
  160. model_name VARCHAR(200),
  161. vendor_id INTEGER DEFAULT 1,
  162. poe_in SMALLINT NOT NULL DEFAULT 0,
  163. poe_out SMALLINT NOT NULL DEFAULT 0,
  164. nagios_template VARCHAR(200)
  165. );
  166. COMMENT ON TABLE device_models IS 'Device models and their characteristics';
  167. COMMENT ON COLUMN device_models.poe_in IS 'Supports Power over Ethernet input';
  168. COMMENT ON COLUMN device_models.poe_out IS 'Provides Power over Ethernet output';
  169. -- Device ports
  170. CREATE TABLE device_ports (
  171. id BIGSERIAL PRIMARY KEY,
  172. device_id INTEGER,
  173. snmp_index INTEGER,
  174. port INTEGER,
  175. ifName VARCHAR(40),
  176. port_name VARCHAR(40),
  177. description VARCHAR(50),
  178. target_port_id INTEGER NOT NULL DEFAULT 0,
  179. auth_id BIGINT,
  180. last_mac_count INTEGER DEFAULT 0,
  181. uplink SMALLINT NOT NULL DEFAULT 0,
  182. nagios SMALLINT NOT NULL DEFAULT 0,
  183. skip SMALLINT NOT NULL DEFAULT 0,
  184. vlan INTEGER NOT NULL DEFAULT 1,
  185. tagged_vlan VARCHAR(250),
  186. untagged_vlan VARCHAR(250),
  187. forbidden_vlan VARCHAR(250)
  188. );
  189. COMMENT ON TABLE device_ports IS 'Ports/interfaces of network devices';
  190. COMMENT ON COLUMN device_ports.port IS 'Physical port number';
  191. COMMENT ON COLUMN device_ports.uplink IS 'This is an uplink port';
  192. COMMENT ON COLUMN device_ports.vlan IS 'Default/native VLAN';
  193. -- Device types
  194. CREATE TABLE device_types (
  195. id SERIAL PRIMARY KEY,
  196. name_russian VARCHAR(50),
  197. name_english VARCHAR(50)
  198. );
  199. COMMENT ON TABLE device_types IS 'Device type classification';
  200. COMMENT ON COLUMN device_types.name_russian IS 'Device type name in Russian';
  201. COMMENT ON COLUMN device_types.name_english IS 'Device type name in English';
  202. -- DHCP logs
  203. CREATE TABLE dhcp_log (
  204. id BIGSERIAL PRIMARY KEY,
  205. mac MACADDR NOT NULL,
  206. ip_int BIGINT NOT NULL,
  207. ip INET DEFAULT NULL,
  208. action VARCHAR(10) NOT NULL,
  209. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  210. auth_id BIGINT NOT NULL,
  211. dhcp_hostname VARCHAR(250),
  212. circuit_id VARCHAR(255),
  213. remote_id VARCHAR(255),
  214. client_id VARCHAR(250)
  215. );
  216. COMMENT ON TABLE dhcp_log IS 'DHCP server transaction logs';
  217. COMMENT ON COLUMN dhcp_log.action IS 'DHCP action: DISCOVER, REQUEST, ACK, NAK, RELEASE';
  218. COMMENT ON COLUMN dhcp_log.circuit_id IS 'DHCP option 82 circuit ID';
  219. -- DHCP queue
  220. CREATE TABLE dhcp_queue (
  221. id BIGSERIAL PRIMARY KEY,
  222. mac MACADDR NOT NULL,
  223. ip INET DEFAULT NULL,
  224. action VARCHAR(10) NOT NULL,
  225. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  226. dhcp_hostname VARCHAR(250)
  227. );
  228. COMMENT ON TABLE dhcp_queue IS 'Queue of deferred DHCP operations';
  229. -- DNS cache
  230. CREATE TABLE dns_cache (
  231. id BIGSERIAL PRIMARY KEY,
  232. dns VARCHAR(250),
  233. ip BIGINT,
  234. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
  235. );
  236. COMMENT ON TABLE dns_cache IS 'DNS resolution cache';
  237. -- DNS queue
  238. CREATE TABLE dns_queue (
  239. id SERIAL PRIMARY KEY,
  240. auth_id INTEGER,
  241. name_type VARCHAR(10) NOT NULL DEFAULT 'A',
  242. name VARCHAR(200),
  243. operation_type VARCHAR(10) NOT NULL DEFAULT 'add',
  244. value VARCHAR(100)
  245. );
  246. COMMENT ON TABLE dns_queue IS 'Queue of deferred DNS operations';
  247. COMMENT ON COLUMN dns_queue.name_type IS 'DNS record type: A, AAAA, PTR, CNAME';
  248. COMMENT ON COLUMN dns_queue.operation_type IS 'Operation type: add, delete, update';
  249. -- Filter instances
  250. CREATE TABLE filter_instances (
  251. id SERIAL PRIMARY KEY,
  252. name VARCHAR(50) UNIQUE,
  253. description VARCHAR(200)
  254. );
  255. COMMENT ON TABLE filter_instances IS 'Filtering policy instances';
  256. -- Firewall rule list
  257. CREATE TABLE filter_list (
  258. id SERIAL PRIMARY KEY,
  259. name VARCHAR(50),
  260. description VARCHAR(250),
  261. proto VARCHAR(10),
  262. dst TEXT,
  263. dstport VARCHAR(20),
  264. srcport VARCHAR(20),
  265. filter_type SMALLINT NOT NULL DEFAULT 0
  266. );
  267. COMMENT ON TABLE filter_list IS 'Firewall/filtering rules';
  268. COMMENT ON COLUMN filter_list.proto IS 'Protocol: tcp, udp, icmp, etc.';
  269. COMMENT ON COLUMN filter_list.dst IS 'Destination IP/CIDR';
  270. COMMENT ON COLUMN filter_list.filter_type IS 'Rule type: 0=allow, 1=deny';
  271. -- Subnet gateways
  272. CREATE TABLE gateway_subnets (
  273. id SERIAL PRIMARY KEY,
  274. device_id INTEGER,
  275. subnet_id INTEGER
  276. );
  277. COMMENT ON TABLE gateway_subnets IS 'Which devices act as gateways for which subnets';
  278. -- Group filter assignments
  279. CREATE TABLE group_filters (
  280. id SERIAL PRIMARY KEY,
  281. group_id INTEGER NOT NULL DEFAULT 0,
  282. filter_id INTEGER NOT NULL DEFAULT 0,
  283. rule_order INTEGER NOT NULL DEFAULT 0,
  284. action SMALLINT NOT NULL DEFAULT 0
  285. );
  286. COMMENT ON TABLE group_filters IS 'Filtering rules assigned to groups';
  287. COMMENT ON COLUMN group_filters.rule_order IS 'Rule processing order';
  288. COMMENT ON COLUMN group_filters.action IS 'Action: 1=allow, 0=deny';
  289. -- Filter groups
  290. CREATE TABLE group_list (
  291. id SERIAL PRIMARY KEY,
  292. instance_id INTEGER NOT NULL DEFAULT 1,
  293. group_name VARCHAR(50),
  294. description VARCHAR(250)
  295. );
  296. COMMENT ON TABLE group_list IS 'Filtering policy groups';
  297. -- MAC address history
  298. CREATE TABLE mac_history (
  299. id BIGSERIAL PRIMARY KEY,
  300. mac VARCHAR(12),
  301. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  302. device_id BIGINT,
  303. port_id BIGINT,
  304. ip INET DEFAULT NULL,
  305. auth_id BIGINT,
  306. dhcp_hostname VARCHAR(250)
  307. );
  308. COMMENT ON TABLE mac_history IS 'MAC address movement history';
  309. COMMENT ON COLUMN mac_history.mac IS 'MAC address (12 hexadecimal characters)';
  310. COMMENT ON COLUMN mac_history.ip IS 'Last used IP address';
  311. -- MAC address vendors
  312. CREATE TABLE mac_vendors (
  313. id SERIAL PRIMARY KEY,
  314. oui VARCHAR(20),
  315. companyName VARCHAR(255),
  316. companyAddress VARCHAR(255)
  317. );
  318. COMMENT ON TABLE mac_vendors IS 'MAC address vendor database';
  319. COMMENT ON COLUMN mac_vendors.oui IS 'Organizationally Unique Identifier (first 6 MAC characters)';
  320. -- Organizational Units
  321. CREATE TABLE ou (
  322. id SERIAL PRIMARY KEY,
  323. ou_name VARCHAR(40),
  324. description VARCHAR(250),
  325. default_users SMALLINT NOT NULL DEFAULT 0,
  326. default_hotspot SMALLINT NOT NULL DEFAULT 0,
  327. nagios_dir VARCHAR(255),
  328. nagios_host_use VARCHAR(50),
  329. nagios_ping SMALLINT NOT NULL DEFAULT 1,
  330. nagios_default_service VARCHAR(100),
  331. enabled SMALLINT NOT NULL DEFAULT 0,
  332. filter_group_id INTEGER NOT NULL DEFAULT 0,
  333. queue_id INTEGER NOT NULL DEFAULT 0,
  334. dynamic SMALLINT NOT NULL DEFAULT 0,
  335. life_duration DECIMAL(10,2) NOT NULL DEFAULT 24.00,
  336. parent_id INTEGER
  337. );
  338. COMMENT ON TABLE ou IS 'Organizational Units (departments/groups)';
  339. COMMENT ON COLUMN ou.ou_name IS 'ou name/identifier';
  340. COMMENT ON COLUMN ou.life_duration IS 'Default lifetime in hours for dynamic OUs';
  341. -- Traffic shaping queues
  342. CREATE TABLE queue_list (
  343. id SERIAL PRIMARY KEY,
  344. queue_name VARCHAR(20) NOT NULL,
  345. download INTEGER NOT NULL DEFAULT 0,
  346. upload INTEGER NOT NULL DEFAULT 0
  347. );
  348. COMMENT ON TABLE queue_list IS 'Bandwidth profiles for traffic shaping';
  349. COMMENT ON COLUMN queue_list.download IS 'Download speed limit in Kbit/s';
  350. COMMENT ON COLUMN queue_list.upload IS 'Upload speed limit in Kbit/s';
  351. -- Remote syslog messages
  352. CREATE TABLE remote_syslog (
  353. id BIGSERIAL PRIMARY KEY,
  354. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  355. device_id BIGINT NOT NULL,
  356. ip INET DEFAULT NULL,
  357. message TEXT NOT NULL
  358. );
  359. COMMENT ON TABLE remote_syslog IS 'Syslog messages from network devices';
  360. -- PHP sessions
  361. CREATE TABLE sessions (
  362. id VARCHAR(128) PRIMARY KEY,
  363. data TEXT NOT NULL,
  364. last_accessed INTEGER NOT NULL
  365. );
  366. COMMENT ON TABLE sessions IS 'PHP session storage';
  367. -- Network subnets
  368. CREATE TABLE subnets (
  369. id SERIAL PRIMARY KEY,
  370. subnet VARCHAR(18),
  371. vlan_tag INTEGER NOT NULL DEFAULT 1,
  372. ip_int_start BIGINT NOT NULL,
  373. ip_int_stop BIGINT NOT NULL,
  374. dhcp_start BIGINT NOT NULL DEFAULT 0,
  375. dhcp_stop BIGINT NOT NULL DEFAULT 0,
  376. dhcp_lease_time INTEGER NOT NULL DEFAULT 480,
  377. gateway BIGINT NOT NULL DEFAULT 0,
  378. office SMALLINT NOT NULL DEFAULT 1,
  379. hotspot SMALLINT NOT NULL DEFAULT 0,
  380. vpn SMALLINT NOT NULL DEFAULT 0,
  381. free SMALLINT NOT NULL DEFAULT 0,
  382. dhcp SMALLINT NOT NULL DEFAULT 1,
  383. static SMALLINT NOT NULL DEFAULT 0,
  384. dhcp_update_hostname SMALLINT NOT NULL DEFAULT 0,
  385. discovery SMALLINT NOT NULL DEFAULT 1,
  386. notify SMALLINT NOT NULL DEFAULT 7,
  387. description VARCHAR(250)
  388. );
  389. COMMENT ON TABLE subnets IS 'Network subnet configuration';
  390. COMMENT ON COLUMN subnets.subnet IS 'Network in CIDR notation';
  391. COMMENT ON COLUMN subnets.vlan_tag IS 'VLAN ID for this subnet';
  392. COMMENT ON COLUMN subnets.office IS 'This is an office subnet';
  393. COMMENT ON COLUMN subnets.hotspot IS 'This is a public/guest subnet';
  394. COMMENT ON COLUMN subnets.notify IS 'Notification bitmask: 1=email, 2=sms, 4=telegram';
  395. CREATE TABLE traffic_detail (
  396. id BIGSERIAL PRIMARY KEY,
  397. auth_id bigint,
  398. router_id integer NOT NULL DEFAULT 0,
  399. ts TIMESTAMP,
  400. proto smallint,
  401. src_ip bigint NOT NULL DEFAULT 0,
  402. dst_ip bigint NOT NULL DEFAULT 0,
  403. src_port integer NOT NULL DEFAULT 0,
  404. dst_port integer NOT NULL DEFAULT 0,
  405. bytes bigint NOT NULL DEFAULT 0,
  406. pkt bigint NOT NULL DEFAULT 0,
  407. );
  408. COMMENT ON TABLE traffic_detail IS 'Detailed traffic flow records (NetFlow)';
  409. COMMENT ON COLUMN traffic_detail.proto IS 'IP protocol number';
  410. COMMENT ON COLUMN traffic_detail.src_ip IS 'Source IP as integer';
  411. COMMENT ON COLUMN traffic_detail.dst_ip IS 'Destination IP as integer';
  412. COMMENT ON COLUMN traffic_detail.bytes IS 'Bytes transferred in this flow';
  413. -- Unknown MAC addresses
  414. CREATE TABLE unknown_mac (
  415. id BIGSERIAL PRIMARY KEY,
  416. mac VARCHAR(12),
  417. port_id BIGINT,
  418. device_id INTEGER,
  419. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
  420. );
  421. COMMENT ON TABLE unknown_mac IS 'Recently detected unknown MAC addresses';
  422. -- User authorization records
  423. CREATE TABLE user_auth (
  424. id SERIAL PRIMARY KEY,
  425. user_id BIGINT NOT NULL DEFAULT 0,
  426. ou_id INTEGER,
  427. ip INET DEFAULT NULL,
  428. ip_int BIGINT NOT NULL DEFAULT 0,
  429. save_traf SMALLINT NOT NULL DEFAULT 0,
  430. enabled SMALLINT NOT NULL DEFAULT 0,
  431. dhcp SMALLINT NOT NULL DEFAULT 1,
  432. filter_group_id SMALLINT NOT NULL DEFAULT 0,
  433. dynamic SMALLINT NOT NULL DEFAULT 0,
  434. end_life TIMESTAMP,
  435. deleted SMALLINT NOT NULL DEFAULT 0,
  436. description VARCHAR(250),
  437. dns_name VARCHAR(253),
  438. dns_ptr_only SMALLINT NOT NULL DEFAULT 0,
  439. WikiName VARCHAR(250),
  440. dhcp_acl TEXT,
  441. queue_id INTEGER NOT NULL DEFAULT 0,
  442. mac VARCHAR(20) NOT NULL DEFAULT '',
  443. dhcp_action VARCHAR(10) NOT NULL DEFAULT '',
  444. dhcp_option_set VARCHAR(50),
  445. dhcp_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  446. dhcp_hostname VARCHAR(60),
  447. last_found TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  448. arp_found TIMESTAMP,
  449. mac_found TIMESTAMP,
  450. blocked SMALLINT NOT NULL DEFAULT 0,
  451. day_quota INTEGER NOT NULL DEFAULT 0,
  452. month_quota INTEGER NOT NULL DEFAULT 0,
  453. device_model_id INTEGER DEFAULT 87,
  454. firmware VARCHAR(100),
  455. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  456. client_id VARCHAR(250),
  457. nagios SMALLINT NOT NULL DEFAULT 0,
  458. nagios_status VARCHAR(10) NOT NULL DEFAULT '',
  459. nagios_handler VARCHAR(50) NOT NULL DEFAULT '',
  460. link_check SMALLINT NOT NULL DEFAULT 0,
  461. changed SMALLINT NOT NULL DEFAULT 0,
  462. dhcp_changed SMALLINT NOT NULL DEFAULT 0,
  463. changed_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  464. created_by VARCHAR(10)
  465. );
  466. COMMENT ON TABLE user_auth IS 'User/device network authorization records';
  467. COMMENT ON COLUMN user_auth.enabled IS 'This authorization is active';
  468. COMMENT ON COLUMN user_auth.dynamic IS 'This is a dynamically created record';
  469. COMMENT ON COLUMN user_auth.day_quota IS 'Daily traffic quota in bytes';
  470. COMMENT ON COLUMN user_auth.nagios IS 'Enable Nagios monitoring for this host';
  471. -- User authorization aliases
  472. CREATE TABLE user_auth_alias (
  473. id SERIAL PRIMARY KEY,
  474. auth_id INTEGER NOT NULL,
  475. alias VARCHAR(100),
  476. description VARCHAR(100),
  477. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
  478. );
  479. COMMENT ON TABLE user_auth_alias IS 'Aliases/DNS names for authorization records';
  480. -- User list
  481. CREATE TABLE user_list (
  482. id BIGSERIAL PRIMARY KEY,
  483. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  484. login VARCHAR(255),
  485. description VARCHAR(255),
  486. enabled SMALLINT NOT NULL DEFAULT 1,
  487. blocked SMALLINT NOT NULL DEFAULT 0,
  488. deleted SMALLINT NOT NULL DEFAULT 0,
  489. ou_id INTEGER NOT NULL DEFAULT 0,
  490. device_id INTEGER,
  491. filter_group_id INTEGER NOT NULL DEFAULT 0,
  492. queue_id INTEGER NOT NULL DEFAULT 0,
  493. day_quota INTEGER NOT NULL DEFAULT 0,
  494. month_quota INTEGER NOT NULL DEFAULT 0,
  495. permanent SMALLINT NOT NULL DEFAULT 0
  496. );
  497. COMMENT ON TABLE user_list IS 'User accounts in the system';
  498. COMMENT ON COLUMN user_list.description IS 'Full name';
  499. COMMENT ON COLUMN user_list.permanent IS 'Permanent (non-dynamic) user';
  500. -- User web sessions
  501. CREATE TABLE user_sessions (
  502. id SERIAL PRIMARY KEY,
  503. session_id VARCHAR(128) NOT NULL,
  504. user_id INTEGER NOT NULL,
  505. ip_address VARCHAR(45) NOT NULL,
  506. user_agent TEXT NOT NULL,
  507. created_at INTEGER NOT NULL,
  508. last_activity INTEGER NOT NULL,
  509. is_active SMALLINT DEFAULT 1
  510. );
  511. COMMENT ON TABLE user_sessions IS 'Web interface user sessions';
  512. -- User traffic statistics
  513. CREATE TABLE user_stats (
  514. id BIGSERIAL PRIMARY KEY,
  515. router_id BIGINT DEFAULT 0,
  516. auth_id BIGINT NOT NULL DEFAULT 0,
  517. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  518. byte_in BIGINT NOT NULL DEFAULT 0,
  519. byte_out BIGINT NOT NULL DEFAULT 0,
  520. pkt_in INTEGER NOT NULL DEFAULT 0,
  521. pkt_out INTEGER NOT NULL DEFAULT 0,
  522. step SMALLINT NOT NULL DEFAULT 3600
  523. );
  524. COMMENT ON TABLE user_stats IS 'Aggregated user traffic statistics';
  525. -- Detailed user statistics
  526. CREATE TABLE user_stats_full (
  527. id BIGSERIAL PRIMARY KEY,
  528. router_id BIGINT DEFAULT 0,
  529. auth_id BIGINT NOT NULL DEFAULT 0,
  530. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  531. byte_in BIGINT NOT NULL DEFAULT 0,
  532. byte_out BIGINT NOT NULL DEFAULT 0,
  533. pkt_in INTEGER NOT NULL DEFAULT 0,
  534. pkt_out INTEGER NOT NULL DEFAULT 0,
  535. step SMALLINT NOT NULL DEFAULT 600
  536. );
  537. COMMENT ON TABLE user_stats_full IS 'Detailed user traffic statistics';
  538. COMMENT ON COLUMN user_stats_full.step IS 'Statistics collection interval in seconds';
  539. -- Temporary variables
  540. CREATE TABLE variables (
  541. id SERIAL PRIMARY KEY,
  542. name VARCHAR(30) NOT NULL UNIQUE,
  543. value VARCHAR(255),
  544. clear_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  545. created TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
  546. );
  547. COMMENT ON TABLE variables IS 'Temporary system variables and locks';
  548. -- Device vendors
  549. CREATE TABLE vendors (
  550. id SERIAL PRIMARY KEY,
  551. name VARCHAR(40) NOT NULL
  552. );
  553. COMMENT ON TABLE vendors IS 'Network equipment vendors';
  554. -- System version
  555. CREATE TABLE version (
  556. id INTEGER PRIMARY KEY DEFAULT 1,
  557. version VARCHAR(10) NOT NULL DEFAULT '3.0.0'
  558. );
  559. COMMENT ON TABLE version IS 'System version information';
  560. -- WAN interface statistics
  561. CREATE TABLE wan_stats (
  562. id BIGSERIAL PRIMARY KEY,
  563. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  564. router_id INTEGER,
  565. interface_id INTEGER,
  566. bytes_in BIGINT NOT NULL DEFAULT 0,
  567. bytes_out BIGINT NOT NULL DEFAULT 0,
  568. forward_in BIGINT NOT NULL DEFAULT 0,
  569. forward_out BIGINT NOT NULL DEFAULT 0
  570. );
  571. COMMENT ON TABLE wan_stats IS 'WAN interface traffic statistics';
  572. COMMENT ON COLUMN wan_stats.bytes_in IS 'Bytes received on WAN interface';
  573. COMMENT ON COLUMN wan_stats.bytes_out IS 'Bytes sent from WAN interface';
  574. -- System activity log
  575. CREATE TABLE worklog (
  576. id BIGSERIAL PRIMARY KEY,
  577. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  578. auth_id BIGINT NOT NULL DEFAULT 0,
  579. customer VARCHAR(50) NOT NULL DEFAULT 'system',
  580. ip INET NOT NULL DEFAULT '127.0.0.1',
  581. message TEXT NOT NULL,
  582. level SMALLINT NOT NULL DEFAULT 1
  583. );
  584. COMMENT ON TABLE worklog IS 'System activity and audit log';
  585. COMMENT ON COLUMN worklog.level IS 'Log level: 1=info, 2=warning, 3=error, 4=debug';
  586. -- Indexes (same as in the original schema)
  587. CREATE INDEX idx_devices_ip ON devices(ip);
  588. CREATE INDEX idx_devices_device_type ON devices(device_type);
  589. CREATE INDEX idx_devices_active ON devices(active) WHERE active = 1;
  590. CREATE INDEX idx_device_ports_device_id ON device_ports(device_id);
  591. CREATE INDEX idx_device_ports_port ON device_ports(port);
  592. CREATE INDEX idx_device_ports_target_port_id ON device_ports(target_port_id);
  593. CREATE INDEX idx_dhcp_log_ts ON dhcp_log(ts, action);
  594. CREATE INDEX idx_dhcp_queue_ts ON dhcp_queue(ts, action);
  595. CREATE INDEX idx_dns_cache_dns ON dns_cache(dns, ip);
  596. CREATE INDEX idx_dns_cache_ts ON dns_cache(ts);
  597. CREATE INDEX idx_mac_history_mac ON mac_history(mac, ts);
  598. CREATE INDEX idx_mac_history_ip ON mac_history(ip, ts);
  599. CREATE INDEX idx_mac_history_ts ON mac_history(ts);
  600. CREATE INDEX idx_ou_ou_name_gin ON OU USING GIN(ou_name gin_trgm_ops);
  601. CREATE INDEX idx_subnets_ip_int_start ON subnets(ip_int_start, ip_int_stop);
  602. CREATE INDEX idx_subnets_dhcp ON subnets(dhcp, office, hotspot, static);
  603. CREATE INDEX idx_traffic_detail_src ON traffic_detail(auth_id, ts, router_id, src_ip);
  604. CREATE INDEX idx_traffic_detail_dst ON traffic_detail(auth_id, ts, router_id, dst_ip);
  605. CREATE INDEX idx_unknown_mac_ts ON unknown_mac(ts, device_id, port_id, mac);
  606. CREATE INDEX idx_user_auth_main ON user_auth(id, user_id, ip_int, mac, ip, deleted);
  607. CREATE INDEX idx_user_auth_deleted ON user_auth(deleted) WHERE deleted = 0;
  608. CREATE INDEX idx_user_auth_ou_id ON user_auth(ou_id);
  609. CREATE INDEX idx_user_list_main ON user_list(id, ou_id, enabled, blocked, deleted);
  610. CREATE INDEX idx_user_sessions_session_id ON user_sessions(session_id);
  611. CREATE INDEX idx_user_sessions_user_id ON user_sessions(user_id);
  612. CREATE INDEX idx_user_sessions_is_active ON user_sessions(is_active) WHERE is_active = 1;
  613. CREATE INDEX idx_user_stats_ts ON user_stats(ts, auth_id, router_id);
  614. CREATE INDEX idx_user_stats_full_ts ON user_stats_full(ts, auth_id, router_id);
  615. CREATE INDEX idx_wan_stats_time ON wan_stats(ts, router_id, interface_id);
  616. CREATE INDEX idx_worklog_customer ON worklog(customer, level, ts);
  617. CREATE INDEX idx_worklog_ts ON worklog(level, ts);
  618. CREATE INDEX idx_worklog_auth_id ON worklog(auth_id, level, ts);
  619. CREATE INDEX idx_worklog_ts ON worklog (ts);