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.
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)
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.
Sometimes the skies shine blue even in the autumn, when one would expect everything to be dull, gray and sad.
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...
I love how robust go dependency handling is! /s
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...
If something is slow, just cache it!
My media endpoint sends ETags now. No more wasting bandwidth!
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!
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.
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...
I think uploading images should work now that I have a media endpoint. If everything works, here’s a picture I snapped recently.
i feel like destroying the universe
- Pretty permalinks for this post:
- https://fireburn.ru/posts/legacy-indieauth-in-kittybox
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...
oh yeah now i can shitpost properly!
test
if u see this i have implemented indieauth and can now do stuff
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.
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.
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.