{"id":568,"date":"2026-01-25T20:58:28","date_gmt":"2026-01-25T23:58:28","guid":{"rendered":"https:\/\/www.tonev.pro.br\/?p=568"},"modified":"2026-01-25T21:45:39","modified_gmt":"2026-01-26T00:45:39","slug":"identidade-de-usuarios-no-opnsense-pfsense","status":"publish","type":"post","link":"https:\/\/www.tonev.pro.br\/?p=568","title":{"rendered":"Identity Awareness em Firewalls Open-Source: int_user_login"},"content":{"rendered":"<p>Quem utiliza firewalls open-source sabe que implementar regras baseadas em usu\u00e1rios (e n\u00e3o apenas em IPs) costuma ser um desafio. At\u00e9 o momento, as solu\u00e7\u00f5es de mercado para essa finalidade s\u00e3o propriet\u00e1rias e implicam em custo adicional.<\/p>\n<p>A principal dificuldade reside no fato de que n\u00e3o h\u00e1 um meio nativo simples para o firewall identificar de qual IP um usu\u00e1rio espec\u00edfico logou &#8211; especialmente em ambientes din\u00e2micos onde um usu\u00e1rio pode alternar entre m\u00faltiplas esta\u00e7\u00f5es, o tempo de vida do DHCP \u00e9 pequeno e n\u00e3o se deseja fazer reservas de endere\u00e7o. A alternativa comum \u00e9 o uso de IPs fixos, o que gera uma carga excessiva de gest\u00e3o e aumenta riscos de spoofing.<\/p>\n<p>Para resolver isso, desenvolvi o <a href=\"https:\/\/github.com\/ivortonev\/int_user_login\">int_user_login<\/a>. O projeto captura dados de autentica\u00e7\u00e3o e os disponibiliza via um webservice simplificado, permitindo que o firewall consulte periodicamente quais IPs pertencem a quais usu\u00e1rios.<\/p>\n<p><span class=\"break-words tvm-parent-container\"><span dir=\"ltr\">Comparando com as solu\u00e7\u00f5es comerciais, o funcionamento \u00e9 exatamente o mesmo: se v\u00e1rios usu\u00e1rios logarem do mesmo computador, o agente de identidade fica monitorando o log do Active Directory, recebe o endere\u00e7o e o reporta para o firewall. Isso pode resultar na combina\u00e7\u00e3o das libera\u00e7\u00f5es das duas contas. No caso do logout do usu\u00e1rio, o agente precisa verificar diretamente na esta\u00e7\u00e3o de trabalho para saber se a sess\u00e3o da conta est\u00e1 ativa ou foi finalizada, caso finalizada reporta a situa\u00e7\u00e3o e o firewall toma a a\u00e7\u00e3o necess\u00e1ria. \u00c9 poss\u00edvel que futuramente essa funcionalidade seja inclu\u00edda tamb\u00e9m, por\u00e9m por enquanto o tempo da sess\u00e3o \u00e9 pr\u00e9-definido &#8211; pode ser alterado &#8211; e sempre que for detectada atividade da conta o tempo \u00e9 estendido.<\/span><\/span><\/p>\n<p><span class=\"break-words tvm-parent-container\"><span dir=\"ltr\">Todo o desenvolvimento foi feito em scripts BASH e PHP. A parte da extra\u00e7\u00e3o dos dados de login \u00e9 toda em BASH e \u00e9 executado em processos batch por quest\u00f5es de simplicidade e facilidade de expans\u00e3o das funcionalidade. A interface que\u00a0 trata os dados no banco de de dados est\u00e1 em PHP. Tudo foi criado e testado em AlmaLinux 10.<\/span><\/span><\/p>\n<p>Atualmente o c\u00f3digo somente atende ambientes com Active Directory, por\u00e9m ser\u00e1 expandido tamb\u00e9m para ambientes Linux para os casos de login remoto como o SSH.<\/p>\n<p>Quem quiser testar, usar, dar uma simples olhada no c\u00f3digo ou contribuir com ideias, o <a href=\"https:\/\/github.com\/ivortonev\/int_user_login\">link do GitHub est\u00e1 aqui<\/a>!<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Quem utiliza firewalls open-source sabe que implementar regras baseadas em usu\u00e1rios (e n\u00e3o apenas em IPs) costuma ser um desafio. At\u00e9 o momento, as solu\u00e7\u00f5es de mercado para essa finalidade s\u00e3o propriet\u00e1rias e implicam em&#8230;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[22,7,2,23,3],"tags":[11,26,12,21,24,25],"class_list":["post-568","post","type-post","status-publish","format-standard","hentry","category-opnsense","category-pfsense","category-rede","category-seguranca","category-windows","tag-firewall","tag-identidade","tag-opnsense","tag-pfsense","tag-rede","tag-seguranca"],"_links":{"self":[{"href":"https:\/\/www.tonev.pro.br\/index.php?rest_route=\/wp\/v2\/posts\/568","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.tonev.pro.br\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.tonev.pro.br\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.tonev.pro.br\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.tonev.pro.br\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=568"}],"version-history":[{"count":5,"href":"https:\/\/www.tonev.pro.br\/index.php?rest_route=\/wp\/v2\/posts\/568\/revisions"}],"predecessor-version":[{"id":574,"href":"https:\/\/www.tonev.pro.br\/index.php?rest_route=\/wp\/v2\/posts\/568\/revisions\/574"}],"wp:attachment":[{"href":"https:\/\/www.tonev.pro.br\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=568"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.tonev.pro.br\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=568"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.tonev.pro.br\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=568"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}