By Casey Liss
Tailscale

Has anyone told you the good word about Tailscale? If not, I’m here to do it right now. This isn’t “sponcon”[1], but in retrospect, I probably should have given Tailscale a call. 😆


If you have multiple computers in your life — including computer-adjacent things like network attached storage — it’s likely you’d like to have access to each of those devices, always. If I need to inspect a file on my Synology in my house while I’m a passenger in the car, I want to be able to do so.

The easiest way to do this is to expose the port(s) your device needs for remote access through your router/firewall. This way, when someone on the Internet says “I’d like to access information using port 80, please”, your router knows what device should respond.

Unfortunately, this exposes your device to the entire Internet and that’s… undesirable.

Traditional VPNs

The easy solution to this problem is a Virtual Private Network; broadly, this means you run some sort of server inside your network that will allow devices outside the network to tunnel into the network. Once a device is on the VPN — that is to say, tunnelled into your network — it can access anything within that network. Said differently, if your phone is on a VPN that is hosted in your house, then your phone can access all the devices in your house. Most corporate VPNs work this same way.

If you’ll permit some hand-waving and over-simplification, traditional VPNs tend to be a sort of funnel — there is one server running inside the network you wish to tunnel into, and all clients connect to that server. That makes setup easy, but generally, it’s sort of an all-or-none scenario: you’re either on the VPN or you’re not.

What if there was a better way?

Tailscale

Coming back to my initial conundrum — getting files from Synology → phone, what is the actual thing standing in the way of that happening? I need the two devices to be able to talk to each other, no matter what network each device is on. If the phone is on cellular in London and my Synology is on FiOS at home, I need them to be able to communicate. I don’t particularly care how, just that they can.

Tailscale is the how.

Tailscale is a mesh network of all your devices. Each device that is running Tailscale is on your “Tailnet”; every device in your Tailnet can talk to any other device on your Tailnet. This all works by way of fairly common VPN software, extremely clever tricks for poking holes in firewalls, and relay fallbacks when no other approach works.

The net effect is that I’m always able to connect to my Synology. Or my Mac mini. Or my ridiculous assortment of Raspberry Pis. And so on. I can also always connect to my Linode nanode that runs this website. Or a Digital Ocean droplet. I can access any of these devices no matter what network I’m on, and no matter what network the device I’m targeting is on.

It’s ✨ magic ✨.

In Practice

So how does this look, in brass tacks, in my everyday life? Tailscale works by giving every node on your Tailnet additional ways to access it:

  • An IPv4 address in the 100.x.y.z address range
  • An IPv6 address
  • A bare hostname
  • Optionally, a fully qualified domain name

For example, my MacBook Pro that I’m using to write this can be referred to as the following within my Tailnet:

  • 100.12.34.56
  • fd7a:115c:x::y:z
  • blackbook-pro
  • blackbook-pro.smiley-tiger.ts.net

Naturally, I’ve lightly changed the addresses, because I’m paranoid, but that shouldn’t be necessary: if you’re not on my Tailnet, it should be impossible to access my devices.

So, anywhere that you may have used an address such as 192.168.1.143, you can instead use 100.12.34.56. Or, even better, you can be IP-agnostic and use blackbook-pro.smiley-tiger.ts.net. Regardless of what network I’m on, if I need to access my MacBook Pro, I will find it at blackbook-pro.smiley-tiger.ts.net.

The smiley-tiger.ts.net is my “Tailnet name”, and is a randomly-assigned pairing of two hyphenated words, with the ts.net suffix.

Who cares?

Perhaps the best way I can sell you on Tailscale is to enumerate why it’s useful to me.

Always-Available Pi-Hole & Swiftbar Widget

I really love Swiftbar, a small utility that lets you add things to your Mac’s menu bar. I use it for a couple of status widgets:

  • Is my garage door at home open or closed?
  • What is the current count of ATP members

I know neither of these is necessary, but they make me happy.

In the case of the garage door widget, it works by querying a Raspberry Pi in the house that reads a sensor on the door. The Pi will respond with whether or not the door is open. This works great in the house, but when I travel, I can’t access my Raspberry Pi. Well, I couldn’t, anyway. With Tailscale I can. Always. No matter what network my MacBook Pro is on.

Instead of having Swiftbar query 196.168.1.254, I have it query garagepi.smiley-tiger.ts.net. So no matter how my laptop is connected to the Internet, as long as I can get on my Tailnet, it will always show the status of my garage door.


All of the above is also applicable to my pi-hole, which I can now access always, from anywhere. Browsing the web with ads being suppressed via my pi-hole makes for a far more pleasurable browsing experience. Thanks to Tailscale, I can do so even when I’m out and about on my iPhone using cellular. Further, what’s great about using Tailscale to access my pi-hole is that all the web traffic is downloaded over my local connection to the Internet — it’s only the ad blocking (read: DNS queries) that are happening via my Tailnet.

Synology ↔ Synology Backup

I actually have two Synology devices — one that lives in my office and, frankly, is arguably the most important device I own. The other lives at my parents’ house, and serves almost exclusively as a backup destination for the main Synology.

In order to back up from one to the other, I needed to expose a port on my parents’ router/firewall, so my Synology could send data to the remote Synology. This is… fine… but certainly not what I’d prefer. There is no particular need for that device to be exposed to the Internet directly.

Enter Tailscale.

Now that I have both Synologies on my Tailnet, they can simply talk to each other through Tailscale. I’ve removed the port forward on my parents’ router, and the only way to get to my remote Synology is to either be in their house, or be on my Tailnet.

Remote Diagnostics

My dad is a very competent technologist… but he’s also getting older. As the world continues to run at warp speed, it’s understandably harder and harder for him to keep up. Occasionally, he runs into issues he needs my help with.

Though my parents only live about 45 minutes away, that’s not a trek I enjoy making under duress, in order to fix a computing-related issue my dad may be having. Often times, all I need to do is be able to see what he sees, or at worst, briefly control his computer.

At first, it seems obvious that the answer is to add my Dad’s MacBook Air to my Tailnet. While that would work, that’s not what I’d prefer — I shouldn’t need him to run software on the off-chance I need to help him.

Thanks to a combination of Tailscale and “subnet routers”, I can help him without any additional software installations on his part.

One of Tailscale’s advantages is that it is really good at incremental deployment — you can add a node here and there as you see fit. In order to assist in that process, Tailscale has a concept called “subnet routers”, which are bridges between your Tailnet and a network that is not in Tailscale.

I have my remote Synology — the one at my parents’ house — set up as a subnet router. This allows me to jump onto my parents’ network, and connect to any of their devices as though I was in their house.

Thus, I can use screen sharing to log into my Dad’s laptop and help him, when he needs it — with permission of course. No driving nor software installation required.

Selective Internet Egress

What with everything going SSL these days, you could make a strong argument that using public WiFi isn’t as dangerous as it once was. However, I’m paranoid, and I like to protect myself.

When I’m using public WiFi, I vastly prefer to actually enter the broader Internet from a known point — typically my house. This way, the venue where I’m sitting doesn’t get to know what I’m up to. Leaving aside data theft, just the possibility of someone following my footsteps across the Internet makes me very uncomfy indeed.

In addition to subnet routers, Tailscale also has the concept of “exit nodes”. In short, when one of your devices uses an exit node, they will use that as their point of egress onto the Internet.

Whenever I’m out and about, I choose to use one of the devices in my house as my exit node. Generally speaking, that device is actually my Apple TV — yes, really — which is almost certainly sitting otherwise idle. I’ve installed the Tailscale app on my Apple TV to allow for precisely this.

Thanks to using my Apple TV as an exit node, I appear to be inside my house to anything on the broader Internet.

Interestingly, if I ever wanted to appear to be in a different geographic region, I could stand up a tiny/cheap server in another region at Linode, and add that server to my Tailnet as an additional exit node. 👀

Tailscale SSH

Now available broadly, Tailscale SSH allows for quick-and-easy login to servers on your Tailnet, without having to futz about with passing keys around. Like all things Tailscale, it appears to work by way of magic.

For any Linux-based device on your Tailnet, you can opt that device into Tailscale SSH, which means you can instantly log into that device. And thanks to Tailscale favoring direct connections whenever possible, the experience should also be as fast and low-latency as possible.

But Wait, There’s More

I haven’t even spoken about funnels nor Taildrops, both of which have saved my bacon at least once. Seriously; there’s so much here.

Perhaps the coolest thing about Tailscale is that for individual users, in most contexts, it’s absolutely free. I’ve used everything described above, and I haven’t paid Tailscale a cent. Tailscale also has a ton of other features that I’m not using yet — such as sharing devices between Tailnets. There’s so much to unpack here; I’ve only glanced off the outer atmosphere.

Tailscale gets my highest recommendation.


  1. Tailscale did sponsor one episode of ATP, but that was quite a while ago, and they have no idea whatsoever I’ve written this blog post.


Callsheet on visionOS

Callsheet is now available on the Vision Pro!

Watching a movie or TV show in the Vision Pro is one of my favorite use cases. Now, you can slide a Callsheet window up next to your media player, all within visionOS. A full dual-screen experience, all within the Vision Pro.

Callsheet for visionOS is fully native. The overwhelming majority of the code is shared between the iOS, iPadOS, and visionOS apps. However, Callsheet is not running in compatibility mode — it’s a full-bore visionOS app.

I’ve taken a pass over the app and made Callsheet a good platform citizen. The visionOS version of Callsheet uses the accent color far more sparingly, uses depth where possible, and embraces background materials where appropriate. I’ve already discovered a couple places where things are awry, but I hope to have a new release in the next couple weeks to fix those oversights.

A couple small caveats, however:

  • Because icons are a different shape on visionOS, I’ve promoted one of the alternate icons on iOS — one that is better-suited for a circle — to be the full-time icon on visionOS
  • Speaking of icons, it’s not currently possible for users to choose an icon for any visionOS app, so that functionality has been disabled on visionOS.

Perhaps my favorite feature of Callsheet for Vision Pro is that Callsheet for visionOS is not a separate subscription. As always, I try to do right by my users; if you’ve subscribed to Callsheet on any platform, that subscription will carry over to all other platforms.

Though I will always think of Callsheet as iPhone-first, I’m already loving having it available when I’m watching a show or movie in my Vision Pro. If you’re a Vision Pro owner, I suspect you’ll really like it too.

You can grab it from the App Store right now!


 

In my [likely-futile] quest to unseat James and Shelly as the king and queen of Clockwise, I gratefully accepted Dan’s offer to join guest-host Rosemary Orchard and fellow guest Lisa Schmeiser on this week’s episode.

On the show, we discussed the recently-disbanded Project Titan, generative AI, simple fixes for problems that should be simple (but aren’t), and the 🤢 factor when it comes to using the Vision Pro in public.

Come for the nuanced discussion about an Apple car and AI; stay for me trying to justify using the Vision Pro outside the house. 🫣


Some Additional Callsheet Press

The Callsheet train keeps on chuggin’! I’ve been lucky enough to catch wind of a couple of really delightful pieces about Callsheet.


Today, Jason Aten (of, among other things, Primary Technology), wrote a lovely piece about Callsheet for Inc. Jason and I spoke briefly via email, and the piece came out really well. I particularly liked (and yet was slightly horrified by 😆) this quote:

To be completely honest, the only thing I can think of wrong about Callsheet is that it is incredibly underpriced (it’s only $9 per year). I mean that with all sincerity, Liss should be charging three to five times what Callsheet costs, and it would still be an incredible value. Ultimately, it’s an app that is successful primarily because of how much value it adds to its users. That might be the simplest lesson of all.


This week’s Mac Power Users was all about Stephen and David’s favorite iPhone apps, and they were kind enough to say some really lovely things about Callsheet as well.

The segment starts at 7:40, and included this lovely quote from Stephen:

Casey does not charge enough for this subscription; I’ll say this publicly: he should charge more.

And from David:

Casey knows what he’s doing; I feel like this is the big winner for Casey. He’s made several apps over the years, but to me this is the one.

😊

 

This week I did something quite weird: I appeared on a Polish podcast. To make it even weirder, I did so as my Persona.

I joined Wojtek Pietrusiewicz in discussing all things Vision Pro. We tried to keep the episode to half an hour, but, I blew us a bit past. Whoops.

Interestingly, for me, having known Wojtek some but never having met in person, I found his persona to be a completely reasonable representation of… him. My own ignorance to his actual appearance made the Persona a perfect stand-in. Conversely, having seen me on video before, Wojtek was… less enthusiastic… about mine. 😆

You can also see the conversation yourself, as Wojtek recorded it and posted it on YouTube.


 

As one would expect, I seem to be doing a press tour discussing the Apple Vision Pro. It’s been discussed on ATP twice, as well as on Analog(ue). New today is my appearance with my friend Max Roberts on Max Frequency.

On this episode, we ease in by discussing the last year-and-change of Max being a dad, Max’s recent Part 107 certification, and how things are going with Callsheet. Then, the main course: a discussion of all things Apple Vision Pro.

I always enjoy my appearances on Max Frequency; this one was no exception. While you may be chock-full of Vision Pro opinions, I thought this one was a fun recap of my first week-or-so with the device.


Vision Pro Panoramas

Take a look at this panoramic photo that I took in 2022:

Note, specifically, the wall. Taken at face value, it looks like whoever built that wall was drunk as hell. It certainly doesn’t look like what you’d expect: a rectangle. I remember it that way: as a rectangle. However, since my memory is trash, I looked up where the photo was taken, and sure enough, my memory was accurate:

The distortion on the first photo is to be expected from a panoramic photo. Pretty much every time I have a straight line in the foreground, it ends up distorted. My brain can [usually] make up for that when I’m looking at the photo again.


Everyone seems to have their own favorite feature on the Vision Pro. It may be watching movies, or watching spatial (3D) videos that you’ve captured, or perhaps the amazing Mac Virtual Display. Though MVD is probably my favorite, panoramas are becoming a close second.

Thankfully, I have occasionally taken panoramic photos in the past, and naturally, I’ve been going through them in the Vision Pro. When I opened up the one above, I was stunned. Naturally, I can’t properly represent what it feels like, but I can take a stab at showing you what it looks like:

There is also a larger version available.

The Vision Pro has un-distorted the image.

🤯

How incredibly cool. Consider me both surprised and delighted.


Multi-Award Winning

A Valentine’s Day surprise happened to me yesterday: something exciting was called to my attention:

Callsheet has won an Editor’s Choice award in the App Store!!

I couldn’t can’t believe my eyes.

Look at it!

Editors' Choice award summary

I’m not sure exactly when this landed, but I’m absolutely overjoyed about it.

As an added bonus, it shows up in search results too:

Callsheet search result with Editors' Choice logo

I’m not sure who at Apple made this selection, but know I’m forever thankful to you. 💙

Thanks to this, and the Upgradie, Callsheet is now a multi-award winning app. That’s pretty great. 😊


A Vision

This is my desk, today. Captured in situ, which is to say, messy as it always is:

A messy desktop with 3× 5K monitors upon it.

Upon it, from left-to-right:

  • A LG UltraFine 5K that was graciously given to me
    This monitor lives on my desk in the winter and is mostly used on the back porch in summer.
  • An Apple Studio Display
  • A LG UltraFine 5K that I bought secondhand from a podcaster friend

This is, by my count, 44,236,800 pixels of real estate[1]. I could absolutely get my work done in a single 5K display. I’ve found over the last couple years that I prefer to use 2× 5K. And if I have another just sitting around during the winter, why not add a third? It’s a bit overkill, but, #yolo.

Having all this space lets me spread out while I do my work. I organize things by display, and generally, it’s something like this:

  • Left: Things I don’t look at often, like mail/RSS/mastodon, as well as general-purpose browsing
  • Center: Xcode & iOS Simulator
  • Right: Git, documentation, Safari for research purposes. I also use a second Space (virtual desktop) here which runs Slack and Messages in split-screen.

I love this setup, until I leave it. Much like independent workers who are “unemployable” after enjoying just a few months of indie life[2], I feel hamstrung when I work elsewhere. Which I like to do at least once a week. I have stopgap measures, but they’re not great.


As I write this, we are a week-and-a-day away from consumers getting their hands on Apple Vision Pro. This ludicrously expensive device seems to be much like the Apple Watch — it has an ostensible purpose, but nobody really knows what consumers will actually do with it. For the Apple Watch, the purpose was fitness (or notification triage). For Apple Vision Pro, it’s entertainment, at least to start.

In thinking about where an Apple Vision Pro will fit in my life, I kept coming up short. I suspect it will be the best device in the house upon which I could watch a movie — quite a bit better than even my LG C9 and my beloved Sonos home theatre. However, watching something on Apple Vision Pro is an inherently solitary endeavor. My family can’t watch the movie I’m watching when it’s being blasted directly into my eyeballs.

I can absolutely imagine Apple Vision Pro being a phenomenal device when used on planes or trains. For better and for worse, I just don’t have the occasion to do so particularly frequently. I have made one plane journey since 2019, and one train journey.[3]

Standalone, I’m not entirely convinced Apple Vision Pro is for me. While I’m sure I’ll enjoy the rare occasions I get to use it without snubbing those around me, I don’t see those situations as being frequent enough to justify the considerable price tag.


Over the last week or so, as I debate how silly it was for me to preorder an Apple Vision Pro, I’ve found myself growing more and more excited about receiving it. This is unusual for me with Apple products, where I usually have an immediate crash of enthusiasm after a purchase. Not quite buyer’s remorse, as much as “oh, well, that’s done”. With Apple Vision Pro, I find my enthusiasm and excitement is 📈. Why?

It’s because my perspective has changed.

I remain mostly ho-hum about Apple Vision Pro as an entertainment device. Not because I doubt its capabilities — far from it. More because I just don’t have the occasion for a lot of solo media consumption today, so why would tomorrow be any different? It’s not you, it’s me.

However, with each passing day, I get incredibly excited about the prospect of Apple Vision Pro as a tool for getting work done. Though I’m very happy with my desk setup — lack of tidiness notwithstanding — it would be amazing to be able to bring that setup elsewhere.

With Apple Vision Pro, I reckon I will be able to.

Apple Vision Pro may be the best Mac accessory Apple has ever created.

Yesterday was an odd day, in which I spent time working at two different local libraries. While I was there, I realized that I am a week and change too early. If I had my Apple Vision Pro with me, I could have the workspace of my dreams, all with only my MacBook Pro and Apple Vision Pro.

Apple Vision Pro supports… uh… sucking-your-Mac-into-the-virtual-world mode. A 4K version of your Mac’s screen appears in the virtual space, but you can still interact with your Mac using its own keyboard and mouse.

That would allow me to build something like this extremely poor rendering shows:

A diagram showing a real desktop with a Mac on it, but a smattering of windows in 3D-space around it.

In this, I envision Slack and Messages to be the visionOS-native versions. I’m intermingling native visionOS apps with my Mac; the latter’s “monitor” is simply one window in the virtual space. That window, showing my Mac’s screen, can be surrounded by several visionOS-native apps as I see fit. The marriage of macOS and visionOS.

You know what’s better than 44 million pixels of real estate? ∞ pixels of real estate.

Now, imagine I could take things further. What if visionOS also supports Universal Control, between macOS and visionOS? Imagine I get a message in Slack or Messages, then I simply cast my gaze over to the visionOS-native app, and then start typing a response on my Mac’s keyboard.

🤯

This could genuinely level-up my ability to get my work done when away from the house.[4]

I remain blasé about Apple Vision Pro, standalone entertainment device. With each passing day I get more and more amped for Apple Vision Pro, my MacBook Pro’s greatest accessory.

The future isn’t here yet, but if Apple has done what I expect, it arrives on the second of February.

And I couldn’t be more excited.


  1. Roughly 24 million pixels more than you XDR folks. So there.

  2. I try very hard not to be unemployable, as you never know what the future holds. Here’s hoping I either never need to find out, or I can ease into the real world with grace if the time comes.

  3. Have y’all heard about trains? They rule. We Americans should look into these things more.

  4. Assuming I can get past the social stigma of being that guy. It didn’t take long with AirPods; I presume it’ll happen eventually with Apple Vision Pro too.


Listen To Your Users

We’re not even three weeks into the new year, but I’ve spent a fair bit of time procrastinating from working on Apple Vision Pro stuff working on updates for Callsheet. Today’s, in particular, is worth calling attention to.

In today’s update to Callsheet — version 2024.4 — I have fixed something that has driven users absolutely mad. I kicked the can down the road repeatedly, in part because I was trying to over-complicate the solution. I also did because this particular thing didn’t bother me that much

…until it did.

Erin and I were watching Oppenheimer, and I was curious who played the role of Albert Einstein. Oppenheimer has a ton of actors in it, and it took an annoying amount of scrolling to find the actor in question. I knew that my users were right: there needed to be some sort of affordance for searching within these lists.

Now, there is. Simply swipe down to expose a standard, system search field:

GIF showing Callsheet's search affordance

Hopefully this will resolve most people’s largest issue — including me. 😊 Note to self: listen to your users.

In addition to a plethora of bug fixes, I also added another minor feature: the ability to grab a Callsheet link (rather than web link) via the sharrow. If you happen to know that the person you’d like to send a link to is also a Callsheet user, you can now send them a link that iOS/iPadOS will open directly in Callsheet.

When you tap on a sharrow, you’ll now get a menu, where you can choose which to share:

Screenshot of Callsheet, taken just after tapping the sharrow, where a pop-up is shown, offering to share a web link or a Callsheet link.

Wherever possible, deep links are supported. The above would have shared this link.

In addition to the above, there’s also been a ton of bug fixes, which are detailed in the app’s release notes on the App Store, because I’m not a jerk.


Version 2024.4 is rolling out slowly now, but if you’re impatient, open up the App Store and search for Callsheet. That should offer you the option to Update and thus jump the queue.