justin․searls․co

Installing a Content Blocker on iOS 9 Public Beta

After spending 3 weeks abroad, literally afraid of opening anything resembling an article in Safari, I was eager to come home, install a beta operating system, and take advantage of iOS 9's now-famous content blocking API. There are a few projects on GitHub that do this, but the most evolved seems to be Block Party.

Let's try out installing a content blocker on an iPhone for ourselves. The instructions below are mostly complete and a bit inane, so it's up to you whether you're better off just waiting the 4–6 weeks until iOS 9 is released to the public.

First, there are some pre-requisites:

With these in place, it's time to open BlockParty.xcodeproj

If this is your first time launching Xcode, you'll need to first let it install additional components, then switch the target from an iPhone 6 simulator (the default) to an iOS device, like so:

After this, plug in your iPhone and its name and model icon should replace the generic "iOS Device" label:

Next, press Run (the familiar "Play" icon at the top-left) and you'll be prompted whether or not you'd like to enable Developer Mode on the Mac (it's up to you, and shouldn't be necessary for the purpose of this task).

You'll probably be greeted with an error that your phone is still processing symbol files, as shown below. Just wait it out until it's completed:

When it's finally ready, click Run again to see the next error:

To resolve this, first click "Fix Issue", which will prompt you to log in to your Apple ID (you no longer need to be a member of a paid developer account, but you do need to be logged in to generate the necessary provisioning profile).

If you try again, you'll get a similar error because these App IDs are reserved by the author of the repo. You'll need to set your own; to do so, start by clicking the project in the left and change the bundle IDs of both targets "BlockParty" and "RediffBlock" to something unique. Here I just replaced his domain name with "com.github.searls"

Each Bundle ID you enter needs to be registered with Apple, which Xcode can do for you by pressing the "Fix Issue" button in the same editor pane:

Now, when you click Run, you should get all the way through installing the app. The failure you see next will be a generic failure with only the message "Security". This is because iOS 9 requires user input on the device to explicitly trust each developer that's loaded apps onto the it.

Next, on the phone, jump into Settings -> General -> Profiles and select your Apple ID under "Developer Profiles", then tap the "Trust" link and subsequent confirmation dialog.

Next, launch the "BlockParty" app from your home screen so that it can register itself to iOS as providing a content blocker.

Finally, in Settings -> Safari -> Content Blockers, you'll see:

Enable it, and you should be able to test in Safari by seeing fewer popover ads appear at a site like iMore or The Verge.

See, wasn't that simple!


Got a taste for hot, fresh takes?

Then you're in luck, because you can subscribe to this site via RSS or Mastodon! And if that ain't enough, then sign up for my newsletter and I'll send you a usually-pretty-good essay once a month. I also have a solo podcast, because of course I do.