create_db.sql 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678
  1. -- Включаем необходимые расширения
  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 'Список контроля доступа - роли и разрешения';
  12. COMMENT ON COLUMN acl.description_english IS 'Описание на английском языке';
  13. COMMENT ON COLUMN acl.description_russian IS 'Описание на русском языке';
  14. -- Кэш компьютеров из Active Directory
  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';
  21. COMMENT ON COLUMN ad_comp_cache.name IS 'Имя компьютера в AD';
  22. COMMENT ON COLUMN ad_comp_cache.last_found IS 'Время последнего обнаружения этого компьютера';
  23. -- Правила аутентификации
  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 'Правила аутентификации и авторизации пользователей';
  33. COMMENT ON COLUMN auth_rules.rule_type IS 'Тип правила: 0=разрешить, 1=запретить, и т.д.';
  34. COMMENT ON COLUMN auth_rules.rule IS 'Идентификатор правила (уникальный)';
  35. -- Здания
  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 'Физические здания/локации';
  42. COMMENT ON COLUMN building.name IS 'Название здания';
  43. -- Системная конфигурация
  44. CREATE TABLE config (
  45. id SERIAL PRIMARY KEY,
  46. option_id INTEGER,
  47. value VARCHAR(250)
  48. );
  49. COMMENT ON TABLE config IS 'Значения системной конфигурации';
  50. -- Опции конфигурации
  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 'Доступные опции конфигурации';
  64. COMMENT ON COLUMN config_options.option_name IS 'Имя/ключ опции';
  65. COMMENT ON COLUMN config_options.draft IS 'Опция в черновом состоянии';
  66. COMMENT ON COLUMN config_options.uniq IS 'Опция уникальна (единственное значение)';
  67. -- Сетевые соединения
  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 'Текущие сетевые соединения (MAC-IP-устройство-порт)';
  76. COMMENT ON COLUMN connections.device_id IS 'ID сетевого устройства';
  77. COMMENT ON COLUMN connections.port_id IS 'ID порта устройства';
  78. COMMENT ON COLUMN connections.auth_id IS 'ID авторизации пользователя';
  79. COMMENT ON COLUMN connections.last_found IS 'Время последней активности соединения';
  80. -- Пользователи системы
  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 'Пользователи/администраторы системы';
  90. COMMENT ON COLUMN customers.login IS 'Логин пользователя';
  91. COMMENT ON COLUMN customers.rights IS 'Уровень прав доступа: 0=просмотр, 1=оператор, 2=админ, 3=суперадмин';
  92. -- Сетевые устройства
  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 'Сетевые устройства (коммутаторы, маршрутизаторы и т.д.)';
  135. COMMENT ON COLUMN devices.device_type IS 'ID типа устройства';
  136. COMMENT ON COLUMN devices.ip IS 'IP-адрес управления устройством';
  137. COMMENT ON COLUMN devices.snmp_version IS 'Версия SNMP: 0=отключено, 1=v1, 2=v2c, 3=v3';
  138. COMMENT ON COLUMN devices.discovery IS 'Включить автоматическое обнаружение';
  139. COMMENT ON COLUMN devices.active IS 'Устройство активно и мониторится';
  140. -- Экземпляры фильтров устройств
  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 'Экземпляры фильтров, назначенные устройствам';
  147. -- L3 интерфейсы устройств
  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 'Интерфейсы 3 уровня на устройствах';
  156. COMMENT ON COLUMN device_l3_interfaces.interface_type IS 'Тип интерфейса: 0=неизвестно, 1=LAN, 2=WAN, 3=DMZ';
  157. -- Модели устройств
  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 'Модели устройств и их характеристики';
  167. COMMENT ON COLUMN device_models.poe_in IS 'Поддерживает питание по Ethernet на входе';
  168. COMMENT ON COLUMN device_models.poe_out IS 'Обеспечивает питание по Ethernet';
  169. -- Порты устройств
  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 'Порты/интерфейсы сетевых устройств';
  190. COMMENT ON COLUMN device_ports.port IS 'Номер физического порта';
  191. COMMENT ON COLUMN device_ports.uplink IS 'Это аплинк-порт';
  192. COMMENT ON COLUMN device_ports.vlan IS 'VLAN по умолчанию/нативный VLAN';
  193. -- Типы устройств
  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 'Классификация типов устройств';
  200. COMMENT ON COLUMN device_types.name_russian IS 'Название типа устройства на русском';
  201. COMMENT ON COLUMN device_types.name_english IS 'Название типа устройства на английском';
  202. -- Логи DHCP
  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 сервера';
  217. COMMENT ON COLUMN dhcp_log.action IS 'Действие DHCP: DISCOVER, REQUEST, ACK, NAK, RELEASE';
  218. COMMENT ON COLUMN dhcp_log.circuit_id IS 'DHCP опция 82 circuit ID';
  219. -- Очередь DHCP
  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 'Очередь отложенных операций DHCP';
  229. -- DNS кэш
  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 разрешений';
  237. -- Очередь DNS
  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 'Очередь отложенных операций DNS';
  247. COMMENT ON COLUMN dns_queue.name_type IS 'Тип DNS записи: A, AAAA, PTR, CNAME';
  248. COMMENT ON COLUMN dns_queue.operation_type IS 'Тип операции: add, delete, update';
  249. -- Экземпляры фильтров
  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 'Экземпляры политик фильтрации';
  256. -- Список правил фильтрации
  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/фильтрации';
  268. COMMENT ON COLUMN filter_list.proto IS 'Протокол: tcp, udp, icmp и т.д.';
  269. COMMENT ON COLUMN filter_list.dst IS 'IP/CIDR назначения';
  270. COMMENT ON COLUMN filter_list.filter_type IS 'Тип правила: 0=разрешить, 1=запретить';
  271. -- Шлюзы подсетей
  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 'Какие устройства являются шлюзами для каких подсетей';
  278. -- Назначения фильтров группам
  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 'Правила фильтрации, назначенные группам';
  287. COMMENT ON COLUMN group_filters.rule_order IS 'Порядок обработки правил';
  288. COMMENT ON COLUMN group_filters.action IS 'Действие: 1=разрешить, 0=запретить';
  289. -- Группы фильтров
  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 'Группы политик фильтрации';
  297. -- История MAC-адресов
  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-адресов';
  309. COMMENT ON COLUMN mac_history.mac IS 'MAC-адрес (12 шестнадцатеричных символов)';
  310. COMMENT ON COLUMN mac_history.ip IS 'Последний использованный IP-адрес';
  311. -- Производители MAC-адресов
  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-адресам';
  319. COMMENT ON COLUMN mac_vendors.oui IS 'Organizationally Unique Identifier (первые 6 символов MAC)';
  320. -- Организационные единицы
  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 'Организационные единицы (отделы/группы)';
  339. COMMENT ON COLUMN ou.ou_name IS 'Имя/идентификатор ou';
  340. COMMENT ON COLUMN ou.life_duration IS 'Время жизни по умолчанию в часах для динамических записей';
  341. -- Очереди шейпинга трафика
  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 'Профили полосы пропускания для шейпинга трафика';
  349. COMMENT ON COLUMN queue_list.download IS 'Ограничение скорости скачивания в Кбит/с';
  350. COMMENT ON COLUMN queue_list.upload IS 'Ограничение скорости отдачи в Кбит/с';
  351. -- Удаленные syslog сообщения
  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 сообщения от сетевых устройств';
  360. -- PHP сессии
  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 сессий';
  367. -- Сетевые подсети
  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 'Конфигурация сетевых подсетей';
  390. COMMENT ON COLUMN subnets.subnet IS 'Сеть в нотации CIDR';
  391. COMMENT ON COLUMN subnets.vlan_tag IS 'ID VLAN для этой подсети';
  392. COMMENT ON COLUMN subnets.office IS 'Это офисная подсеть';
  393. COMMENT ON COLUMN subnets.hotspot IS 'Это публичная/гостевая подсеть';
  394. COMMENT ON COLUMN subnets.notify IS 'Битовая маска для уведомлений по типу событий';
  395. -- Подробные логи трафика
  396. CREATE TABLE traffic_detail (
  397. id BIGSERIAL PRIMARY KEY,
  398. auth_id bigint,
  399. router_id integer NOT NULL DEFAULT 0,
  400. ts TIMESTAMP,
  401. proto smallint,
  402. src_ip bigint NOT NULL DEFAULT 0,
  403. dst_ip bigint NOT NULL DEFAULT 0,
  404. src_port integer NOT NULL DEFAULT 0,
  405. dst_port integer NOT NULL DEFAULT 0,
  406. bytes bigint NOT NULL DEFAULT 0,
  407. pkt bigint NOT NULL DEFAULT 0
  408. );
  409. COMMENT ON TABLE traffic_detail IS 'Подробные записи потоков трафика (NetFlow)';
  410. COMMENT ON COLUMN traffic_detail.proto IS 'Номер IP протокола';
  411. COMMENT ON COLUMN traffic_detail.src_ip IS 'Исходный IP в виде целого числа';
  412. COMMENT ON COLUMN traffic_detail.dst_ip IS 'Адрес назначения IP в виде целого числа';
  413. COMMENT ON COLUMN traffic_detail.bytes IS 'Байтов переданно в этом потоке';
  414. -- Неизвестные MAC-адреса
  415. CREATE TABLE unknown_mac (
  416. id BIGSERIAL PRIMARY KEY,
  417. mac VARCHAR(12),
  418. port_id BIGINT,
  419. device_id INTEGER,
  420. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
  421. );
  422. COMMENT ON TABLE unknown_mac IS 'Недавно обнаруженные неизвестные MAC-адреса';
  423. -- Записи авторизации пользователей
  424. CREATE TABLE user_auth (
  425. id SERIAL PRIMARY KEY,
  426. user_id BIGINT NOT NULL DEFAULT 0,
  427. ou_id INTEGER,
  428. ip INET DEFAULT NULL,
  429. ip_int BIGINT NOT NULL DEFAULT 0,
  430. save_traf SMALLINT NOT NULL DEFAULT 0,
  431. enabled SMALLINT NOT NULL DEFAULT 0,
  432. dhcp SMALLINT NOT NULL DEFAULT 1,
  433. filter_group_id SMALLINT NOT NULL DEFAULT 0,
  434. dynamic SMALLINT NOT NULL DEFAULT 0,
  435. end_life TIMESTAMP,
  436. deleted SMALLINT NOT NULL DEFAULT 0,
  437. description VARCHAR(250),
  438. dns_name VARCHAR(253),
  439. dns_ptr_only SMALLINT NOT NULL DEFAULT 0,
  440. WikiName VARCHAR(250),
  441. dhcp_acl TEXT,
  442. queue_id INTEGER NOT NULL DEFAULT 0,
  443. mac VARCHAR(20) NOT NULL DEFAULT '',
  444. dhcp_action VARCHAR(10) NOT NULL DEFAULT '',
  445. dhcp_option_set VARCHAR(50),
  446. dhcp_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  447. dhcp_hostname VARCHAR(60),
  448. last_found TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  449. arp_found TIMESTAMP,
  450. mac_found TIMESTAMP,
  451. blocked SMALLINT NOT NULL DEFAULT 0,
  452. day_quota INTEGER NOT NULL DEFAULT 0,
  453. month_quota INTEGER NOT NULL DEFAULT 0,
  454. device_model_id INTEGER DEFAULT 87,
  455. firmware VARCHAR(100),
  456. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  457. client_id VARCHAR(250),
  458. nagios SMALLINT NOT NULL DEFAULT 0,
  459. nagios_status VARCHAR(10) NOT NULL DEFAULT '',
  460. nagios_handler VARCHAR(50) NOT NULL DEFAULT '',
  461. link_check SMALLINT NOT NULL DEFAULT 0,
  462. changed SMALLINT NOT NULL DEFAULT 0,
  463. dhcp_changed SMALLINT NOT NULL DEFAULT 0,
  464. changed_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  465. created_by VARCHAR(10)
  466. );
  467. COMMENT ON TABLE user_auth IS 'Записи авторизации пользователей/устройств в сети';
  468. COMMENT ON COLUMN user_auth.enabled IS 'Эта авторизация активна';
  469. COMMENT ON COLUMN user_auth.dynamic IS 'Это динамически созданная запись';
  470. COMMENT ON COLUMN user_auth.day_quota IS 'Дневная квота трафика в байтах';
  471. COMMENT ON COLUMN user_auth.nagios IS 'Включить мониторинг Nagios для этого хоста';
  472. -- Алиасы авторизации пользователей
  473. CREATE TABLE user_auth_alias (
  474. id SERIAL PRIMARY KEY,
  475. auth_id INTEGER NOT NULL,
  476. alias VARCHAR(100),
  477. description VARCHAR(100),
  478. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
  479. );
  480. COMMENT ON TABLE user_auth_alias IS 'Алиасы/DNS имена для записей авторизации';
  481. -- Список пользователей
  482. CREATE TABLE user_list (
  483. id BIGSERIAL PRIMARY KEY,
  484. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  485. login VARCHAR(255),
  486. description VARCHAR(255),
  487. enabled SMALLINT NOT NULL DEFAULT 1,
  488. blocked SMALLINT NOT NULL DEFAULT 0,
  489. deleted SMALLINT NOT NULL DEFAULT 0,
  490. ou_id INTEGER NOT NULL DEFAULT 0,
  491. device_id INTEGER,
  492. filter_group_id INTEGER NOT NULL DEFAULT 0,
  493. queue_id INTEGER NOT NULL DEFAULT 0,
  494. day_quota INTEGER NOT NULL DEFAULT 0,
  495. month_quota INTEGER NOT NULL DEFAULT 0,
  496. permanent SMALLINT NOT NULL DEFAULT 0
  497. );
  498. COMMENT ON TABLE user_list IS 'Учетные записи пользователей в системе';
  499. COMMENT ON COLUMN user_list.description IS 'Фамилия Имя Отчество';
  500. COMMENT ON COLUMN user_list.permanent IS 'Это постоянный пользователь (не динамический)';
  501. -- Сессии пользователей (веб-интерфейс)
  502. CREATE TABLE user_sessions (
  503. id SERIAL PRIMARY KEY,
  504. session_id VARCHAR(128) NOT NULL,
  505. user_id INTEGER NOT NULL,
  506. ip_address VARCHAR(45) NOT NULL,
  507. user_agent TEXT NOT NULL,
  508. created_at INTEGER NOT NULL,
  509. last_activity INTEGER NOT NULL,
  510. is_active SMALLINT DEFAULT 1
  511. );
  512. COMMENT ON TABLE user_sessions IS 'Сессии пользователей веб-интерфейса';
  513. -- Статистика трафика пользователей
  514. CREATE TABLE user_stats (
  515. id BIGSERIAL PRIMARY KEY,
  516. router_id BIGINT DEFAULT 0,
  517. auth_id BIGINT NOT NULL DEFAULT 0,
  518. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  519. byte_in BIGINT NOT NULL DEFAULT 0,
  520. byte_out BIGINT NOT NULL DEFAULT 0
  521. pkt_in INTEGER,
  522. pkt_out INTEGER,
  523. step SMALLINT NOT NULL DEFAULT 3600
  524. );
  525. COMMENT ON TABLE user_stats IS 'Статистика трафика пользователей (агрегированная)';
  526. -- Подробная статистика пользователей
  527. CREATE TABLE user_stats_full (
  528. id BIGSERIAL PRIMARY KEY,
  529. router_id BIGINT DEFAULT 0,
  530. auth_id BIGINT NOT NULL DEFAULT 0,
  531. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  532. byte_in BIGINT NOT NULL DEFAULT 0,
  533. byte_out BIGINT NOT NULL DEFAULT 0,
  534. pkt_in INTEGER,
  535. pkt_out INTEGER,
  536. step SMALLINT NOT NULL DEFAULT 600
  537. );
  538. COMMENT ON TABLE user_stats_full IS 'Подробная статистика трафика пользователей';
  539. COMMENT ON COLUMN user_stats_full.step IS 'Интервал сбора статистики в секундах';
  540. -- Временные переменные
  541. CREATE TABLE variables (
  542. id SERIAL PRIMARY KEY,
  543. name VARCHAR(30) NOT NULL UNIQUE,
  544. value VARCHAR(255),
  545. clear_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  546. created TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
  547. );
  548. COMMENT ON TABLE variables IS 'Временные системные переменные и блокировки';
  549. -- Производители устройств
  550. CREATE TABLE vendors (
  551. id SERIAL PRIMARY KEY,
  552. name VARCHAR(40) NOT NULL
  553. );
  554. COMMENT ON TABLE vendors IS 'Производители сетевого оборудования';
  555. -- Версия системы
  556. CREATE TABLE version (
  557. id INTEGER PRIMARY KEY DEFAULT 1,
  558. version VARCHAR(10) NOT NULL DEFAULT '2.4.14'
  559. );
  560. COMMENT ON TABLE version IS 'Информация о версии системы';
  561. -- Статистика WAN интерфейсов
  562. CREATE TABLE wan_stats (
  563. id BIGSERIAL PRIMARY KEY,
  564. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  565. router_id INTEGER,
  566. interface_id INTEGER,
  567. bytes_in BIGINT NOT NULL DEFAULT 0,
  568. bytes_out BIGINT NOT NULL DEFAULT 0,
  569. forward_in BIGINT NOT NULL DEFAULT 0,
  570. forward_out BIGINT NOT NULL DEFAULT 0
  571. );
  572. COMMENT ON TABLE wan_stats IS 'Статистика трафика WAN интерфейсов';
  573. COMMENT ON COLUMN wan_stats.bytes_in IS 'Байтов получено на WAN интерфейсе';
  574. COMMENT ON COLUMN wan_stats.bytes_out IS 'Байтов отправлено с WAN интерфейса';
  575. -- Журнал активности системы
  576. CREATE TABLE worklog (
  577. id BIGSERIAL PRIMARY KEY,
  578. ts TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  579. auth_id BIGINT NOT NULL DEFAULT 0,
  580. customer VARCHAR(50) NOT NULL DEFAULT 'system',
  581. ip INET NOT NULL DEFAULT '127.0.0.1',
  582. message TEXT NOT NULL,
  583. level SMALLINT NOT NULL DEFAULT 1
  584. );
  585. COMMENT ON TABLE worklog IS 'Журнал активности и аудита системы';
  586. COMMENT ON COLUMN worklog.level IS 'Уровень логирования: 1=инфо, 2=предупреждение, 3=ошибка, 4=отладка';
  587. -- Индексы (такие же как в оригинальной структуре)
  588. CREATE INDEX idx_devices_ip ON devices(ip);
  589. CREATE INDEX idx_devices_device_type ON devices(device_type);
  590. CREATE INDEX idx_devices_active ON devices(active) WHERE active = 1;
  591. CREATE INDEX idx_device_ports_device_id ON device_ports(device_id);
  592. CREATE INDEX idx_device_ports_port ON device_ports(port);
  593. CREATE INDEX idx_device_ports_target_port_id ON device_ports(target_port_id);
  594. CREATE INDEX idx_dhcp_log_ts ON dhcp_log(ts, action);
  595. CREATE INDEX idx_dhcp_queue_ts ON dhcp_queue(ts, action);
  596. CREATE INDEX idx_dns_cache_dns ON dns_cache(dns, ip);
  597. CREATE INDEX idx_dns_cache_ts ON dns_cache(ts);
  598. CREATE INDEX idx_mac_history_mac ON mac_history(mac, ts);
  599. CREATE INDEX idx_mac_history_ip ON mac_history(ip, ts);
  600. CREATE INDEX idx_mac_history_ts ON mac_history(ts);
  601. CREATE INDEX idx_ou_ou_name_gin ON OU USING GIN(ou_name gin_trgm_ops);
  602. CREATE INDEX idx_subnets_ip_int_start ON subnets(ip_int_start, ip_int_stop);
  603. CREATE INDEX idx_subnets_dhcp ON subnets(dhcp, office, hotspot, static);
  604. CREATE INDEX idx_traffic_detail_src ON traffic_detail(auth_id, ts, router_id, src_ip);
  605. CREATE INDEX idx_traffic_detail_dst ON traffic_detail(auth_id, ts, router_id, dst_ip);
  606. CREATE INDEX idx_unknown_mac_ts ON unknown_mac(ts, device_id, port_id, mac);
  607. CREATE INDEX idx_user_auth_main ON user_auth(id, user_id, ip_int, mac, ip, deleted);
  608. CREATE INDEX idx_user_auth_deleted ON user_auth(deleted) WHERE deleted = 0;
  609. CREATE INDEX idx_user_auth_ou_id ON user_auth(ou_id);
  610. CREATE INDEX idx_user_list_main ON user_list(id, ou_id, enabled, blocked, deleted);
  611. CREATE INDEX idx_user_sessions_session_id ON user_sessions(session_id);
  612. CREATE INDEX idx_user_sessions_user_id ON user_sessions(user_id);
  613. CREATE INDEX idx_user_sessions_is_active ON user_sessions(is_active) WHERE is_active = 1;
  614. CREATE INDEX idx_user_stats_ts ON user_stats(ts, auth_id, router_id);
  615. CREATE INDEX idx_user_stats_full_ts ON user_stats_full(ts, auth_id, router_id);
  616. CREATE INDEX idx_wan_stats_time ON wan_stats(ts, router_id, interface_id);
  617. CREATE INDEX idx_worklog_customer ON worklog(customer, level, ts);
  618. CREATE INDEX idx_worklog_level_ts ON worklog(level, ts);
  619. CREATE INDEX idx_worklog_auth_id ON worklog(auth_id, level, ts);
  620. CREATE INDEX idx_worklog_ts ON worklog (ts);