<?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type="text/xsl" href="../../assets/xml/rss.xsl" media="all"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>AS58280 (Articoli su ROV)</title><link>https://as58280.net/</link><description></description><atom:link href="https://as58280.net/it/categories/rov.xml" rel="self" type="application/rss+xml"></atom:link><language>it</language><copyright>Contents © 2025 &lt;a href="mailto:max@as58280.net"&gt;Max Stucchi&lt;/a&gt; </copyright><lastBuildDate>Thu, 30 Jan 2025 15:53:05 GMT</lastBuildDate><generator>Nikola (getnikola.com)</generator><docs>http://blogs.law.harvard.edu/tech/rss</docs><item><title>RPKI Origin Validation on Mikrotik</title><link>https://as58280.net/it/articles/RPKI-on-Mikrotik/</link><dc:creator>Max Stucchi</dc:creator><description>&lt;h3&gt;Configuring RPKI-based Route Origin Validation on Mikrotik&lt;/h3&gt;
&lt;p&gt;About a week ago, Mikrotik announced that the latest version of their OS - I mean, the beta version of RouterOSv7 - now has support for RPKI Origin Validation.&lt;/p&gt;
&lt;p&gt;I have decided to try to configure it and report here.&lt;/p&gt;
&lt;p&gt;Unfortunately, &lt;strong&gt;IPv6 BGP&lt;/strong&gt; in RouterOSv7 Beta 8 is &lt;strong&gt;broken&lt;/strong&gt;, in which it does not send any network announcement to the other peer in the BGP session.  This means that at the time of this writing, my whole IPv6 configuration is broken, because I can't originate any IPv6 announcement from my network.&lt;/p&gt;
&lt;p&gt;Anyway, on with the experiment.  First of all we need to find our &lt;em&gt;canary&lt;/em&gt;, a network that is covered by a ROA that makes it &lt;em&gt;invalid&lt;/em&gt;.  There is a route announced by Cloudflare that we can use, and it's all described in &lt;a href="https://blog.cloudflare.com/is-bgp-safe-yet-rpki-routing-security-initiative/"&gt;this article&lt;/a&gt;:&lt;/p&gt;
&lt;div class="code"&gt;&lt;pre class="code literal-block"&gt;&lt;span class="o"&gt;[&lt;/span&gt;admin@r1.btl.ch.as58280.net&lt;span class="o"&gt;]&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;/ipv6/route&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;print&lt;span class="w"&gt; &lt;/span&gt;where&lt;span class="w"&gt; &lt;/span&gt;dst-address&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;"2606:4700:7000::/48"&lt;/span&gt;
Flags:&lt;span class="w"&gt; &lt;/span&gt;D&lt;span class="w"&gt; &lt;/span&gt;-&lt;span class="w"&gt; &lt;/span&gt;DYNAMIC&lt;span class="p"&gt;;&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;I&lt;span class="w"&gt; &lt;/span&gt;-&lt;span class="w"&gt; &lt;/span&gt;INACTIVE,&lt;span class="w"&gt; &lt;/span&gt;A&lt;span class="w"&gt; &lt;/span&gt;-&lt;span class="w"&gt; &lt;/span&gt;ACTIVE&lt;span class="p"&gt;;&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;b&lt;span class="w"&gt; &lt;/span&gt;-&lt;span class="w"&gt; &lt;/span&gt;BGP,&lt;span class="w"&gt; &lt;/span&gt;m&lt;span class="w"&gt; &lt;/span&gt;-&lt;span class="w"&gt; &lt;/span&gt;MODEM
Columns:&lt;span class="w"&gt; &lt;/span&gt;DST-ADDRESS,&lt;span class="w"&gt; &lt;/span&gt;GATEWAY,&lt;span class="w"&gt; &lt;/span&gt;DISTANCE
&lt;span class="w"&gt;       &lt;/span&gt;DST-ADDRESS&lt;span class="w"&gt;          &lt;/span&gt;GA&lt;span class="w"&gt;  &lt;/span&gt;DI
&lt;span class="w"&gt;  &lt;/span&gt;DIb&lt;span class="w"&gt;  &lt;/span&gt;&lt;span class="m"&gt;2606&lt;/span&gt;:4700:7000::/48&lt;span class="w"&gt;  &lt;/span&gt;::&lt;span class="w"&gt;  &lt;/span&gt;&lt;span class="m"&gt;20&lt;/span&gt;
&lt;span class="w"&gt;  &lt;/span&gt;DIb&lt;span class="w"&gt;  &lt;/span&gt;&lt;span class="m"&gt;2606&lt;/span&gt;:4700:7000::/48&lt;span class="w"&gt;  &lt;/span&gt;::&lt;span class="w"&gt;  &lt;/span&gt;&lt;span class="m"&gt;20&lt;/span&gt;
&lt;/pre&gt;&lt;/div&gt;

&lt;p&gt;As you can see, we are now receiving it.  I am receiving a full IPv6 feed from &lt;a href="https://www.openfactory.ch"&gt;OpenFactory - AS58299&lt;/a&gt; at the moment.&lt;/p&gt;
&lt;p&gt;We have to do work in three stages:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;Install a validator.  In this case we will use &lt;a href="https://www.nlnetlabs.nl/projects/rpki/routinator/"&gt;routinator&lt;/a&gt; from NLNetLabs.  It's really easy to install, fast, and will fit here;&lt;/li&gt;
&lt;li&gt;Set up a connection to the validator from the router.  In this case I am running a RB4011;&lt;/li&gt;
&lt;li&gt;Use the information we obtain from the validator to filter out the invalid networks.&lt;/li&gt;
&lt;/ol&gt;
&lt;h4&gt;1. Install routinator&lt;/h4&gt;
&lt;p&gt;I have been using FreeBSD for about 20 years, so I will go ahead with it.  Routinator can also be installed on any Linux flavour.&lt;/p&gt;
&lt;p&gt;On FreeBSD, we have a package, so I will go ahead with pkg.&lt;/p&gt;
&lt;div class="code"&gt;&lt;pre class="code literal-block"&gt;root@routinator&lt;span class="w"&gt; &lt;/span&gt;/root&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;pkg&lt;span class="w"&gt; &lt;/span&gt;install&lt;span class="w"&gt; &lt;/span&gt;routinator
&lt;/pre&gt;&lt;/div&gt;

&lt;p&gt;Then configure to init it for the TALs&lt;/p&gt;
&lt;div class="code"&gt;&lt;pre class="code literal-block"&gt;sudo&lt;span class="w"&gt; &lt;/span&gt;-u&lt;span class="w"&gt; &lt;/span&gt;routinator&lt;span class="w"&gt; &lt;/span&gt;-g&lt;span class="w"&gt; &lt;/span&gt;routinator&lt;span class="w"&gt; &lt;/span&gt;routinator&lt;span class="w"&gt; &lt;/span&gt;-c&lt;span class="w"&gt; &lt;/span&gt;/usr/local/etc/routinator/routinator.conf&lt;span class="w"&gt; &lt;/span&gt;init

sudo&lt;span class="w"&gt; &lt;/span&gt;-u&lt;span class="w"&gt; &lt;/span&gt;routinator&lt;span class="w"&gt; &lt;/span&gt;-g&lt;span class="w"&gt; &lt;/span&gt;routinator&lt;span class="w"&gt; &lt;/span&gt;routinator&lt;span class="w"&gt; &lt;/span&gt;-c&lt;span class="w"&gt; &lt;/span&gt;/usr/local/etc/routinator/routinator.conf&lt;span class="w"&gt; &lt;/span&gt;init&lt;span class="w"&gt; &lt;/span&gt;--accept-arin-rpa
&lt;/pre&gt;&lt;/div&gt;

&lt;p&gt;The first command actually errored out, so I first copy the config file manually, and then re-run those two commands.&lt;/p&gt;
&lt;div class="code"&gt;&lt;pre class="code literal-block"&gt;root@routinator&lt;span class="w"&gt; &lt;/span&gt;/root&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;cp&lt;span class="w"&gt; &lt;/span&gt;/usr/local/etc/routinator/routinator.conf.example&lt;span class="w"&gt; &lt;/span&gt;/usr/local/etc/routinator/routinator.conf
&lt;/pre&gt;&lt;/div&gt;

&lt;p&gt;Additionally, I didn't have &lt;em&gt;sudo&lt;/em&gt;, so I ran the commands as root and then I changed the owner of all the directories to be the &lt;em&gt;routinator&lt;/em&gt; user.&lt;/p&gt;
&lt;p&gt;I also changed the configuration so that the directory structure is more in line with what FreeBSD uses as standard hierarchy.&lt;/p&gt;
&lt;p&gt;You can find the complete file &lt;a href="https://github.com/AS58280/AS58280-Confs/blob/master/routinator.rpki.as58280.net/usr/local/etc/routinator/routinator.conf"&gt;here&lt;/a&gt;&lt;/p&gt;
&lt;p&gt;The last thing to do is to configure routinator to run in &lt;em&gt;rc.conf&lt;/em&gt; and then run it:&lt;/p&gt;
&lt;div class="code"&gt;&lt;pre class="code literal-block"&gt;root@routinator&lt;span class="w"&gt; &lt;/span&gt;/root&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nb"&gt;echo&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s1"&gt;'routinator_enable="YES"'&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&amp;gt;&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;/etc/rc.conf
root@routinator&lt;span class="w"&gt; &lt;/span&gt;/root&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;/usr/local/etc/rc.d/routinator&lt;span class="w"&gt; &lt;/span&gt;start
&lt;/pre&gt;&lt;/div&gt;

&lt;p&gt;and now we have routinator running and listening on 45.129.224.37 port 3323.&lt;/p&gt;
&lt;p&gt;This instance of routinator is available to use, and I'll soon setup a hostname for it.&lt;/p&gt;
&lt;h4&gt;2. Configure the RTR Session&lt;/h4&gt;
&lt;p&gt;Then, on to configuring our router.  As you can see, we have a specific menu for RPKI:&lt;/p&gt;
&lt;div class="code"&gt;&lt;pre class="code literal-block"&gt;&lt;span class="o"&gt;[&lt;/span&gt;admin@r1.btl.ch.as58280.net&lt;span class="o"&gt;]&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;/routing/bgp&amp;gt;

..&lt;span class="w"&gt; &lt;/span&gt;--&lt;span class="w"&gt; &lt;/span&gt;go&lt;span class="w"&gt; &lt;/span&gt;up&lt;span class="w"&gt; &lt;/span&gt;to&lt;span class="w"&gt; &lt;/span&gt;routing
advertisements&lt;span class="w"&gt; &lt;/span&gt;--
connection&lt;span class="w"&gt; &lt;/span&gt;--
peer-cache&lt;span class="w"&gt; &lt;/span&gt;--
rpki&lt;span class="w"&gt; &lt;/span&gt;--
template&lt;span class="w"&gt; &lt;/span&gt;--
&lt;/pre&gt;&lt;/div&gt;

&lt;p&gt;The work we have to do is divided in two parts:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;Setting up communication to the routinator instance; and&lt;/li&gt;
&lt;li&gt;Setting up our filters so that we filter based on RPKI.&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;First of all, we have to configure the RTR Session.  We will connect to the routinator instance we have set up previously, so here:&lt;/p&gt;
&lt;div class="code"&gt;&lt;pre class="code literal-block"&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="nx"&gt;admin&lt;/span&gt;&lt;span class="err"&gt;@&lt;/span&gt;&lt;span class="nx"&gt;r1&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;btl&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;ch&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;as58280&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;net&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="o"&gt;/&lt;/span&gt;&lt;span class="nx"&gt;routing&lt;/span&gt;&lt;span class="o"&gt;/&lt;/span&gt;&lt;span class="nx"&gt;bgp&lt;/span&gt;&lt;span class="o"&gt;/&lt;/span&gt;&lt;span class="nx"&gt;rpki&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nx"&gt;add&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nx"&gt;address&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="m m-Double"&gt;45.129.224.37&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nx"&gt;port&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="mi"&gt;3323&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nx"&gt;preference&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="mi"&gt;1&lt;/span&gt;
&lt;/pre&gt;&lt;/div&gt;

&lt;p&gt;and I got an error while trying to print the entries:&lt;/p&gt;
&lt;div class="code"&gt;&lt;pre class="code literal-block"&gt;&lt;span class="o"&gt;[&lt;/span&gt;admin@r1.btl.ch.as58280.net&lt;span class="o"&gt;]&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;/routing/bgp/rpki&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;print
Flags:&lt;span class="w"&gt; &lt;/span&gt;X&lt;span class="w"&gt; &lt;/span&gt;-&lt;span class="w"&gt; &lt;/span&gt;disabled
&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="m"&gt;0&lt;/span&gt;&lt;span class="w"&gt;   &lt;/span&gt;&lt;span class="p"&gt;;;;&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;group&lt;span class="w"&gt; &lt;/span&gt;name&lt;span class="w"&gt; &lt;/span&gt;must&lt;span class="w"&gt; &lt;/span&gt;be&lt;span class="w"&gt; &lt;/span&gt;specified
&lt;span class="w"&gt;     &lt;/span&gt;&lt;span class="nv"&gt;address&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="m"&gt;45&lt;/span&gt;.129.224.37&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;port&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="m"&gt;3323&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;preference&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="m"&gt;1&lt;/span&gt;
&lt;span class="o"&gt;[&lt;/span&gt;admin@r1.btl.ch.as58280.net&lt;span class="o"&gt;]&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;/routing/bgp/rpki&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nb"&gt;set&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="m"&gt;0&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;group&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;

Group&lt;span class="w"&gt; &lt;/span&gt;::&lt;span class="o"&gt;=&lt;/span&gt;


&lt;span class="o"&gt;[&lt;/span&gt;admin@r1.btl.ch.as58280.net&lt;span class="o"&gt;]&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;/routing/bgp/rpki&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nb"&gt;set&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="m"&gt;0&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;group&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;validator
&lt;span class="o"&gt;[&lt;/span&gt;admin@r1.btl.ch.as58280.net&lt;span class="o"&gt;]&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;/routing/bgp/rpki&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;print
Flags:&lt;span class="w"&gt; &lt;/span&gt;X&lt;span class="w"&gt; &lt;/span&gt;-&lt;span class="w"&gt; &lt;/span&gt;disabled
&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="m"&gt;0&lt;/span&gt;&lt;span class="w"&gt;   &lt;/span&gt;&lt;span class="nv"&gt;group&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;validator&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;address&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="m"&gt;45&lt;/span&gt;.129.224.37&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;port&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="m"&gt;3323&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;preference&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="m"&gt;1&lt;/span&gt;
&lt;span class="o"&gt;[&lt;/span&gt;admin@r1.btl.ch.as58280.net&lt;span class="o"&gt;]&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;/routing/bgp/rpki&amp;gt;
&lt;/pre&gt;&lt;/div&gt;

&lt;p&gt;Turns out you can configure groups of validators to talk to, and I later on discovered that in your filters you can point to these specific groups.  That looks like an interesting feature.&lt;/p&gt;
&lt;h4&gt;3. Configure the filters&lt;/h4&gt;
&lt;p&gt;Let's go ahead and see what we need to do next with the filters.&lt;/p&gt;
&lt;div class="code"&gt;&lt;pre class="code literal-block"&gt;&lt;span class="o"&gt;[&lt;/span&gt;admin@r1.btl.ch.as58280.net&lt;span class="o"&gt;]&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;/routing/filter/rule&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;add&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;action&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;accept&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;chain&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="k"&gt;in&lt;/span&gt;-v6&lt;span class="w"&gt; &lt;/span&gt;rpki-verify&lt;span class="o"&gt;=&lt;/span&gt;validator&lt;span class="w"&gt; &lt;/span&gt;rpki-match&lt;span class="o"&gt;=&lt;/span&gt;valid
&lt;span class="o"&gt;[&lt;/span&gt;admin@r1.btl.ch.as58280.net&lt;span class="o"&gt;]&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;/routing/filter/rule&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;add&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;chain&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="k"&gt;in&lt;/span&gt;-v6&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;action&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;reject&lt;span class="w"&gt; &lt;/span&gt;match-rpki&lt;span class="o"&gt;=&lt;/span&gt;invalid
&lt;/pre&gt;&lt;/div&gt;

&lt;p&gt;and then we need to add this filter chain to the template we use for BGP.  In &lt;em&gt;/routing/bgp/template/&lt;/em&gt; I have the following:&lt;/p&gt;
&lt;div class="code"&gt;&lt;pre class="code literal-block"&gt;&lt;span class="o"&gt;[&lt;/span&gt;admin@r1.btl.ch.as58280.net&lt;span class="o"&gt;]&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;/routing/bgp/template&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;print
Flags:&lt;span class="w"&gt; &lt;/span&gt;*&lt;span class="w"&gt; &lt;/span&gt;-&lt;span class="w"&gt; &lt;/span&gt;default,&lt;span class="w"&gt; &lt;/span&gt;X&lt;span class="w"&gt; &lt;/span&gt;-&lt;span class="w"&gt; &lt;/span&gt;disabled,&lt;span class="w"&gt; &lt;/span&gt;I&lt;span class="w"&gt; &lt;/span&gt;-&lt;span class="w"&gt; &lt;/span&gt;inactive
&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="m"&gt;0&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;*&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;;;;&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;reserved&lt;span class="w"&gt; &lt;/span&gt;AS&lt;span class="w"&gt; &lt;/span&gt;value
&lt;span class="w"&gt;     &lt;/span&gt;&lt;span class="nv"&gt;name&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;"default"&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;instance&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;default

&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="m"&gt;1&lt;/span&gt;&lt;span class="w"&gt;   &lt;/span&gt;&lt;span class="nv"&gt;name&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;"stucchinet4"&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;routing-table&lt;span class="o"&gt;=&lt;/span&gt;main&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;as&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="m"&gt;58280&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;address-families&lt;span class="o"&gt;=&lt;/span&gt;ip,ipv6
&lt;span class="w"&gt;     &lt;/span&gt;output.filter&lt;span class="o"&gt;=&lt;/span&gt;out-v4&lt;span class="w"&gt; &lt;/span&gt;.network&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="m"&gt;45&lt;/span&gt;.129.224.0/22

&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="m"&gt;2&lt;/span&gt;&lt;span class="w"&gt;   &lt;/span&gt;&lt;span class="nv"&gt;name&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;"stucchinet6"&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;routing-table&lt;span class="o"&gt;=&lt;/span&gt;main&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;instance&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;default&lt;span class="w"&gt; &lt;/span&gt;apply-changes&lt;span class="o"&gt;=&lt;/span&gt;auto&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;as&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="m"&gt;58280&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;address-families&lt;span class="o"&gt;=&lt;/span&gt;ipv6&lt;span class="w"&gt; &lt;/span&gt;output.filter&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;""&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;.network&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;""&lt;/span&gt;
&lt;/pre&gt;&lt;/div&gt;

&lt;p&gt;And especially for the IPv6 template, I have no input.filter set, yet.  So let's go ahead and add it:&lt;/p&gt;
&lt;div class="code"&gt;&lt;pre class="code literal-block"&gt;&lt;span class="o"&gt;[&lt;/span&gt;admin@r1.btl.ch.as58280.net&lt;span class="o"&gt;]&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;/routing/bgp/template&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nb"&gt;set&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="m"&gt;2&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;input.filter&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="k"&gt;in&lt;/span&gt;-v6
&lt;span class="o"&gt;[&lt;/span&gt;admin@r1.btl.ch.as58280.net&lt;span class="o"&gt;]&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;/routing/bgp/template&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;print
Flags:&lt;span class="w"&gt; &lt;/span&gt;*&lt;span class="w"&gt; &lt;/span&gt;-&lt;span class="w"&gt; &lt;/span&gt;default,&lt;span class="w"&gt; &lt;/span&gt;X&lt;span class="w"&gt; &lt;/span&gt;-&lt;span class="w"&gt; &lt;/span&gt;disabled,&lt;span class="w"&gt; &lt;/span&gt;I&lt;span class="w"&gt; &lt;/span&gt;-&lt;span class="w"&gt; &lt;/span&gt;inactive
&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="m"&gt;0&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;*&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;;;;&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;reserved&lt;span class="w"&gt; &lt;/span&gt;AS&lt;span class="w"&gt; &lt;/span&gt;value
&lt;span class="w"&gt;     &lt;/span&gt;&lt;span class="nv"&gt;name&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;"default"&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;instance&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;default

&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="m"&gt;1&lt;/span&gt;&lt;span class="w"&gt;   &lt;/span&gt;&lt;span class="nv"&gt;name&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;"stucchinet4"&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;routing-table&lt;span class="o"&gt;=&lt;/span&gt;main&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;as&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="m"&gt;58280&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;address-families&lt;span class="o"&gt;=&lt;/span&gt;ip,ipv6
&lt;span class="w"&gt;     &lt;/span&gt;output.filter&lt;span class="o"&gt;=&lt;/span&gt;out-v4&lt;span class="w"&gt; &lt;/span&gt;.network&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="m"&gt;45&lt;/span&gt;.129.224.0/22

&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="m"&gt;2&lt;/span&gt;&lt;span class="w"&gt;   &lt;/span&gt;&lt;span class="nv"&gt;name&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;"stucchinet6"&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;routing-table&lt;span class="o"&gt;=&lt;/span&gt;main&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;instance&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;default&lt;span class="w"&gt; &lt;/span&gt;apply-changes&lt;span class="o"&gt;=&lt;/span&gt;auto&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nv"&gt;as&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="m"&gt;58280&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;address-families&lt;span class="o"&gt;=&lt;/span&gt;ipv6&lt;span class="w"&gt; &lt;/span&gt;output.filter&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;""&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;.network&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;""&lt;/span&gt;
&lt;span class="w"&gt;     &lt;/span&gt;input.filter&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="k"&gt;in&lt;/span&gt;-v6
&lt;/pre&gt;&lt;/div&gt;

&lt;p&gt;and there it is.&lt;/p&gt;
&lt;h4&gt;4. Check the result&lt;/h4&gt;
&lt;p&gt;Let's now check if Origin Validation gets applied:&lt;/p&gt;
&lt;div class="code"&gt;&lt;pre class="code literal-block"&gt;&lt;span class="o"&gt;[&lt;/span&gt;admin@r1.btl.ch.as58280.net&lt;span class="o"&gt;]&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;/routing/bgp/template&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;/ipv6&lt;span class="w"&gt; &lt;/span&gt;route/
&lt;span class="o"&gt;[&lt;/span&gt;admin@r1.btl.ch.as58280.net&lt;span class="o"&gt;]&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;/ipv6/route&amp;gt;&lt;span class="w"&gt; &lt;/span&gt;print&lt;span class="w"&gt; &lt;/span&gt;where&lt;span class="w"&gt; &lt;/span&gt;dst-address&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;"2606:4700:7000::/48"&lt;/span&gt;

&lt;span class="o"&gt;[&lt;/span&gt;admin@r1.btl.ch.as58280.net&lt;span class="o"&gt;]&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;/ipv6/route&amp;gt;
&lt;/pre&gt;&lt;/div&gt;

&lt;p&gt;Here we go!  The prefix is not visible anymore and gets filtered out.&lt;/p&gt;
&lt;p&gt;You might have to disable and re-enable the BGP Session for the filter to kick in.&lt;/p&gt;
&lt;p&gt;This is the end.  Besides the issues with IPv6 BGP, it seems that Mikrotik is going towards a nice result with this, so I hope they work quickly on making RouterOS v7 available for production, and hopefully this will increase RPKI adoption around the World, and will make &lt;a href="http://instituut.net/~job/"&gt;Job Snijders&lt;/a&gt; happy... :)&lt;/p&gt;</description><guid>https://as58280.net/it/articles/RPKI-on-Mikrotik/</guid><pubDate>Tue, 17 Nov 2020 14:16:18 GMT</pubDate></item></channel></rss>