summaryrefslogblamecommitdiff
path: root/arfnet2.html
blob: 26eac6a3efa4dd50506ec19aed165204c4168b3c (plain) (tree)



























                                                                   

























                                                                     
















                                                                       
                                                























                                                                         














                                      

















































































                                                               




                                 








                                                        




                                                         



                                                             





                            

















                     
                                                    




                   
                                                    




                   
                                                    












                                               
                                                          


            



                                       


            










                                       















                                             






                    
                   






                  
                  






                 
                   






               
                  






                 
                   






               
                  






                     
                   






                  
                  






               
                   






               
                  






                   
                   






                   
                  






                    
                   






                  
                  






                         
                   
                             





                
                  







                            






                  
                  






           

                   





                 

                    





                 

                   





                  

                  

               
                
                  
                
       

                     
               

                
                  
                









                                               

                    
















                   




































































































































                             









































                                                                    








                                                              
                
                    
       









                        
                          




                                     

























                                                       
                                       

                                          



























































































                                                              
                         
                                            


                  









                                        
                          



                     









                                                                 



           
                  



                                  
                   



                                            

          
                                                                


                
                                   



                                       
                                                

                         

                   
                                    
                                      








                                                               






                                                             





                                                             


                                                                    


                            


                                                     
      
                           

            




                                                                     







                                                                   
                   
                    
                                                     





                                                          
       


























                                                       

                                                                        
      


                                     
       




















                                         
        

                                                               




                             
                                                                       



                 





                                                                  


                                                                       





























































                                                







                   




                  
                      


                   




                       


          

                                       










                     
            




                        
            




                        





                   




                      
                  

               
                               

           
                   




                        
                  




                               





                   








                      
                              


                  


           


                   
                         

                        
                       

                  
                         

                               
                       

                   



                        

                  

                        
           


                   


                         


                  

                         
                               





                         
           



                         
                               
           




                         
           



                         
                               


                   











                               


           


                  
                        
                
                         


                   
                             
                
                        


                  
                           
                
                        


                   
                              
                
                        


                  
                         
                
                         


                   
                            
                
                        


                  
                        
                
                        


                   
                         
                
                         


                  
                             
                
                         


                   
                            
                
                        


                  
                        
                
                        


                   
                         
                
                        


                  
                         
                
                        


                   
                          
                
                        


                  
                        
                
                        


                   
                           
                
                        


                  
                          
                
                        


                   





                         












                          




                        




           
                  

















                                       




                                   
                  




                              
                   




                                 
                  




                               
                   




                               
                  




           
                   




                         
                  




                                           
                   




                  
                  




                    

          
                                               










                     
                               




                        
                              



                    








                                
                          

           

          
                                               

















                         
                                                             
      



                                                                       
       

               
<!doctype html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<style>
		table, td, th {
			border: 1px solid black;
		}
		th {
			padding-top: 5px;
			padding-bottom: 5px;
		}
		td {
			padding-top: 2.5px;
			padding-bottom: 2.5px;
		}
		th, td {
			padding-left: 10px;
			padding-right: 10px;
		}
		</style>
	</head>
	<body>
		<h1 id="arfnet2-deployment">ARFNET2 deployment</h1>
  <p>After the disastrous ISP <a
  href="http://arf20.com/explanation.txt">schism</a></p>
  <h2 id="masterplan">Masterplan</h2>
  <p>Stage 1: very safe</p>
  <ul>
  <li>Close all ports</li>
  <li>Nuke (or stop) all old VMs (exclude OPNSense)</li>
  <li>Make DMZ</li>
  <li>Make new basic VMs (cloning deb12 template)</li>
  <li>Open basic ports</li>
  </ul>
  <p>Stage 2: new services</p>
  <ul>
  <li>IONOS VPS for mail</li>
  <li>Some new very safe services</li>
  <li>HE IPv6 tunnel</li>
  <li>Own authoritative nameservers for domain zone</li>
  </ul>
  <p>Stage 3*: finally</p>
  <ul>
  <li>Another VPS in unknown provider for
  <ul>
  <li>Tor</li>
  <li>Reverse-proxying the media library</li>
  </ul></li>
  <li>PHP on main site with more web services from scratch, hopefully
  secure</li>
  <li>More new services</li>
  </ul>
  <h2 id="domain">Domain</h2>
  <p>arf20.com</p>
  <p>Registrar: namecheap</p>
  <h3 id="name-sever-glue-records-at-registrar">Name sever glue records
  at registrar</h3>
  <table>
  <thead>
  <tr class="header">
  <th>Nameserver</th>
  <th>Name</th>
  <th>IP</th>
  </tr>
  </thead>
  <tbody>
  <tr class="odd">
  <td>NS1</td>
  <td>ns1.arf20.com</td>
  <td>2.59.235.35 <br> 2600:70ff:f039:4::13</td>
  </tr>
  <tr class="even">
  <td>NS2</td>
  <td>ns2.arf20.com</td>
  <td>5.250.186.185 <br> 2001:ba0:210:d600::1</td>
  </tr>
  </tbody>
  </table>
  <h2 id="networking">Networking</h2>
  <h3 id="hardware">Hardware</h3>
  <pre><code>                   WAP
                    |
       +-----+   +--------------------------+     +----------------+
ISP ===| ONT |---| DELL switch              |-----| TP-Link switch |
       +-----+   +--------------------------+     +----------------+
                    |        |          |                |
                    |        |          |                |
                 +---------------+  Rest of devices   Living room devices
                 | eno1     eno2 |
                 | server router |
                 +---------------+
                   
- 1000BASE-T
= GPON fiber</code></pre>
  <p>12U rack</p>
  <pre><code>+--------------+--------+
| drawer       |        |
| drawer       | PDU    |
| patch panel  |        |
| switch       |        |
|              |        |
|              |        |
| R720         |        |
| R720         |        |
|              |        |
|              |        |
|              |        |
|              | UPS    |
+--------------+--------+</code></pre>
  <h4 id="dell-powerconnect-5424-switch">DELL PowerConnect 5424
  switch</h4>
  <p>Port assignents</p>
  <table>
  <thead>
  <tr class="header">
  <th>port</th>
  <th>endpoint</th>
  <th>options</th>
  </tr>
  </thead>
  <tbody>
  <tr class="odd">
  <td>g2</td>
  <td>ONT</td>
  <td>VLAN access 2</td>
  </tr>
  <tr class="even">
  <td>g4</td>
  <td>server eno2 WAN</td>
  <td>VLAN access 2</td>
  </tr>
  <tr class="odd">
  <td>g6</td>
  <td>test2</td>
  <td>VLAN access 2</td>
  </tr>
  <tr class="even">
  <td>g3</td>
  <td>WAP</td>
  <td>VLAN access 5</td>
  </tr>
  <tr class="odd">
  <td>g5</td>
  <td>PC</td>
  <td>VLAN access 4</td>
  </tr>
  <tr class="even">
  <td>g7</td>
  <td>Living R.</td>
  <td>VLAN access 5</td>
  </tr>
  <tr class="odd">
  <td>g9</td>
  <td>server eno1 DMZ+LAN</td>
  <td>VLAN trunk 4, 5</td>
  </tr>
  <tr class="even">
  <td>g15</td>
  <td>test4</td>
  <td>VLAN access 4</td>
  </tr>
  <tr class="odd">
  <td>g17</td>
  <td>test1</td>
  <td>VLAN access 1</td>
  </tr>
  <tr class="even">
  <td>g19</td>
  <td>test5</td>
  <td>VLAN access 5</td>
  </tr>
  <tr class="odd">
  <td>g21</td>
  <td>iDRAC</td>
  <td>VLAN access 4</td>
  </tr>
  <tr class="even">
  <td>g23</td>
  <td>printer</td>
  <td>VLAN access 4</td>
  </tr>
  </tbody>
  </table>
  <p>Management</p>
  <ul>
  <li>interface vlan 4: 192.168.4.2/24 gw 192.168.4.1</li>
  </ul>
  <h3 id="public-ips">Public IPs</h3>
  <ul>
  <li>AVANZA_STATIC: 2.59.235.35</li>
  <li>AVANZA_CGNAT: dynamic</li>
  <li>HE prefixes
  <ul>
  <li>2001:470:1f21:125::/64</li>
  <li>2600:70ff:f039::/48</li>
  </ul></li>
  <li>IONOS VPS: 5.250.186.185 2001:ba0:210:d600::1</li>
  </ul>
  <h3 id="gateways">Gateways</h3>
  <ul>
  <li>AVANZA
  <ul>
  <li>WAN_STATIC: 2.59.235.1</li>
  <li>WAN_CGNAT: dynamic</li>
  </ul></li>
  <li>HE v6 tunnel
  <ul>
  <li>server: 216.66.87.102, 2001:470:1f20:125::1/64</li>
  <li>client: 2.59.235.35, 2001:470:1f20:125::2</li>
  </ul></li>
  </ul>
  <h3 id="physical-and-logical-networks">Physical and Logical
  Networks</h3>
  <table>
  <colgroup>
  <col style="width: 26%" />
  <col style="width: 26%" />
  <col style="width: 21%" />
  <col style="width: 26%" />
  </colgroup>
  <thead>
  <tr class="header">
  <th>name</th>
  <th>VLAN</th>
  <th>net</th>
  <th>desc</th>
  </tr>
  </thead>
  <tbody>
  <tr class="odd">
  <td>WAN</td>
  <td>2</td>
  <td></td>
  <td></td>
  </tr>
  <tr class="even">
  <td>DMZ</td>
  <td>4</td>
  <td>192.168.4.0/24 <br> 2600:70ff:f039:4::/64</td>
  <td>Services</td>
  </tr>
  <tr class="odd">
  <td>LAN</td>
  <td>5</td>
  <td>192.168.5.0/24 <br> 2600:70ff:f039:5::/64</td>
  <td>Clients</td>
  </tr>
  <tr class="even">
  <td>VPN</td>
  <td></td>
  <td>192.168.6.0/24 <br> 2600:70ff:f039:6::/64</td>
  <td>Wireguard clients</td>
  </tr>
  </tbody>
  </table>
  <h2 id="firewall">Firewall</h2>
  <h3 id="interface-rules">Interface Rules</h3>
  <ul>
  <li>WAN_CGNAT in
  <ul>
  <li>deny *</li>
  </ul></li>
  <li>WAN_STATIC in
  <ul>
  <li>allow v4 from * to {services} –&gt; NAT rules</li>
  </ul></li>
  <li>DMZ in
  <ul>
  <li>deny v4 to LAN net</li>
  <li>allow v4 to firewall</li>
  <li>allow v4 to * gw WAN_STATIC</li>
  <li>allow v6 to * gw HE_TUNNELV6</li>
  </ul></li>
  <li>LAN in
  <ul>
  <li>allow v4 ICMP to firewall</li>
  <li>allow v4 IP DNS to firewall</li>
  <li>allow v4 to DMZ net</li>
  <li>allow v4 to * gw WAN_CGNAT</li>
  <li>allow v6 to * gw HE_TUNNELV6</li>
  </ul></li>
  <li>Wireguard in
  <ul>
  <li>allow v4+6 to DMZ net</li>
  <li>allow v4 to * gw WAN_CGNAT</li>
  <li>allow v6 to * gw HE_TUNNELV6</li>
  </ul></li>
  </ul>
  <h3 id="ipv4-nat-rules">IPv4 NAT Rules</h3>
  <table>
  <thead>
  <tr class="header">
  <th>Service</th>
  <th>Customer</th>
  <th>IPProto</th>
  <th>Ext Port</th>
  <th>Host</th>
  <th>Re Port</th>
  </tr>
  </thead>
  <tbody>
  <tr class="odd">
  <td>WireGuard</td>
  <td></td>
  <td>UDP</td>
  <td>51820</td>
  <td>router</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>DNS NS1</td>
  <td></td>
  <td>TCP/UDP</td>
  <td>53</td>
  <td>misc</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>iperf3</td>
  <td></td>
  <td>TCP</td>
  <td>5201</td>
  <td>misc</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>NNTP</td>
  <td></td>
  <td>TCP</td>
  <td>119</td>
  <td>misc</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>Web</td>
  <td></td>
  <td>TCP</td>
  <td>80,443</td>
  <td>web</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>Git</td>
  <td></td>
  <td>TCP</td>
  <td>9418</td>
  <td>web</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>bittorrent</td>
  <td></td>
  <td>TCP/UDP</td>
  <td>8999</td>
  <td>nas</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>rsync</td>
  <td></td>
  <td>TCP/UDP</td>
  <td>873</td>
  <td>nas</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>IRC</td>
  <td></td>
  <td>TCP</td>
  <td>6667</td>
  <td>comm</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>IRCS</td>
  <td></td>
  <td>TCP</td>
  <td>6697</td>
  <td>comm</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>XMPP c2s</td>
  <td></td>
  <td>TCP</td>
  <td>5222</td>
  <td>comm</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>XMPP s2s</td>
  <td></td>
  <td>TCP</td>
  <td>5269</td>
  <td>comm</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>TURN STUN</td>
  <td></td>
  <td>TCP/UDP</td>
  <td>3478</td>
  <td>comm</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>TURN</td>
  <td></td>
  <td>TCP/UDP</td>
  <td>5349</td>
  <td>comm</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>TURN UDP relay</td>
  <td></td>
  <td>TCP/UDP</td>
  <td>49152-50176</td>
  <td>comm</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>mc waterfall proxy</td>
  <td></td>
  <td>TCP</td>
  <td>25565</td>
  <td>game</td>
  <td>25567</td>
  </tr>
  <tr class="odd">
  <td>mc bedrock geyser</td>
  <td></td>
  <td>TCP</td>
  <td>19132</td>
  <td>game</td>
  <td>19132</td>
  </tr>
  <tr class="even">
  <td>css-ds</td>
  <td></td>
  <td>TCP/UDP</td>
  <td>27015</td>
  <td>game</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td></td>
  <td></td>
  <td></td>
  <td></td>
  <td></td>
  <td></td>
  </tr>
  <tr class="even">
  <td>exo ssh</td>
  <td>exo</td>
  <td>TCP</td>
  <td>4041</td>
  <td>exovps</td>
  <td>22</td>
  </tr>
  <tr class="odd">
  <td>exo extra</td>
  <td>exo</td>
  <td>TCP</td>
  <td>4040</td>
  <td>exovps</td>
  <td>4040</td>
  </tr>
  <tr class="even">
  <td>yero ssh</td>
  <td>yero</td>
  <td>TCP</td>
  <td>1511</td>
  <td>yerovps</td>
  <td>22</td>
  </tr>
  <tr class="odd">
  <td>yero mc</td>
  <td>yero</td>
  <td>TCP</td>
  <td>25569</td>
  <td>yerovps</td>
  <td>25565</td>
  </tr>
  <tr class="even">
  <td>yero panel</td>
  <td>yero</td>
  <td>TCP</td>
  <td>24444</td>
  <td>yerovps</td>
  <td>24444</td>
  </tr>
  </tbody>
  </table>
  <h3 id="ipv6-port-rules">IPv6 port rules</h3>
  <table>
  <thead>
  <tr class="header">
  <th>Service</th>
  <th>Customer</th>
  <th>IPProto</th>
  <th>Dest Host</th>
  <th>Dest Port</th>
  </tr>
  </thead>
  <tbody>
  <tr class="odd">
  <td>DNS NS1</td>
  <td></td>
  <td>TCP/UDP</td>
  <td>misc</td>
  <td>53</td>
  </tr>
  <tr class="even">
  <td>Web</td>
  <td></td>
  <td>TCP</td>
  <td>web</td>
  <td>80,443</td>
  </tr>
  <tr class="odd">
  <td>NNTP</td>
  <td></td>
  <td>TCP</td>
  <td>misc</td>
  <td>119</td>
  </tr>
  <tr class="even">
  <td>iperf3</td>
  <td></td>
  <td>TCP</td>
  <td>misc</td>
  <td>5201</td>
  </tr>
  <tr class="odd">
  <td>Git</td>
  <td></td>
  <td>TCP</td>
  <td>9418</td>
  <td>web</td>
  </tr>
  <tr class="even">
  <td>bittorrent</td>
  <td></td>
  <td>TCP/UDP</td>
  <td>8999</td>
  <td>nas</td>
  </tr>
  <tr class="odd">
  <td>rsync</td>
  <td></td>
  <td>TCP/UDP</td>
  <td>873</td>
  <td>nas</td>
  </tr>
  <tr class="even">
  <td>IRC</td>
  <td></td>
  <td>TCP</td>
  <td>6667</td>
  <td>comm</td>
  </tr>
  <tr class="odd">
  <td>IRCS</td>
  <td></td>
  <td>TCP</td>
  <td>6697</td>
  <td>comm</td>
  </tr>
  <tr class="even">
  <td>XMPP c2s</td>
  <td></td>
  <td>TCP</td>
  <td>5222</td>
  <td>comm</td>
  </tr>
  <tr class="odd">
  <td>XMPP s2s</td>
  <td></td>
  <td>TCP</td>
  <td>5269</td>
  <td>comm</td>
  </tr>
  <tr class="even">
  <td>TURN STUN</td>
  <td></td>
  <td>TCP/UDP</td>
  <td>3478</td>
  <td>comm</td>
  </tr>
  <tr class="odd">
  <td>TURN</td>
  <td></td>
  <td>TCP/UDP</td>
  <td>5349</td>
  <td>comm</td>
  </tr>
  <tr class="even">
  <td>TURN UDP relay</td>
  <td></td>
  <td>TCP/UDP</td>
  <td>49152-50176</td>
  <td>comm</td>
  </tr>
  <tr class="odd">
  <td>mc-waterfall-proxy</td>
  <td></td>
  <td>TCP</td>
  <td>25565</td>
  <td>game</td>
  </tr>
  <tr class="even">
  <td></td>
  <td></td>
  <td></td>
  <td></td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>exo-ssh</td>
  <td>exo</td>
  <td>TCP</td>
  <td>4041</td>
  <td>exovps</td>
  </tr>
  <tr class="even">
  <td>exo-extra</td>
  <td>exo</td>
  <td>TCP</td>
  <td>4040</td>
  <td>exovps</td>
  </tr>
  <tr class="odd">
  <td>yero-ssh</td>
  <td>yero</td>
  <td>TCP</td>
  <td>1511</td>
  <td>yerovps</td>
  </tr>
  <tr class="even">
  <td>yero-sql</td>
  <td>yero</td>
  <td>TCP</td>
  <td>1512</td>
  <td>yerovps</td>
  </tr>
  <tr class="odd">
  <td>FiveM SuperioresRP</td>
  <td>yero</td>
  <td>TCP/UDP</td>
  <td>30120,40120</td>
  <td>yerovps</td>
  </tr>
  </tbody>
  </table>
  <h2 id="hosts">Hosts</h2>
  <ul>
  <li>server - DELL PowerEdge R720 running Proxmox PVE - …</li>
  <li>mail - IONOS VPS running Debian 12 - 5.250.186.185
  2001:ba0:210:d600::1</li>
  </ul>
  <h2 id="management">Management</h2>
  <ul>
  <li>OPNSense router DMZ.1</li>
  <li>DELL switch DMZ.2</li>
  <li>TP-Link WAP LAN.2</li>
  <li>Proxmox hypervisor DMZ.4</li>
  <li>DELL server iDRAC DMZ.5</li>
  <li>HP printer DMZ.7</li>
  </ul>
  <h2 id="server-vms-and-services">server VMs and services</h2>
  <p>server runs Proxmox PVE.</p>
  <p>All VMs are Debian 12 (templated) with wazuh agent</p>
  <h3 id="proxmox-dmz.4-hypervisor">proxmox DMZ.4 (hypervisor)</h3>
  <ul>
  <li>SSH</li>
  <li>Proxmox management interface :8006</li>
  <li>smartmon + node exporter :9100</li>
  <li>sensor exporter*</li>
  <li>NUT - Network UPS TOols daemon (and proper UPS)*</li>
  </ul>
  <h3 id="router-dmz.1">router DMZ.1</h3>
  <ul>
  <li>(routing/firewalling)</li>
  <li>SSH</li>
  <li>DHCP</li>
  <li>unbound DNS</li>
  <li>OpenVPN</li>
  <li>WireGuard</li>
  <li>IPsec*</li>
  <li>ntopng :3000</li>
  <li>telegraf - note: editing config via webfig breaks (timeout and
  unbound config)</li>
  </ul>
  <h3 id="nas-dmz.6">nas DMZ.6</h3>
  <p>RAID attached here (with the grey stuff) (local only)</p>
  <ul>
  <li>SSH</li>
  <li>NFS</li>
  <li>Samba SMB*</li>
  <li>MiniDLNA*</li>
  <li>FTP</li>
  <li>qBittorrent-nox</li>
  <li>jellyfin</li>
  <li>nginx</li>
  <li>mpd :8000</li>
  </ul>
  <table>
  <thead>
  <tr class="header">
  <th>vhost</th>
  <th>webroot/proxy</th>
  <th>Comment</th>
  </tr>
  </thead>
  <tbody>
  <tr class="odd">
  <td>dark.arf20.com*</td>
  <td>/d/FTPServer/</td>
  <td>Allow only VPS and private</td>
  </tr>
  </tbody>
  </table>
  <h3 id="web-dmz.9">web DMZ.9</h3>
  <ul>
  <li>SSH</li>
  <li>cerbot</li>
  <li>nginx (status at :8080)</li>
  <li>fastcgi PHP</li>
  <li>mariadb SQL</li>
  <li>nginx-prometheus-exporter :9113</li>
  <li>prometheus :9090</li>
  <li>telegraf</li>
  <li>influxdb :8086</li>
  <li>grafana :3000
  <ul>
  <li>Proxmox</li>
  <li>nginx</li>
  <li>iDRAC</li>
  </ul></li>
  <li>zabbix*</li>
  <li>netbox*</li>
  <li>fcgiwrap</li>
  <li>git-http-backend - git smart http server CGI</li>
  <li>gitd - git daemon</li>
  <li>cgit - web frontend for git</li>
  <li>phpBB - forum software</li>
  <li>Jekyll - blog static site generator thing</li>
  <li>opentracker? - bittorrent tracker*</li>
  <li>gophernicus - gopher server*</li>
  <li>photoprism - photo shit</li>
  <li>squid - http proxy server :3128</li>
  </ul>
  <table>
  <colgroup>
  <col style="width: 22%" />
  <col style="width: 48%" />
  <col style="width: 29%" />
  </colgroup>
  <thead>
  <tr class="header">
  <th>vhost</th>
  <th>webroot/proxy</th>
  <th>Comment</th>
  </tr>
  </thead>
  <tbody>
  <tr class="odd">
  <td>default</td>
  <td>&lt;return 418 im a teapot&gt;</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>default:8080</td>
  <td>&lt;return nstub_status&gt;</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>arf20.com</td>
  <td>/var/www/arf20.com/html/</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>www.arf20.com</td>
  <td>&lt;301 redirect arf20.com&gt;</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>matrix.arf20.com</td>
  <td>http://comm.lan:8008/_matrix</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>webmail.arf20.com</td>
  <td>/var/www/webmail.arf20.com/html/</td>
  <td>SquirrelMail</td>
  </tr>
  <tr class="odd">
  <td>nextcloud.arf20.com</td>
  <td>/var/www/nextcloud.arf20.com/html/</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>grafana.arf20.com</td>
  <td>http://localhost:3000</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>jellyfin.arf20.com</td>
  <td>http://nas.lan:8096</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>git.arf20.com</td>
  <td>/srv/git/</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>cgit.arf20.com</td>
  <td>fastcgi:/usr/lib/cgit/cgit.cgi</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>blog.arf20.com</td>
  <td>/var/www/blog.arf20.com/_site/</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>forum.arf20.com</td>
  <td>/var/www/forum.arf20.com/html/</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>deb.arf20.com</td>
  <td>/d/FTPServer/software/debian/</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>memes.arf20.com</td>
  <td>/var/www/memes.arf20.com/, /d/FTPserver/{dcimg, dcmemes,
  explosionsandfire}</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>news.arf20.com</td>
  <td>Web-News NNTP newsgroups frontend</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>dash.arf20.com</td>
  <td>/var/www/dash.arf20.com/html/</td>
  <td>CSTIMS</td>
  </tr>
  <tr class="even">
  <td>ftp.arf20.com</td>
  <td>/d/FTPServer/public/</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>photo.arf20.com</td>
  <td>[::1]:2342</td>
  <td>photoprism</td>
  </tr>
  <tr class="even">
  <td>radio.arf20.com</td>
  <td>/ = /var/www/radio.arf20.com/html/; /stream = nas:8000</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>os.arf20.com</td>
  <td>/ = /d/FTPServer/OS/</td>
  <td></td>
  </tr>
  <tr class="even">
  <td></td>
  <td></td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>status.yero.dev</td>
  <td>http://yerovps.lan:3001</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>panaland.arf20.com</td>
  <td>/var/www/panaland.arf20.com/html/</td>
  <td></td>
  </tr>
  </tbody>
  </table>
  <h3 id="wazuh-dmz.10---secure">wazuh DMZ.10 -&gt; secure*</h3>
  <ul>
  <li>SSH</li>
  <li>wazuh</li>
  <li>password manager server*</li>
  </ul>
  <h3 id="game-dmz.11">game DMZ.11</h3>
  <ul>
  <li>SSH</li>
  <li>waterfall (minecraft reverse proxy) :25565
  <ul>
  <li>mclobby (auth)</li>
  <li>minepau*</li>
  </ul></li>
  <li>panaland mc modded :25566</li>
  <li>css dedicated server :27015</li>
  </ul>
  <h3 id="comm-dmz.12">comm DMZ.12</h3>
  <ul>
  <li>SSH</li>
  <li>cerbot</li>
  <li>unrealircd - IRC</li>
  <li>synapse - matrix</li>
  <li>postgresql - DB for synapse</li>
  <li>pantalaimon - encrypt matterbridge traffic to matrix</li>
  <li>matterbridge - bridge channels with different protocols
  <ul>
  <li>discord</li>
  <li>matrix</li>
  <li>irc</li>
  <li>xmpp</li>
  </ul></li>
  <li>prosody - XMPP</li>
  <li>coturn - TURN server for matrix and xmpp</li>
  <li>asterisk - VoIP SIP PBX*</li>
  </ul>
  <h3 id="misc-deb12-lxc-dmz.13">misc (Deb12 LXC) DMZ.13</h3>
  <ul>
  <li>SSH</li>
  <li>iperf3</li>
  <li>bind9 - master authoritative nameserver for arf20.com zone NS1
  <ul>
  <li>public recursive*</li>
  </ul></li>
  <li>OpenLDAP LDAP*</li>
  <li>INN2 - NNTP USENET server with SDF peering</li>
  <li>Discord servers
  <ul>
  <li>gDebrid (gookie)</li>
  </ul></li>
  </ul>
  <h3 id="t2-t2-sde-dmz.15">t2 (T/2 SDE) DMZ.15</h3>
  <h3 id="pubnix-openbsd-7.5-dmz.16">pubnix (OpenBSD 7.5) DMZ.16</h3>
  <ul>
  <li>SSH</li>
  </ul>
  <h3 id="mail-arfnet-ionos-vps-5.250.186.185-2001ba0210d6001">mail
  (ARFNET-IONOS VPS) 5.250.186.185 2001:ba0:210:d600::1</h3>
  <ul>
  <li>SSH</li>
  <li>certbot</li>
  <li>postfix - MTA smtpd, submission, submissions <a
  href="https://github.com/ARF20NET/mail-conf">config</a></li>
  <li>dovecot - imapd</li>
  <li>opendkim</li>
  <li>opendmarc</li>
  <li>bind9 - slave authoritative nameserver NS2</li>
  <li>mlmmj - mailing list manager
  <ul>
  <li>installed to /usr/local/bin/mlmmj-webarchiver.sh and
  /etc/mlmmj-webarchiver</li>
  </ul></li>
  <li>mlmmj-webarchiver - mailing list archiver</li>
  </ul>
  <table>
  <colgroup>
  <col style="width: 22%" />
  <col style="width: 48%" />
  <col style="width: 29%" />
  </colgroup>
  <thead>
  <tr class="header">
  <th>vhost</th>
  <th>webroot/proxy</th>
  <th>Comment</th>
  </tr>
  </thead>
  <tbody>
  <tr class="odd">
  <td>default</td>
  <td>&lt;return 418 im a teapot&gt;</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>lists.arf20.com</td>
  <td>/ = /var/www/lists.arf20.com/html/<br> /archive =
  /srv/www/htdocs/archive/</td>
  <td>Mailing lists</td>
  </tr>
  </tbody>
  </table>
  <h3 id="proxy-arfnet-hostmenow-vps-92.60.77.4">proxy (ARFNET-HOSTMENOW
  VPS) 92.60.77.4</h3>
  <ul>
  <li>SSH</li>
  <li>IPsec tunnel</li>
  <li>nginx reverse proxy to nas</li>
  </ul>
  <table>
  <thead>
  <tr class="header">
  <th>vhost</th>
  <th>webroot/proxy</th>
  <th>Comment</th>
  </tr>
  </thead>
  <tbody>
  <tr class="odd">
  <td>default</td>
  <td>&lt;return 418 im a teapot&gt;</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>jokesondmca.mooo.com</td>
  <td>http://nas/</td>
  <td>Stuff</td>
  </tr>
  </tbody>
  </table>
  <hr />
  <h3 id="yero-debian-vps-dmz.192-yero">yero-debian VPS DMZ.192
  (yero)</h3>
  <ul>
  <li>SSH</li>
  <li>mariadb</li>
  <li>FiveM SuperioresRP</li>
  </ul>
  <h3 id="exo-debian-vps-dmz.195-exo">exo-debian VPS DMZ.195 (exo)</h3>
  <ul>
  <li>SSH</li>
  <li>netbox</li>
  </ul>
  <h3 id="loofa-debian-vps-dmz.196-loofa">loofa-debian VPS DMZ.196
  (loofa)</h3>
  <ul>
  <li>SSH</li>
  <li>?</li>
  </ul>
  <p>*TODO</p>
  <h2 id="internal-name-and-number-assignation-table">Internal Name and
  Number Assignation Table</h2>
  <p>DMZ IPv4s and IPv6 ends in the same way</p>
  <table>
  <thead>
  <tr class="header">
  <th>Addr</th>
  <th>Name</th>
  </tr>
  </thead>
  <tbody>
  <tr class="odd">
  <td>DMZ.1</td>
  <td>router.lan</td>
  </tr>
  <tr class="even">
  <td>DMZ.2</td>
  <td>switch.lan</td>
  </tr>
  <tr class="odd">
  <td>DMZ.3</td>
  <td>wap.lan</td>
  </tr>
  <tr class="even">
  <td>DMZ.4</td>
  <td>proxmox.lan</td>
  </tr>
  <tr class="odd">
  <td>DMZ.5</td>
  <td>idrac.lan</td>
  </tr>
  <tr class="even">
  <td>DMZ.6</td>
  <td>nas.lan</td>
  </tr>
  <tr class="odd">
  <td>DMZ.7</td>
  <td>printer.lan</td>
  </tr>
  <tr class="even">
  <td>DMZ.8</td>
  <td>desktop.lan</td>
  </tr>
  <tr class="odd">
  <td>DMZ.9</td>
  <td>web.lan</td>
  </tr>
  <tr class="even">
  <td>DMZ.10</td>
  <td>wazuh.lan</td>
  </tr>
  <tr class="odd">
  <td>DMZ.11</td>
  <td>game.lan</td>
  </tr>
  <tr class="even">
  <td>DMZ.12</td>
  <td>comm.lan</td>
  </tr>
  <tr class="odd">
  <td>DMZ.13</td>
  <td>misc.lan</td>
  </tr>
  <tr class="even">
  <td>DMZ.15</td>
  <td>(t2)</td>
  </tr>
  <tr class="odd">
  <td>DMZ.16</td>
  <td>pubnix</td>
  </tr>
  <tr class="even">
  <td></td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>DMZ.192</td>
  <td>yero-debian</td>
  </tr>
  <tr class="even">
  <td>DMZ.195</td>
  <td>exo-debian</td>
  </tr>
  <tr class="odd">
  <td>DMZ.196</td>
  <td>loofa-debian</td>
  </tr>
  </tbody>
  </table>
  <h2 id="dns">DNS</h2>
  <h3 id="domain-zone">Domain zone</h3>
  <table>
  <thead>
  <tr class="header">
  <th>Name</th>
  <th>Type</th>
  <th>Content</th>
  <th>Comment</th>
  </tr>
  </thead>
  <tbody>
  <tr class="odd">
  <td>@</td>
  <td>NS</td>
  <td>ns1.arf20.com</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>@</td>
  <td>NS</td>
  <td>ns2.arf20.com</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td></td>
  <td></td>
  <td></td>
  <td></td>
  </tr>
  <tr class="even">
  <td>ns1</td>
  <td>A</td>
  <td>2.59.235.35</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>ns1</td>
  <td>AAAA</td>
  <td>2600:70ff:f039:4::13</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>ns2</td>
  <td>A</td>
  <td>5.250.186.185</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>ns2</td>
  <td>AAAA</td>
  <td>2001:ba0:210:d600::1</td>
  <td></td>
  </tr>
  <tr class="even">
  <td></td>
  <td></td>
  <td></td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>arf20.com</td>
  <td>A</td>
  <td>2.59.235.35</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>arf20.com</td>
  <td>AAAA</td>
  <td>2600:70ff:f039:4::9</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td></td>
  <td></td>
  <td></td>
  <td></td>
  </tr>
  <tr class="even">
  <td>mail.arf20.com</td>
  <td>A</td>
  <td>5.250.186.185</td>
  <td>ARFNET-IONOS</td>
  </tr>
  <tr class="odd">
  <td>mail.arf20.com</td>
  <td>AAAA</td>
  <td>2001:ba0:210:d600::1</td>
  <td>ARFNET-IONOS</td>
  </tr>
  <tr class="even">
  <td>web.arf20.com</td>
  <td>A</td>
  <td>2.59.235.35</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>web.arf20.com</td>
  <td>AAAA</td>
  <td></td>
  <td></td>
  </tr>
  <tr class="even">
  <td>game.arf20.com</td>
  <td>A</td>
  <td>2.59.235.35</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>game.arf20.com</td>
  <td>AAAA</td>
  <td>2600:70ff:f039:4::11</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>comm.arf20.com</td>
  <td>A</td>
  <td>2.59.235.35</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>comm.arf20.com</td>
  <td>AAAA</td>
  <td>2600:70ff:f039:4::12</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>misc.arf20.com</td>
  <td>A</td>
  <td>2.59.235.35</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>misc.arf20.com</td>
  <td>AAAA</td>
  <td>2600:70ff:f039:4::13</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>pubnix.arf20.com</td>
  <td>A</td>
  <td>2.59.235.35</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>pubnix.arf20.com</td>
  <td>AAAA</td>
  <td>2600:70ff:f039:4::16</td>
  <td></td>
  </tr>
  <tr class="even">
  <td></td>
  <td></td>
  <td></td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>irc.arf20.com</td>
  <td>CNAME</td>
  <td>comm.arf20.com</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>jellyfin.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>matrix.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>nextcloud.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>turn.arf20.com</td>
  <td>CNAME</td>
  <td>comm.arf20.com</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>webmail.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>www.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>xmpp.arf20.com</td>
  <td>CNAME</td>
  <td>comm.arf20.com</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>xmppconf.arf20.com</td>
  <td>CNAME</td>
  <td>comm.arf20.com</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>grafana.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>git.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>cgit.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>blog.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>forum.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>deb.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>zabbix.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>memes.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>news.arf20.com</td>
  <td>CNAME</td>
  <td>misc.arf20.com</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>dash.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>ftp.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>photo.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="even">
  <td></td>
  <td></td>
  <td></td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>lahomosexualidadde.arf20.com</td>
  <td>CNAME</td>
  <td>weonpollo.xyz</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>panaland.arf20.com</td>
  <td>CNAME</td>
  <td>web.arf20.com</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td></td>
  <td></td>
  <td></td>
  <td></td>
  </tr>
  <tr class="even">
  <td>_acme-challenge.jellyfin</td>
  <td>CNAME</td>
  <td>(challenge)</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>_acme-challenge.irc</td>
  <td>CNAME</td>
  <td>(challenge)</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>_acme-challenge.matrix</td>
  <td>CNAME</td>
  <td>(challenge)</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>_acme-challenge.mail</td>
  <td>CNAME</td>
  <td>(challenge)</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>_acme-challenge.xmpp</td>
  <td>CNAME</td>
  <td>(challenge)</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td></td>
  <td></td>
  <td></td>
  <td></td>
  </tr>
  <tr class="even">
  <td>arf20.com</td>
  <td>MX</td>
  <td>mail.arf20.com</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>selector._domainkey</td>
  <td>TXT</td>
  <td>(DKIM)</td>
  <td>DKIM for selector ‘selector’</td>
  </tr>
  <tr class="even">
  <td>_dmarc</td>
  <td>TXT</td>
  <td>(DMARC)</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td>arf20.com</td>
  <td>TXT</td>
  <td>(SPF)</td>
  <td></td>
  </tr>
  </tbody>
  </table>
  <h3 id="he-v6-rdns-zone">HE v6 rDNS zone</h3>
  <table>
  <thead>
  <tr class="header">
  <th>Name</th>
  <th>Type</th>
  <th>Content</th>
  <th>Comment</th>
  </tr>
  </thead>
  <tbody>
  <tr class="odd">
  <td>2600:70ff:f039:4::13</td>
  <td>PTR</td>
  <td>ns1.arf20.com</td>
  <td></td>
  </tr>
  <tr class="even">
  <td>2600:70ff:f039:4::9</td>
  <td>PTR</td>
  <td>arf20.com</td>
  <td></td>
  </tr>
  <tr class="odd">
  <td></td>
  <td></td>
  <td></td>
  <td></td>
  </tr>
  <tr class="even">
  <td>2600:70ff:f039:4::195</td>
  <td>PTR</td>
  <td>global.dns.navy</td>
  <td></td>
  </tr>
  </tbody>
  </table>
  <h3 id="ionos-rdns-zone">IONOS rDNS zone</h3>
  <table>
  <thead>
  <tr class="header">
  <th>Name</th>
  <th>Type</th>
  <th>Content</th>
  <th>Comment</th>
  </tr>
  </thead>
  <tbody>
  <tr class="odd">
  <td>5.250.186.185</td>
  <td>PTR</td>
  <td>mail.arf20.com</td>
  <td></td>
  </tr>
  </tbody>
  </table>
  <h2 id="custom-arfnet-software">Custom ARFNET software</h2>
  <ul>
  <li><a href="https://cgit.arf20.com/arfnet2-cstims">cstims</a>:
  client, service, ticket and invoice management system</li>
  <li><a href="https://cgit.arf20.com/arfnet2-lists">lists</a>: mailing
  list browser</li>
  </ul>
	</body>
</html>