Nie jesteś zalogowany.
Jeśli nie posiadasz konta, zarejestruj je już teraz! Pozwoli Ci ono w pełni korzystać z naszego serwisu. Spamerom dziękujemy!
Prosimy o pomoc dla małej Julki — przekaż 1% podatku na Fundacji Dzieciom zdazyć z Pomocą.
Więcej informacji na dug.net.pl/pomagamy/.
Witam, mam działający serwer OpenVPN. Utworzyłem kilka podsieci:
client-to-client push "route 10.8.1.0 255.255.255.0" ;administarorzy push "route 10.8.101.0 255.255.255.0" ;serwis push "route 10.6.0.0 255.255.255.0" ;klienci push "route 10.9.0.0 255.255.255.0" ;podsieć klientów
Chciałbym teraz nieco ograniczyć możliwości poszczególnych klientów. Chciałbym aby administratorzy mieli dostęp do wszystkich klientów. Natomiast klienci z podsieci 10.6.0.0 nie powinni mieć dostępu miedzy sobą ani do innych podsieci. Przez dostęp rozumiem np. zdalny pulpit, VNC, ICMP itp.
moja konfiguracja iptables:
#!/bin/sh iptables -F iptables -X iptables -t nat -X iptables -t nat -F iptables -P INPUT DROP iptables -P FORWARD DROP iptables -P OUTPUT ACCEPT iptables -A INPUT -i lo -j ACCEPT iptables -A INPUT -j ACCEPT -m state --state ESTABLISHED,RELATED iptables -A FORWARD -j ACCEPT -m state --state ESTABLISHED,RELATED # ICMP iptables -A INPUT -i eth0 -p icmp -j ACCEPT # OPENVPN iptables -A INPUT -m state --state NEW -m udp -p udp --dport 1194 -j ACCEPT # SSH iptables -A INPUT -i eth0 -p tcp --dport 22 -j ACCEPT # FTP iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 21 -j ACCEPT iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 12000:12003 -j ACCEPT
Próbowałem z regułami typu:
iptables -A FORWARD -i tun0 -s 10.6.0.0/24 -d 10.9.0.0/24 -j DROP iptables -A FORWARD -i tun0 -s 10.6.0.0/24 -d 10.6.0.0/24 -j DROP
ale to chyba nie tędy droga.
Z góry dzięki za pomoc.
Offline
Troszkę za mało akceptujesz w łańcuchu FORWARD.
Skoro domyślna polityka to DROP, musisz wskazać co ma przechodzić
Przykładowo dla adminów
iptables -A FORWARD -s 10.8.1.0/24 -j ACCEPT
iptables -A FORWARD -d 10.8.1.0/24 -j ACCEPT
Offline
Mój problem jest w tym, że wszystko przechodzi. A ja chciałbym ograniczyć dostęp.
aktualne iptables:
#!/bin/sh iptables -F iptables -X iptables -t nat -X iptables -t nat -F iptables -P INPUT DROP iptables -P FORWARD DROP iptables -P OUTPUT ACCEPT iptables -A INPUT -j ACCEPT -m state --state ESTABLISHED,RELATED # ICMP iptables -A INPUT -i eth0 -p icmp -j ACCEPT # OPENVPN iptables -A INPUT -m state --state NEW -m udp -p udp --dport 1194 -j ACCEPT # SSH iptables -A INPUT -i eth0 -p tcp --dport 22 -j ACCEPT # FTP iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 21 -j ACCEPT iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 12000:12003 -j ACCEPT # Administratorzy iptables -A FORWARD -s 10.8.1.0/24 -j ACCEPT iptables -A FORWARD -d 10.8.1.0/24 -j ACCEPT
Offline
Problem rozwiązany!
Musi być wyłączna funkcja "client-to-client" w pliku konfiguracyjnym serwera VPN. Dodatkowo, to czego nie byłem świadomy to brak "net.ipv4.ip_forward = 1". Dopiero wtedy zaczęły działać reguły FORWARD w iptables.
bobycob, dzięki za podpowiedzi!
pozdrawiam
ziemson
Offline
Time (s) | Query |
---|---|
0.00012 | SET CHARSET latin2 |
0.00005 | SET NAMES latin2 |
0.00090 | SELECT u.*, g.*, o.logged FROM punbb_users AS u INNER JOIN punbb_groups AS g ON u.group_id=g.g_id LEFT JOIN punbb_online AS o ON o.ident='18.119.114.250' WHERE u.id=1 |
0.00078 | REPLACE INTO punbb_online (user_id, ident, logged) VALUES(1, '18.119.114.250', 1733969331) |
0.00041 | SELECT * FROM punbb_online WHERE logged<1733969031 |
0.00081 | SELECT t.subject, t.closed, t.num_replies, t.sticky, f.id AS forum_id, f.forum_name, f.moderators, fp.post_replies, 0 FROM punbb_topics AS t INNER JOIN punbb_forums AS f ON f.id=t.forum_id LEFT JOIN punbb_forum_perms AS fp ON (fp.forum_id=f.id AND fp.group_id=3) WHERE (fp.read_forum IS NULL OR fp.read_forum=1) AND t.id=20220 AND t.moved_to IS NULL |
0.00006 | SELECT search_for, replace_with FROM punbb_censoring |
0.00094 | SELECT u.email, u.title, u.url, u.location, u.use_avatar, u.signature, u.email_setting, u.num_posts, u.registered, u.admin_note, p.id, p.poster AS username, p.poster_id, p.poster_ip, p.poster_email, p.message, p.hide_smilies, p.posted, p.edited, p.edited_by, g.g_id, g.g_user_title, o.user_id AS is_online FROM punbb_posts AS p INNER JOIN punbb_users AS u ON u.id=p.poster_id INNER JOIN punbb_groups AS g ON g.g_id=u.group_id LEFT JOIN punbb_online AS o ON (o.user_id=u.id AND o.user_id!=1 AND o.idle=0) WHERE p.topic_id=20220 ORDER BY p.id LIMIT 0,25 |
0.00081 | UPDATE punbb_topics SET num_views=num_views+1 WHERE id=20220 |
Total query time: 0.00488 s |