diff --git a/content/blog/2023-02-07-ipv6-canvas.md b/content/blog/2023-02-07-ipv6-canvas.md new file mode 100644 index 0000000..23c534e --- /dev/null +++ b/content/blog/2023-02-07-ipv6-canvas.md @@ -0,0 +1,37 @@ +--- +layout: page +title: "Blatant self-advertising on the IPv6 Canvas" +description: "An ungodly amount of pings for a small bitmap" +date: 2023-02-07 +tags: project +draft: false +extra: + auto_center_images: true + excerpt: "Using some python, I have a reference to this website semi-permanently implanted on the IPv6 Canvas" +--- + +Yesterday, the [IPv6 Canvas](https://blog.tugzrida.xyz/2023/02/06/introducing-the-ipv6-canvas/) was pushed to the public. + +Of course, as soon as I learned of this, I threw together a script to place my domain `ewpratten.com` on the canvas for all to see. + +## Screenshots + +![](/images/posts/ipv6-canvas/v6_canvas_1.png) + +![](/images/posts/ipv6-canvas/v6_canvas_2.png) + +## How I'm doing this + +The code is [public](https://github.com/ewpratten/v6-canvas-writer) for anyone wanting to do this themselves, and the process for getting everything working was pretty simple. + +1. I designed the graphic in a random online pixel art editor +2. The design was converted to a bitmap +3. I have a Python script that can read an arbitrary bitmap and convert it to a list of IPv6 addresses +4. Hundreds of `ping -c 1` processes are spawned in the background to write the image to the canvas + +This script is executed via a Cron job on one of my edge routers for maximum IP nerdiness. + +### Why ping? + +I considered doing this with some clever `mtr` commands, or even crafting the ICMP ECHO packets straight from the script, but that was slightly too much work for the 5 minutes I had before work this morning. + diff --git a/sass/styles/components/navbar.scss b/sass/styles/components/navbar.scss index cbe50fd..6aee732 100644 --- a/sass/styles/components/navbar.scss +++ b/sass/styles/components/navbar.scss @@ -1,6 +1,6 @@ .ewp-navbar { margin-top: 1em; - margin-bottom: 1em; + // margin-bottom: 1em; text-align: center; .navbar-items { @@ -13,10 +13,21 @@ // & > li { // display: inline-block; - + // .dropdown-menu { // box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px; // } // } } } + +.announcement { + text-align: center; + font-weight: bold; + background-color: rgb(239, 239, 239); + margin-top: 0; + padding: 0.25em; + border: 2px dashed grey; + border-top: none; + color:dimgray; +} diff --git a/static/images/posts/ipv6-canvas/v6_canvas_1.png b/static/images/posts/ipv6-canvas/v6_canvas_1.png new file mode 100644 index 0000000..9cf18b8 Binary files /dev/null and b/static/images/posts/ipv6-canvas/v6_canvas_1.png differ diff --git a/static/images/posts/ipv6-canvas/v6_canvas_2.png b/static/images/posts/ipv6-canvas/v6_canvas_2.png new file mode 100644 index 0000000..e396567 Binary files /dev/null and b/static/images/posts/ipv6-canvas/v6_canvas_2.png differ diff --git a/templates/base.html b/templates/base.html index e4e2236..dffafbd 100644 --- a/templates/base.html +++ b/templates/base.html @@ -5,6 +5,7 @@ {% set is_article = false %} {% set feature_flags = [] %} {% set redirect_target = "" %} +{% set announcement = "" %} {% endblock variable_wormhole %} @@ -58,6 +59,10 @@ {# Navbar #}
{% include "components/navbar.html" %} + + {% if announcement %} +

{{announcement | safe}}

+ {% endif %}
{# Actual content #} diff --git a/templates/components/navbar.html b/templates/components/navbar.html index 772f72d..08b4004 100644 --- a/templates/components/navbar.html +++ b/templates/components/navbar.html @@ -30,5 +30,5 @@ · Contact -
+
\ No newline at end of file diff --git a/templates/index.html b/templates/index.html index bc25d0f..354009c 100644 --- a/templates/index.html +++ b/templates/index.html @@ -30,6 +30,7 @@ {% if section.extra.uses %} {% set feature_flags = section.extra.uses %} {% endif %} +{% set announcement = "Found me though the IPv6 Canvas? Click here." %} {% endblock variable_wormhole %} {# Page content #}