Urbit is still basically just a broken computer simulator

published: 2023-10-01


Recap

I wrote a post about Urbit before, so I don't feel like rehashing the entire intro for what is essentially just an update post, but in case you're too lazy to read it, here's a reminder: Urbit is a single-threaded interpreter for webapps that claims to be peer-to-peer but in practice can't connect to other peers half of the time and also falls over if you don't have stable DNS or IPv4 connectivity:

ames: czar at wet.urbit.org: not found (b)
http: fail (14691, 504): temporary failure
http: fail (14692, 504): temporary failure
http: fail (14693, 504): temporary failure
http: fail (14694, 504): temporary failure
http: fail (14695, 504): temporary failure
http: fail (14696, 504): temporary failure
http: fail (14697, 504): temporary failure
				

In other words, Urbit is a program you run on your personal computer to make a fashion statement about sticking it to MEGACORP and being self-sovereign while failing to appreciate the irony of a peer-to-peer system that can't bootstrap without a connection to urbit.org and the Ethereum blockchain. You know, since Urbit uses Ethereum for identity management. In fact, if you ever lose all the files in your Urbit "pier" (installation), you need to pony up a small amount of ETH (for me it was 0.004) to make the network "forget" you and start again. Since I wasn't planning on using Urbit ever again after my aforementioned post, I had to spend about $7 for this "factory reset". Thankfully whoever had given me my Urbit keys in the first place had left some money in them, so I didn't actually have to spend any of my own money. Urbit also has a distinct lack of actually useful apps for people who don't like to socialize online: in the course of doing research for this update post, I only found one or two apps I could actually see myself using more than once, and those apps already have far superior offline equivalents.


*youtuber voice* LeT's GeT rIgHt InTo It!!1!

In my original post, I complained:

Unintuitively, "installing" more apps means opening the search bar instead of a dedicated "install" button (even a little plus sign would have been more helpful) and pasting in a long unmemorable string from an external app directory...

Sometime between then and now, this got fixed. When signing into the Urbit web interface, titled "Landscape", at the top of the screen is now a little blue button with the text "Get Urbit Apps". Clicking this button brings up a small app catalog with categories like "Tlon Selects", "Powered by Pals", "Make Urbit Useful", and "Make Urbit Fun". Installing apps takes a while, and the spinning wheel icon remains, but now you get some idea of what Landscape is doing while it loads the relevant app store entry. The Urbit documentation doesn't make this obvious, but you can also install apps via the CLI "dojo": app shortcode ~sitden-sonnet/channel translates to the command |install ~sitden-sonnet %channel.

That doesn't mean app installation is any faster, as you will be often met with this screen for five minutes or more:

Even if you find an app you want to install, whether in the catalog or on an app directory elsewhere, you're almost certainly going to run into the same five logs over and over with no success:

  1. Checking connection
  2. Checking DNS
  3. Checking our galaxy
  4. Checking ~person's sponsors
  5. ~person's sponsor can reach them, but we can't

Is my Internet connection flaky, or is a good portion of the Urbit community gone without a trace? Who knows! Let's look at some apps still functioning to see what function Urbit has in Current Year.

Groups

This isn't the titular "glorified chatroom" of my previous post, but it might as well be, because I couldn't connect to the Urbit peer responsible for distributing ~dister-fabnev-hinmur/escape. Visually it's a Discord clone, where each group has multiple channels on the left sidebar. But it also takes several minutes to load any messages after you switch to any channel, and my fan was on the maximum speed the whole time I had the Groups tab open. Firefox even asked me multiple times to kill the tab because it was slowing down the rest of my computer.

Not having any idea where to go, and the man who originally gave me my Urbit keys no longer with an active Internet presence (and thus unavailable for recommendations), I joined one of the default groups named "Tlon Local". The "Internet Cafe" channel was active, and every time I sent a message, someone would reply within an hour or so. Annoyingly, replies to messages don't show up as their own messages but instead sit behind a "replies" button that has to be expanded every time. So unless it's your message, there's no visual reminder that a discussion is still going on... somewhere. Happy backscrolling! I hope it's winter where you are, because your computer is about to turn into a really inefficient space heater.

Additional groups could be found by scrolling down to the bottom of the channel list in Tlon Local and clicking on "Community Catalog". I was met with a lot of... white squares. And then the squares loaded, and I could see the actual preview images for each channel behind the channel's name, like "stereosound" and "California Art Community". I clicked on one, and after multiple page refreshes I managed to get into a few groups to explore.

pals (~paldev/pals)

Keep track of your friends! Other applications can use this list to find ships to talk to, pull content from, etc.

Pals looks like a tool to pin peers to fetch Urbit content from. Some Urbit apps use Pals to populate your feed with content. I saw two peers in my list, both with minuses by them, which meant I'd added them but they hadn't added me back.

basket (~nodmyn-dosrux/basket)

Basket is supposed to be a meme repository. But it won't let you upload images directly to Urbit; you have to instead hand over a URL to an existing image on the Internet. Once you have, the image appears fullscreen, and there are two buttons on the top: "live" and "repo". There's also a search box, but it only appears to search the memes you yourself had added. I didn't see a mechanism to look at the memes of others. So it's like a really shitty Hydrus?

The images are still served directly from the original URL, by the way. Decide on your own if this is a privacy concern.

Goals (~dister-dozzod-niblyx-malnus/gol-cli)

Goals is a todo list with too many menus. The first thing you see upon launch being a button labeled "Add a pool to get started". To make a new goal, you hover over the pool, click on the "plus" icon that appears by it, and then type in a new goal and hit the enter key. Hovering over by the goal, a meatball menu appears where you can mark the goal as "complete". Also in the meatball menu are options for inviting other people and groups to either have read-only access to your task pool or to collaborate with adding tasks and marking them as complete.

Sorry I couldn't think of anything snarky for this one. The app works. That's all I can say.

%blog (~hanrut-sillet-dachus-tiprel/blog)

I opened %blog and was immediately met with a Markdown post editor. No real tutorial, no setup: you wanted to write a post, so here, write the damn post. My first instinct was to hit Control-A to clear all the lorem ipsum and paste my own words in, but apparently that was the wrong thing to do: it kicked me to a menu with buttons for "new draft" and "new theme". After a few minutes hopelessly lost, I discovered that I could go back to my draft post by clicking the "four arrows" button in the bottom-right corner. A text box lets you type in the desired "slug" (the name of the post in the URL) for the post, so because the poem is titled "A New Page", I picked the slug /a-new-page.

After I had copy-pasted the same poem I always do when testing web3 dreck, I clicked "Publish"... and then it asked me for a URL:

You have not yet specified the URL of your blog, please confirm the below location.
Subscribers to your blog require this in order to create the correct links.

It doesn't give you an indication of what you're supposed to put in. But you'd think that app makers would set reasonable defaults, right? So I just hit the publish button again. As it turns out, doing this without setting a slug can destroy your Urbit installation. Unfortunately I set one, so the post doesn't end here.

I made the same mistake I made last year and assumed that an Urbit publishing app would allow me to publish inside of Urbit. But it turns out that %blog is just a glorified CMS, because I then went to http://127.0.0.1:8081/a-new-page in a new tab and saw my post. You'd think it would be something like http://127.0.0.1:8081/~socleb-fosrut/a-new-page instead, where anyone can go to that URL and see my post, and I could go to http://127.0.0.1:8081/~sampel-palnet/ to see ~sampel-palnet's posts, but "I'm expecting too much of Urbit" seems to be a recurring theme. And in order to use %blog as a CMS, you have to set up a web server to reverse-proxy to your Urbit ship, because it's not like Urbit likes putting unobfuscated files on your hard drive:

perthro:~/urbit/socleb-fosrut$ tree -a
.
├── .bin
│   ├── live
│   │   └── vere-v2.11-linux-x86_64
│   └── pace
├── .http.ports
├── .run
├── .urb
│   ├── bhk
│   │   ├── north.bin
│   │   └── south.bin
│   ├── chk
│   │   ├── north.bin
│   │   └── south.bin
│   ├── conn.sock
│   ├── get
│   ├── log
│   │   ├── data.mdb
│   │   └── lock.mdb
│   └── put
└── .vere.lock
9 directories, 12 files
				

Where exactly am I supposed to point Caddy to?

kenning (~migmeg-fidlen-sillus-mallus/kenning)

Memorize passages of text. Every passage is called a "kenning".
  • Every kenning is assigned a kelvin version based on word count.
  • You may test your knowledge by filling in the blanks.
  • As kelvin decreases, the number of blanks increases.
  • For large passages, split the text into several kens for best results.

Pretty straightforward. I added the first sentence of SCUM Manifesto. It started with a kelvin of 47. I got two words in before I failed. Very shameful of me.

But %kenning does what few Urbit apps do, which is actually function as intended.

Trill (~dister-dozzod-sortug/trill)

Remember Bastyon from my last web3 post? Trill is like if you got a cheap knockoff of Bastyon from a person who knows that putting blackbirds on random things is an effective way to get you to buy things. Trill is full of people who'd be happier on 8chan 8kun but aren't because 8kun doesn't also require you sell your soul to a blockchain beforehand. Trill is also full of people who hate functioning emojis:

There are supposedly quote posts, but none of them ever load:

There's an "attach image" button, but it just threw an error in my browser's console every time I clicked on it and it did nothing else.

index-74ddaac9.js:168 Uncaught (in promise) TypeError: Failed to construct 'URL': Invalid URL
	at VT (index-74ddaac9.js:168)
	at eW (index-74ddaac9.js:168)
	at rn (index-74ddaac9.js:186)
	at Bo (index-74ddaac9.js:186)
	at Object.KB (index-74ddaac9.js:37)
	at IB (index-74ddaac9.js:37)
	at QB (index-74ddaac9.js:37)
	at bk (index-74ddaac9.js:37)
	at nC (index-74ddaac9.js:37)
	at index-74ddaac9.js:37
				

Astrolabe (~dister-midlev-mindyr/astrolabe)

Astrolabe is your one-stop shop for exploring Urbit address space. Currently, Astrolabe lets you type in @ps or Azimuth point numbers to look up ships on the network.

So you can look up anyone and see who their sponsor is and what kind of Urbit ID they have and how many times they've had to pay for a "factory reset" like I did.

Look, mom, I'm on TV!

fafa (~paldev/fafa)

A two-factor authentication app. Finally something I might find useful!

Oh, what does this disclaimer say?

remember that neither urbit nor this app have had a full security audit yet. avoid adding factors over unencrypted http. make sure to save the recovery codes, and/or add a copy of these factors into an authenticator on earth.

~paldev, I'm sure you're a nice person, but I'd really prefer not to get hacked, thanks.

rumors (~paldev/rumors)

Rumors is supposedly an app where you type in small bits of text and then others can see them, like a pseudonymous confessions site. I have no way of knowing for sure what this app is supposed to do, because all I ever saw was the header "rumors and gossip" and then a text box. Whatever text I typed into the box disappeared without a trace once I hit the enter button. I was on Urbit long enough to have plenty of peers, but I never saw any "rumors" from anyone else.

picture (~paldev/picture)

You can upload a picture. The picture then replaces the default icon for the "picture" app in Landscape. That's all it ever did.

grove (~dister-dozzod-dalten/grove)

It describes itself as a "groups file drive", so it's some kind of file storage with a sharing component. (Again, good luck accessing your files without going through the Urbit interface since the actual underlying file system is just a bunch of bin files.) The default group in the interface is set to ~nibset-napyn/tlon, where uploads seemed to be disabled and I couldn't actually make any folders (even though the folder button isn't greyed out like the upload button is) and also the entire "group" was empty. I couldn't test grove further as there was no button to make my own group or indication as to which other Urbit app would allow me to do so.

cliff (~paldev/cliff)

Cliff is another file browser, but this one actually lets you browse the Urbit filesystem. (You know, the contents of those .bin files Urbit stores everything in.) The top of the page has the file path. After the name of my Urbit planet is a drop-down list that let me see the data my apps had stored. Most apps just had a desk/bill... folder? file? I'm not sure what it was, because %cliff didn't make it obvious, but it didn't have anything interesting in it.

In the top-right corner of the screen is a pencil icon. I clicked on it, and it brought me to an editor for plaintext files. (And I thought to myself, finally, an Urbit app that's actually useful!) I edited some text, saved it... and crashed %cliff:

The actual error in the dojo would have been informative... if I could actually decipher the Hoon programming language:

crud: %request event failed
[%poke %request]
bar-stack
[ i=[i=/gall/use/cliff/0w2.lvVVM/~socleb-fosrut/edit/save t=[i=/dill t=~[//term/1]]]
t=[i=[i=/eyre/run-app-request/~.eyre_0v4.s0t8o.cq8qa.c8oko.r7m9p.gi0sp t=[i=//http-server/0vk.fjgv1/2.745/1 t=~]] t=~[[i=//http-server/0vk.fjgv1/2.745/1 t=~]]]
]
call: failed
[from=2 deletes={} changes={~}]
[%error-validating /]
[%validate-page-fail / %from %mime]
				

Quorum (~dister-dister-sidnym-ladrut/quorum)

A choral explanations app (a la Stack Overflow or Quora) for Urbit

There is no default "knowledge board". You have to join one. And in order to do that, you have to know one exists first.

Canvas (~dister-norsyr-torryn/canvas)

Remember r/place, or literally any other "social pixel art" game? It's basically that. You have a private canvas by default, and Canvas the app comes pre-loaded with a public map. There are also buttons to create a new canvas or join an existing one.

Canvas didn't work well for me on mobile, even with the fancy pen stylus my Galaxy S23 Ultra came with, but Canvas works well enough on desktop. I could place pixels and overwrite large sections of the map in just a few seconds with the bucket tool. There was only one snag: the magnifying glass tool doesn't let you zoom in; instead, if you hover over any arbitrary pixel on the canvas, it tells you who most recently changed that pixel to its current value.

Studio (~tirrel/studio)

welcome to studio
start by creating a site

It's a blogging platform. And just like %blog, other people can't access your posts over a pure Urbit connection; you have to have a domain pointing at your Urbit server and a reverse proxy. So, just like the rest of Urbit, it would only be accessible as long as DNS and HTTP are up. Which makes it no equivalent to the "freesites" in Hyphanet as it requires infrastructure outside Urbit. Which makes Studio just another shitty CMS.

You know, I'm getting real tired of these... You'd think someone with the technical knowledge required to get an Urbit planet up and running would know how to write some simple static HTML and thus wouldn't have the need for a CMS.

Portal (~worpet-bildet/portal)

Portal is another Twitter clone. The userbase seems to be nicer than Trill's, though. When I opened Portal, above the usual text box where you can write your posts, there was a search bar... with the OpenAI logo next to it? Below that was a set of "tags": "Crypto", "Longform", "Productivity"... Clicking on a tag wouldn't search posts by the words in the search query, but instead with an AI-like prompt: for example, clicking on "Longform" would populate the words "high wordCount" in the search box and then find posts in the feed with, well, a lot of words.

Oopsies, you can only post images if you connect an S3 bucket... you know, a service owned by MEGACORP... which Urbit was supposed to help people get away from...

Next to the like button I saw a button to tip Ethereum. You know, in case you want to fund the poster's next factory reset of their Urbit ship when they inevitably corrupt the opaque database files Urbit thought it was a good idea to store all their data in. We're very nice here at Portal, you know?

focus (~havdys-nordus-mocwyl/focus)

For the love of whatever deity you believe in, mute your speakers (or at least your browser) when launching this app or else it will blow your eardrums out. Why does a simple timer need to make such a harsh noise on startup? Deity only knows.

DukeBox (~tagrev-lacmur-lomped-firser/dukebox)

A DOS emulator? An emulator for Urbit? How many layers of abstraction are we going for? Who cares! KidPix, here I come-

Internal Server Error
There was an error while handling the request for /apps/dukebox/.
/app/docket/hoon:<[712 7].[712 33]>
/app/docket/hoon:<[711 5].[718 20]>
/app/docket/hoon:<[708 5].[718 20]>
/app/docket/hoon:<[705 5].[718 20]>
/app/docket/hoon:<[703 5].[718 20]>
/app/docket/hoon:<[702 5].[718 20]>
				

Trackur (~dister-finned-palmer/trackur)

Trackur bills itself as a "simple fitness tracker". One can track their weight loss and fasting over time. I was able to input a date a few months ago where I weighed myself and discovered that I'd lost twenty pounds since I moved into my apartment. It took a while to save, but it did save without crashing.


in lieu of an obnoxious YouTube outro

I'm still not any more interested in a convoluted chat app to talk with strangers than I was last year, and Urbit still appears no more capable of hosting my writings in-network without the need to shell out to other centralized aspects of the pre-existing Internet like DNS. I have to hand it to Urbit: the documentation has gotten slightly better since last year, as has the onboarding process and Landscape, but I still have a difficult time seeing where Urbit belongs in an "Internet apocalypse" plan. Urbit's app installation process depends heavily on DNS and the *.urbit.org servers working and being accessible from your own connection, and since installing someone's app depends on them being online and reachable at the same time you are, Urbit wouldn't function well in a scenario where we try to conserve on electricity by only coming online for a little bit each day to fetch new messages and send ones out, a use case which Hyphanet handles well and almost seems to encourage. And as the post I linked above (not the one I wrote, the other one) explained, Urbit's app updates, when they do reach you, aren't signed and are installed automatically over-the-air. Compare this to a hypothetical partially-airgapped Debian install where nothing happens to your computer unless you explicitly connect to a network and ask for an update or a new program to install.

Almost a year ago, I covered a similar network called Solid. Like Urbit, Solid is designed for having all your data for everything in one server (preferably under your control) and allowing apps other people wrote to access this data instead of signing up for a bazillion online accounts across a myriad of servers you don't control. If the whole point of Urbit is to be the only place a user needs to go to do everything online under a single identity, then Solid works better for this: Solid doesn't require a blockchain for identity management, doesn't require you to spend money to reset your identity in case of a hard drive crash, and doesn't (currently) harbor any delusions about one day superceding large portions of the modern-day Internet stack. Also Solid can be jerry-rigged to work over Tor or I2P or Yggdrasil or whatever darknet is to come, while Urbit can't.

Also Solid has a functioning text editor.

To recap, Urbit is difficult to join and bootstrap, lacks fundamental security features, doesn't reliably install wanted applications, and when apps are installed they are often low-quality if functional at all. Urbit cannot function in a situation where Internet access is limited or nonexistent. Therefore Urbit, despite the past year of improvements, is still nothing more than a broken computer simulator.


CC BY-NC-SA 4.0 © Vane Vander