1
This commit is contained in:
Evan Pratten 2022-11-11 19:05:01 -05:00
parent c520c509fe
commit 8ffaba65e0
9 changed files with 194 additions and 1 deletions

View File

@ -0,0 +1,46 @@
---
layout: page
title: "Crudely geo-filtering internet routes"
description: "How I make routers drop traffic for certain countries"
date: 2022-11-04
tags: network
draft: true
extra:
auto_center_images: true
excerpt:
---
Sometimes I find the need to filter internet traffic traversing my networks based on country of origin. Commonly, I find that dropping certain countries (*cough Russia*) decreases the amount of scans and attacks I see to nearly zero. Sometimes its also nice to ignore routes that pass through countries with heavy surveillance policies too.
In my network, I personally have two types of geographic filters:
- Blacklist: Do not accept any traffic to or from a country
- Depreference: Try to pick routes that do not pass through a country
In order to implement any of this, I first needed a way to quantify which country originates a particular route being learned by an edge router. There are many ways to do this, generally following the rule that *more accuracy = much more effort*.
While working on this system for myself, I came up with a few possible ways to programmatically determine a route's country of origin:
- Parse the route's [geofeed](https://datatracker.ietf.org/doc/html/rfc9092) file
- **Pro:** If the geofeed is implemented correctly, this is highly accurate
- **Con:** This requires the prefix to have a covering geofeed in the first place
- **Con:** Its really easy for a network to lie in their geofeed
- Assume that [autonomous systems](https://en.wikipedia.org/wiki/Autonomous_system_(Internet)) operate in the country they are registered
- **Pro:** Very easy to obtain the country of origin for an AS
- **Con:** Global anycast exists
- **Con:** Hobbynets like to lie about their country of operation
- Infer geographical information from [BGP communities](https://www.rfc-editor.org/rfc/rfc1997)
- **Pro:** If done right, this is very accurate
- **Pro:** Sounds awesome, would be good talk material
- **Con:** Documenting communities used by transit providers is a lot of work
- **Con:** Not all transit providers use communities
- **Con:** My upstreams like stripping communities from their routes sometimes
After pondering my options, I ended up choosing to just filter on the country of origin attached to each AS number's records. This is very easy to obtain, and leaves room for me to do something fancy in the future now that I have the rest of the system in place too.
## Getting a list of ASNs registered to a country
If I were to update this filter regularly, I would try pulling [WHOIS](https://en.wikipedia.org/wiki/WHOIS) database dumps, parsing through the data, and creating a lookup table for this purpose.
However, I really don't need to instantly catch networks as they are registered, and feel perfectly fine updating this filter every few months. Thus, the easy route.

View File

@ -0,0 +1,87 @@
---
layout: page
title: "A brief walk through my all-time favorite songs"
description: "..and crashing spotify clients in the process"
date: 2022-11-10
tags: music
draft: true
extra:
auto_center_images: true
excerpt:
---
Music is a core part of my daily life. For about 13 hours straight each day, I have all kinds of tracks playing while I work on things. Having a constant stream of music playing is a habit I have held for years, it keeps some rhythm in my day, and at the same time gives me plenty of chances to find new tracks and artists to listen to.
My methods of listening to music have changed over the years a bit. As far as I can remember, I started listening to music on my own via YouTube sometime in elementary school. I could have the first two entries in the following list mixed up, but this should be the general order of how I have listened to songs over time:
- YouTube
- [Stingray Music](https://en.wikipedia.org/wiki/Stingray_Music)
- iTunes
- SoundCloud
- YouTube ... again
- Curated mixes via [Call of the Wild](https://www.monstercat.com/call-of-the-wild)
- I listened to every single weekly release from episode **1** through roughly **285** and found many of my favorite artists here
- ~~Youtube~~ [NewPipe](https://newpipe.net/)
- Spotify
It was sometime during my "NewPipe era" that I decided it might be a good idea to make a playlist of songs I liked, instead of just trying to remember and search them every time I wanted to listen to something I knew.
It was with this decision that I spawned my project to track every one of my favorite songs over time.
## The mega playlist
Sometime in early 2020, after switching to use Spotify as my streaming service of choice, I started what I called the "mega playlist". This started by copying over my old NewPipe playlist, and reorganizing things a bit. During this time, I came up with a set of rules for this music collection:
- Only the best of the best shall enter this playlist
- Songs may be slightly out of order, but must generally fall in the order I listened to them
- All songs must cleanly cross-fade with each other so I don't notice jarring switches when the track changes
This last point came in to place because I was playing this mix while doing school work, and didn't like being interrupted by a sudden musical mood or tempo change.
After a year or so of collecting songs for this project, the "mega playlist" was renamed to "Journey" (a journey through songs I like if you will), and I also [published it](https://open.spotify.com/playlist/3KoQ6Wqo6GexHLsRkEJB9u?si=ec9e54abfc70443d) on my Spotify page.
I also realized it would be reasonably easy to extend the playlist *before* 2019 to include every song I remember liking. As it turns out, Spotify gets very unhappy if your playlists start pushing the 24 hour mark. Scrolling, searching, and moving songs will crash the mobile app at that point. So, I ended up creating a second pre-journey playlist, which I called [Intro](https://open.spotify.com/playlist/4DknNpYMzmfJdiwRWklJlK?si=675a811e35654090).
## The highlights
With the context out of the way, why not share some of the highlights of this project. As of the time of writing, I have a total of 38 hours of music in *Intro* and *Journey*.. Thats 646 songs! Last year I decided to test myself and listen to them all in order to see what I remembered. Surprisingly, I could hum the melody of every single one of them despite not listening to some for a few years. The power of a good song I guess :man_shrugging:
### Where it *almost* all began
Skipping some earlier rock music that I can't remember enough of to add to a playlist, the first electronic song I distinctly remember obsessing over was ***Top of the World*** by [Stephen Walking](https://open.spotify.com/artist/0FvgCHaMG7KL6M83yJuhmL).
<iframe style="border-radius:12px" src="https://open.spotify.com/embed/track/23MJSTyBjJBnthv83gmnEy?utm_source=generator" width="100%" height="80" frameBorder="0" allowfullscreen="" allow="autoplay; clipboard-write; encrypted-media; fullscreen; picture-in-picture"></iframe>
This track then led me to discover *[012: Aftermath](https://open.spotify.com/album/4iom89zyZI8s7ZgDmthiFx?si=LMnVVnC4QSa0usGLYuFczQ)*, probably my most listened to [Monstercat](https://www.monstercat.com/) album, which contained two songs that stuck in my head for years:
<iframe style="border-radius:12px" src="https://open.spotify.com/embed/track/7yW5kmVbaWVT3zKYFGcU2L?utm_source=generator" width="100%" height="80" frameBorder="0" allowfullscreen="" allow="autoplay; clipboard-write; encrypted-media; fullscreen; picture-in-picture"></iframe>
<br>
<iframe style="border-radius:12px" src="https://open.spotify.com/embed/track/2XsbGteXQCFYERLww9cwq7?utm_source=generator" width="100%" height="80" frameBorder="0" allowfullscreen="" allow="autoplay; clipboard-write; encrypted-media; fullscreen; picture-in-picture"></iframe>
Another notable mention is one of the weirdest music videos I have ever seen, which was produced for Stephen Walking's [Short Shorts](https://www.youtube.com/watch?v=-JNDliFODF4).
### Exploring the electronic sub-genres
After listening to a fair bit of dubstep, and dubstep-ish tracks, I eventually came to find some lighter tracks. My favorite of which was *Turbo Penguin*
<iframe style="border-radius:12px" src="https://open.spotify.com/embed/track/3cKpKxz7JOZsCf4C2rRB5K?utm_source=generator" width="100%" height="80" frameBorder="0" allowfullscreen="" allow="autoplay; clipboard-write; encrypted-media; fullscreen; picture-in-picture"></iframe>
I also discovered an artist by the name of [San Holo](https://en.wikipedia.org/wiki/San_Holo), who pioneered the [Future Bass](https://en.wikipedia.org/wiki/Future_bass) genre which I came to love. I played his *Victory* EP on repeat for a long time.
<iframe src="https://open.spotify.com/embed/album/4RxpFCkTTBNALA3njzCe4Y?utm_source=generator" width="100%" height="180" frameBorder="0" allowfullscreen="" allow="autoplay; clipboard-write; encrypted-media; fullscreen; picture-in-picture"></iframe>
Continuing on the trend of finding artists I liked, ,I also discovered [Tokyo Machine](https://open.spotify.com/artist/3bwENxqj9nhaAI3fsAwmv9?si=04zUDzfXTgyHsK5J1ZqkXg) and was quite fascinated by his take on chiptune with a bass house twist.
### Going heavy again
I have found that no matter the genres and artists I find myself listening to, my general musical mood flip-flops between bouncy, light tracks, and excessively heavy, bassy tracks.
Keeping with the semi-chronology of this post, I went on to listen to heavier, more rave-fit tracks like *Gorilla Glue* by [Dirty Audio](https://open.spotify.com/artist/1WGex9YdmT4TZjmmMirZA8), *BAMF* by the [Pegboard Nerds](https://en.wikipedia.org/wiki/Pegboard_Nerds), *Panic* by [Dion Timmer](https://open.spotify.com/artist/06VibSJEr3GLxLBBZhRums) and *many many more* (tracks 104 to 187 of [Intro](https://open.spotify.com/playlist/4DknNpYMzmfJdiwRWklJlK?si=675a811e35654090)).
<iframe style="border-radius:12px" src="https://open.spotify.com/embed/track/1VyXn3bJyGczirLLCAywmD?utm_source=generator" width="100%" height="80" frameBorder="0" allowfullscreen="" allow="autoplay; clipboard-write; encrypted-media; fullscreen; picture-in-picture"></iframe>
<br>
<iframe style="border-radius:12px" src="https://open.spotify.com/embed/track/73nWSc3002fGRPrnFDev8x?utm_source=generator" width="100%" height="80" frameBorder="0" allowfullscreen="" allow="autoplay; clipboard-write; encrypted-media; fullscreen; picture-in-picture"></iframe>
<br>
<iframe style="border-radius:12px" src="https://open.spotify.com/embed/track/68RuKZzcIp8X3p7PgG6mbU?utm_source=generator" width="100%" height="80" frameBorder="0" allowfullscreen="" allow="autoplay; clipboard-write; encrypted-media; fullscreen; picture-in-picture"></iframe>
A brief intermission of vocal-filled melodic tracks was induced after this period due to the release of [Instinct](https://open.spotify.com/album/7qzURREdjo1w2mKBGGcDkZ?si=4hKGb9YAR1iFP3UBWzNsDg), another great Monstercat album.

View File

@ -13,7 +13,8 @@ Here is a list of social platforms I am reasonably active on:
- [LinkedIn](https://www.linkedin.com/in/ewpratten/)
- [GitHub](https://github.com/ewpratten)
- [Instagram](https://www.instagram.com/evanpratten/)
- [Twitter](https://twitter.com/ewpratten/)
<!-- - [Twitter](https://twitter.com/ewpratten/) -->
- [Mastodon](https://ewp.fyi/mastodon)
- [QRZ](https://qrz.com/db/va3zza)
- [Spotify](https://open.spotify.com/artist/1aLNEmgqBJkhfkEZvf8Vh5)
- [Apple Music](https://music.apple.com/us/artist/evan-pratten/1611566708)

View File

@ -0,0 +1,6 @@
---
title: November 2022
---
- **Nov 4**
- Early afternoon: QSO with VA3ZEV (Dave) via the VE3RSB repeater

9
content/notes/_index.md Normal file
View File

@ -0,0 +1,9 @@
---
title: Notes
extra:
inject_notes: true
---
# Notes
A list of smaller notes I have taken on things. Can be thought of as future blog posts.

View File

@ -0,0 +1,14 @@
---
title: Blocking and depreferring BGP routes from specific countries
---
Hurricane Electric keeps a somewhat up-to-date list of ASNs registered to each country in the world. This is obtainable via:
```sh
export COUNTRY=CA # This is the country code to look up
curl -A "asd" https://bgp.he.net/country/$COUNTRY | grep -o -E "AS([0-9]+)" | sort | uniq
# You should get a list of ASNs piped to stdout
```
Two types of filters are handy. Blackholing, and depreferring.

View File

@ -14,6 +14,8 @@
})(window, document, 'script', 'dataLayer', 'GTM-KFJ95RP');</script>
<!-- End Google Tag Manager -->
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
@ -89,6 +91,7 @@
<p>
<a href="/">Home</a> |
<a href="/blog">Blog</a> |
{# <a href="/blog">Rabbit Hole</a> | #}
{# <a href="/work">My Work</a> | #}
{# <a href="/network">Network</a> | #}
<a href="/contact">Contact</a>
@ -154,6 +157,9 @@
window.location.href = window.location.href.replace('retrylife.ca', 'ewpratten.com');
}
</script>
{# Meta magic for mastodon verification #}
<a rel="me" href="https://social.ewpratten.com/@evan" style="display:none;"></a>
</body>
</html>

View File

@ -10,6 +10,11 @@
{{ super() }}
{# Disable crawling if requested #}
{% if page.extra.no_crawl %}
<meta name="robots" content="noindex, nofollow">
{% endif %}
{% if page.extra.uses_katex %}
<script src='https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/latest.js?config=TeX-MML-AM_CHTML' async></script>
<script type="text/x-mathjax-config">

View File

@ -5,6 +5,12 @@
{% block head %}
{{ super() }}
{# Disable crawling if requested #}
{% if section.extra.no_crawl %}
<meta name="robots" content="noindex, nofollow">
{% endif %}
<meta property="og:title" content="{{section.title}} - Evan Pratten" />
{% if section.description %}
<meta property="og:description" content="{{section.description}}" />
@ -91,4 +97,17 @@
{% endfor %}
</ul>
{% endif %}
{# Notes #}
{% if section.extra.inject_notes %}
<ul>
{% for page in section.pages %}
{% if not page.extra.hidden %}
<li class="blog-post-li"><a href="{{page.path}}">{{page.title}}</a>
</li>
{% endif %}
{% endfor %}
</ul>
{% endif %}
{% endblock content %}