Skip to content

Apparently someone intercepted an SMS message from Discord on my phone and registered themselves a new account.

I hacked that account using my own phone number. Now I apparently have two Discord accounts.

Aesop of the Day: if you use a burner phone to create an account, make sure the number doesn’t belong to someone else.

Webmention counters:

  • 0
  • 💬0
  • 🔄0
  • 🔖0

I kissed a girl pivoted my monitor 270 degrees and I liked it!

(This allows me to see so much more text and keep focus with more windows open! so interesting)

Webmention counters:

  • 0
  • 💬0
  • 🔄0
  • 🔖0

For some reason, when asked how to stop mice from waking up a Linux PC, people recommend writing a udev rule and matching by a device ID. No more of this, I found a better way that works with any mouse!

ACTION=="add", ATTRS{bInterfaceClass}="03", ATTRS{bInterfaceProtocol}=="02", ATTR{power/wakeup}="disabled"

I read what is apparently the USB HID specification to learn that HID devices use the bInterfaceProtocol field to signify if they are a keyboard, a mouse or some other device. The above udev rule matches on that field (apparently udev exposes a lot of interesting stuff about devices, including how much power they want to draw? I wonder if there’s any use for this...) to gather all USB mice in your system.

No more your laptop has to turn on when you jiggle a mouse accidentally.

Webmention counters:

  • 0
  • 💬0
  • 🔄0
  • 🔖0

Sometimes the skies shine blue even in the autumn, when one would expect everything to be dull, gray and sad.

Webmention counters:

  • 0
  • 💬0
  • 🔄0
  • 🔖0

Acquiring random bits of knowledge and experience allows one to comprehend concepts one would be unable to ordinarily comprehend and utilize due to lack of perceived usefulness.

For example, actor frameworks in asynchronous systems. I thought that actors were extraneous entities that aren’t relevant to the problem space; and yet this concept has a use!

By segregating responsibilities of the app and allowing actors to communicate in strictly predefined messages, one can improve the separation of the application modules and ease refactoring.

Maybe I should try using this in a project to feel out the concept. Actually, I do have a pet project: I always wanted to write my own Microsub server...

Webmention counters:

  • 0
  • 💬0
  • 🔄0
  • 🔖0

Moving a bookshelf is tough, but satisfaction after rearranging your furniture and coming into your room and feeling like you’re in a completely new place is absolutely worth it.

If you’re bored, just start moving some furniture...

Webmention counters:

  • 0
  • 💬0
  • 🔄0
  • 🔖0

If something is slow, just cache it!

My media endpoint sends ETags now. No more wasting bandwidth!

Webmention counters:

  • 0
  • 💬0
  • 🔄0
  • 🔖0

Turns out in some jurisdictions it is literally illegal to work at night. What to do if you have a sudden nightly productivity burst?... uuuuuuuugh!

Webmention counters:

  • 0
  • 💬0
  • 🔄0
  • 🔖0

Migrated all of my old uploads to the new media endpoint and fixed the URLs. Should be no more broken images on this website! ...aside from the ones I may or may not have lost.

Webmention counters:

  • 0
  • 💬0
  • 🔄0
  • 🔖0

Something I should consider doing is picking up the branch where I experimented with transcoding media formats inside of the media endpoint. That photo I just uploaded was fairly large and it took several seconds to load on my mobile connection...

Webmention counters:

  • 0
  • 💬0
  • 🔄0
  • 🔖0
A photo of a tree, hiding a streetlamp in between its leaves.

I think uploading images should work now that I have a media endpoint. If everything works, here’s a picture I snapped recently.

Webmention counters:

  • 0
  • 💬0
  • 🔄0
  • 🔖0

Since Kittybox (or more precisely, its IndieAuth library) doesn’t support omitting PKCE, I found myself unable to log into some apps like Together. Kinda sad, but that’s the price of being on the bleeding edge of the spec, with almost no support for legacy clients.

Had to add authorization_endpoint and token_endpoint links into the header though, because it might be that I am pretty much the only one to use the newest spec and properly implement it. For now.

Next step could probably be actually making webmentions work...

Webmention counters:

  • 0
  • 💬0
  • 🔄0
  • 🔖0

test

if u see this i have implemented indieauth and can now do stuff

Webmention counters:

  • 0
  • 💬0
  • 🔄0
  • 🔖0

Sometimes you have to scale your ambitions back and go slow to prevent yourself from overworking and subsequently burning out. It is sometimes hard to admit, but it is the truth of this world.

Webmention counters:

  • 0
  • 💬0
  • 🔄0
  • 🔖0

I hate OpenSSL, but the webauthn-rs crate happens to use it. Ugh. I don’t want to ship C code in Kittybox! But it looks like rewriting the whole webauthn-rs crate to remove OpenSSL dependency might be the only option, if it’s possible at all.

Webmention counters:

  • 0
  • 💬0
  • 🔄0
  • 🔖0

Oh well. It looks like I tried to implement an asynchronous template system for Rust, but instead of actual templates I ended up manually writing a stream of Bytes instances. It takes 10 times as much space as its output. But it’s asynchronous, and I expect that TTFB for, say, a large feed, would be much better with it.

For completeness, here is one template I wrote. It should’ve been an h-card.

pub fn card(mut mf2: serde_json::Value) -> impl Stream<Item = Bytes> + Unpin + Send {
    let uid: String = match mf2["properties"]["uid"][0].take() {
        serde_json::Value::String(uid) => uid,
        _ => panic!("h-card without a uid")
    };
    let photo: Option<String> = match mf2["properties"]["photo"][0].take() {
        serde_json::Value::String(url) => Some(url),
        _ => None
    };
    let name: String = match mf2["properties"]["name"][0].take() {
        serde_json::Value::String(name) => name,
        _ => panic!("encountered h-card without a name")
    };
    chunk(b"<article class=\"h-card\">")
        .chain(futures::stream::once(std::future::ready(
            match photo {
                Some(url) => {
                    let mut tag = Vec::new();
                    tag.extend_from_slice(b"<img class=\"u-photo\" src=\"");
                    html_escape::encode_double_quoted_attribute_to_vec(url, &mut tag);
                    tag.extend_from_slice(b"\" />");

                    Bytes::from(tag)
                },
                None => Bytes::new()
            }
        )))
        .chain(futures::stream::once(std::future::ready({
            let mut buf = Vec::new();
            buf.extend_from_slice(b"<h1><a class=\"u-url u-uid p-name\" href=\"");
            html_escape::encode_double_quoted_attribute_to_vec(uid, &mut buf);
            buf.extend_from_slice(b"\">");

            html_escape::encode_text_to_vec(&name, &mut buf);

            buf.extend_from_slice(b"</a></h1>");

            Bytes::from(buf)
        })))
        .chain(chunk(b"</article>"))
}

It’s huge. Here is the output it should produce (whitespace is mine):

<article class="h-card">
    <img class="u-photo" src="https://example.com/media/me.png" />
    <h1><a class="u-url u-uid p-name" href="https://example.com/">Jane Doe</a></h1>
</article>

I need some sort of macro system to work with these. The idea itself seems good, but the implementation... meh.

Webmention counters:

  • 0
  • 💬0
  • 🔄0
  • 🔖0