In How to Create Real Recurring Location-based iOS Reminders, I described a method using IFTTT to mark location-based reminders as incomplete. Shortly after that post, I upgraded my iPhone to iOS 13 and quickly discovered that the update broke then IFTTT iOS Reminders service. All triggers and actions in the service no longer worked as expected (or at all), including IFTTT’s Reminder Completed in List trigger. So I was back to dismissing my recurring location-based reminders without marking them as complete. And on top of that, despite the additional functionality of the new Reminders app, I started encountering all sorts of issues, including the fact that Reminders in Notification Center started randomly turning itself off. While I haven’t found a solution to that and other new Reminders issues, I did come up with a solution to replace IFTTT’s broken Reminder Completed in List trigger. Read on to discover how… Continue reading
My parents are getting up there in age and awhile back, I was dismayed when my dad asked me if a message from “Apple” on his answering machine about his iCloud account being hacked was real (he thought it was!).
I’d been suggesting for awhile that he port his number to google voice so he could stop paying for land line service. I’d looked up how to go about doing it. But I’d been second guessing that option after reading some horror stories about people losing their life-long phone numbers. Plus, I wasn’t too thrilled about google listening in on all their calls.
I had set up Nomorobo for them some time ago, and it was effective for awhile, but the telemarketing industry and scammers started spoofing random local numbers. So they were getting multiple scam calls a day and I worried about them falling for a phishing scam, or worse. Their neighbor had fallen victim to a scam where a caller pretended to be their grandson and needed bail money asap. She ended up being scammed out of $10k.
I had looked through all the services from my parents’ landline provider for blocking callers, etc, but the options were very limited, even though they had a VOIP service through their cable company. There was no way to implement a white list (a list of known callers that are allowed to call you), nor was there a way to implement call screening other than caller ID.
But I recently had an inspiration based on the way nomorobo is set up. I could do both – whitelist all my parents known callers and send the rest through call screening using google voice, without porting their number and without (the majority of) their calls being listened in on by google! Read on to find out how… Continue reading
Inexplicably, iOS Reminders do not have a repeat option underneath their “Remind me at a location” setting when creating a reminder, or a “Remind me next time” (…I arrive here) selection when you hard-press a reminder notification. The only way to hackily get repeated location-based reminders is to never mark them as completed. The problem with that way of dealing with location-based reminders is that 1. they eventually disappear from your notifications and 2. you cannot tell whether you’ve actually completed the reminded task or it is still yet to be done.
I have figured out a way to create recurring location-based reminders using:
Read on to learn how… Continue reading
I just put the finishing touches on my bus shortcuts on my iPhone. It always bugged me that I couldn’t ask Siri “When’s the next bus to work?” or “When’s the next bus home?”. NJ Transit has a web interface called My Bus Now and I always have it up on a first gen iPad in the bathroom in the morning, but frequently, as I’m rushing around to make it to the bus, I want to do a quick time check to see how far away the bus is. My hands aren’t always free or I don’t want to stop running around, unlock the phone, navigate my home screen, tap my homescreen shortcut, put my glasses on, wait for the page to load, and look at the screen to make sure it’s the right bus route (which I frequently miss and sit there at the stop kicking myself for not noticing the next bus was for a different route number). It’s much faster, accurate, and more efficient to just say “He Siri, when’s the next bus to work?”, with all those details taken care of for me. With Siri Shortcuts in iOS 12, this is now possible.
And here’s the answer:
- Turn airplane mode on, then off
The fastest way to do this is to swipe up from the bottom of the screen to access the control center, then tap the airplane icon:
Wait for the other icons to darken, as the phone turns off wifi, bluetooth, and cellular signals, then tap the airplane to turn those back on again. After doing this, you should be able to load anything on your local network using its .local address (as long as it’s configured correctly on the remote device).
This is a temporary solution. Access to .local addresses will stop again at some point and you will have to repeat this work-around to regain access.
Here’s the cause and why this solution works:
At some point, an iOS update seems to have caused this issue. The problem is Apple’s usage of .local addresses for its bonjour services (which allows devices to advertise their services, such as printing an airplay). Bonjour does not play nicely with other services which use .local. Bonjour is somehow interrupting the DNS resolution of these addresses. It intercepts the communication of for example, your browser and the device providing the service and the presenting symptom (at least in my case) is a browser timeout. The browser claims that the website simply stopped responding. Each device has its own strategy to try and resolve domain names. On a mac, that can be configured using the /etc/hosts file, but on an iPhone, the user doesn’t have a way of editing that equivalent setting. What’s more is, the iPhone caches these shortcuts, and it’s that cache that is the problem. Turning on airplane mode flushes that cache and allows your services you’ve manually set up on your network’s devices to get through. However at some point, bonjour is going to come along and cause that cache to be reinitialized and cause the issue to recur. This is why this is not a permanent solution.
What is a .local address?
Dot local addresses are memorable shortcuts to access other devices on your local network. It’s like your own personal dot com. All major OS’s support them: macOS, Windows, Linux, even RaspberryPi. You can use it for screen sharing, file access, web pages, ssh, etc.. If you’re running a web server on a computer in your home, you can access it from a web browser on another device by going to it’s .local address in a web browser, e.g. mymac.local.
I use my .local domains from my iPhone to do a number of things when I’m at home on my local network: screen sharing via the VNC app, ssh via the Terminus app, watching live TV via the iPhone’s Safari browser that accesses my EyeTV media server, and some websites I created for fun. I usually add bookmarks to local web URLs to my home screen for easy access.
How do I find/edit my computer’s .local domain name?
Each mac on your network has a .local address based on your computer’s name. You can find it in the Sharing pane of the System Preferences app. At the top of the pane, there’s a entry field for your computer’s name and underneath that is some descriptive text. You can enter any name you want, but not all characters on your keyboard are allowed to be used in a domain name. macOS thus removes some characters, such as apostrophes, and replaces other characters (such as spaces) with dashes.
I tried using the .local address after this fix, but it doesn’t work.
macOS doesn’t activate a .local address by default. You must share the service you want to use in the Sharing pane of the System Preferences app. The section under the computer name has a panel with checkboxes where you can turn on or off certain services. As long as one is turned on, the .local address is active. However, the only devices that can access it are ones that are on the same network. If you’re trying to access it from an iPhone, for example, make sure that you are connected to the same WiFi network as the computer you’re trying to reach. If all else fails, you can use the computer’s local IP address (assigned by DHCP). You can find that address in the Network pane of the System Preferences app. If that works, and you’ve tried turning airplane mode on & off on your iPhone, then the .local should work. If that doesn’t work, let me know in the comments.
Other things I tried.
I first encountered this issue when I was trying to access my EyeTV media server. I have used this server for over a decade, but about 4 or 5 years ago, I moved and no longer was receiving a good broadcast TV signal. I recently bought a new outdoor directional antenna however, and now had stuff to watch. So I opened up the old bookmark I used to reliably use on my iPhone for years that used the .local address of the computer with the EyeTV media server. It wouldn’t work! I discovered that if I went to the computer’s DHCP address, it did work. I could have just changed the bookmark, but it irks me when stuff that should work, doesn’t, so I called Apple.
Apple Support had me “Reset All Settings” because they could not explain why it didn’t work. (I’ll be submitting a bug report after this post.) It worked! It was a heavy-handed solution and I spent a week returning my phone to its normal behavior. Then the next day I tried to access the server, the problem was back!
Googling this was not much help. There are many solutions out there that suggest things like turning your phone off/on, clearing your browser cache, turning sharing preferences off and back on, etc.. None of them worked. Every once in awhile, I randomly noticed that the .local addresses started working, but shortly there-after would stop working again. And I didn’t want to have to reset all settings every time this happened. Finally, after reading about the /etc/hosts file and mDNSresponder, I started googling things like “reset iphone dns”, which lead me to a solution for another problem that involved cycling the airplane mode setting and to my delight, it worked.
I’ll probably use the DHCP-assigned IP address for bookmarks in the future, but I finally know enough about what’s going on to be satisfied. I hate it when things don’t work.
I recently wrote an Automator workflow that asks me if I want to check the arrival of the next bus and opens the local transit system’s bus stop arrival web page that shows the live time the next bus is expected to arrive at the stop I saved in the workflow. I then created a recurring calendar event in the Calendar app that opens the Automator application I’d saved. (I could have created a cron job, but I like the ability to easily adjust the alert time if I need to leave work early.)
The alert is a custom alert, which I selected to occur “at the event time” and “Open file…”, for which I selected my bus Automator app. I quickly noticed that at some point in the week, the alerts on all my recurring events change to a default of a simple notification with a sound occurring the day before. The first time I missed the bus, I discovered the problem and edited the event to fix it. But it kept happening, and happening.
TL;DR: The procedure is at the bottom of this article. Continue reading
Today I discovered that I didn’t have enough iCloud storage space for a file I wanted to share. In the past (apparently since sometime in 2015), I was able to find space here and there, but today, it appeared, I was out of options. Actually, I don’t really use iCloud for much, storage-wise. I upgraded my iCloud storage to the 50G plan, mainly just for backups for apps, email, and a few documents, but with all that extra space (coming from the free 5G plan), I had decided to turn on backups on my other iOS devices and… to turn on the iCloud Photo Library on my phone. I didn’t really understand how it worked. Apple always seems to be changing its photo synching services. I had imagined it would be awfully nice if I didn’t have to physically connect my phone to my computer to upload my latest photos, because up until I activated the iCloud Photo Library, I would occasionally sync and select to remove photos from my phone after import. So through some wishful thinking, my synching sessions got fewer and fewer and I noticed that it never seemed to free up much space.
Somewhere along the line, iPhoto gave way to the Photos app on macOS, and the “remove after import” checkbox went away and I figured they must have figured it out the way I’d previously imagined. After each import, the photos would no longer be detected on the phone from the photos app, so I just hoped they were getting transferred. I was confused that I still seemed to have photos on my phone – lots of them, but I still had space, so I just hoped everything was being magically handled. Besides, I had other things to worry about, so I chose to ignore the problem and just hope that things were somehow magically and wirelessly getting to my computer. I willfully put out of my mind and didn’t think about the fact that I had intentionally not turned on the iCloud Photo Library on my computer, because I knew I had 10 times as many photos there as I had on my phone.
Today however, I finally tallied the photos on iCloud, and it was over 20 gigs! I tried synching my phone again. I couldn’t tell where all the photos on my phone were being stored. Why could I transfer some, and they would disappear, yet I had seemingly 3 years of photos on my phone. Were the photos in the iCloud Photo Library also getting onto my computer? It looked like some were in both places, but were they all? I searched for a way to limit the space that photos would take up in iCloud. I googled to find out whether I could safely delete photos from my phone(/iCloud?) and I got mixed messages.
The thing is, it’s not transparent where a particular photo is stored when I’m in the photos app and there’s no way to let my computer handle it the way it had in the past. So I decided to recruit some help and called Apple. I eventually got elevated to a Photos app expert (Jacob), and he explained things very well. Here’s how I understood it:
- All the photos on my phone were being saved on iCloud, and only in iCloud.
- I had enabled “Optimize iPhone Storage” in the Photos Settings, which means that I only had compressed/smaller versions of the photos actually on my phone. The full versions were in iCloud.
- When I synched my phone with my computer, I was only getting recent photos that hadn’t uploaded to iCloud yet.
- Those transferred photos weren’t removed from the phone, so they also ended up on iCloud (but anything that had uploaded to iCloud since the last time I synched, never made it onto my computer).
- The macOS Photos app does not synch the compressed/small versions of photos on my phone that were reduced after uploading to iCloud.
So I was faced with an issue. Normally, one would just turn on the iCloud Photo Library on the computer and it would download all the high res photos, but doing that would be a 2-way synch and I had 10 times the amount of photos on my computer. There wasn’t enough space in my iCloud drive to synch everything. I could have bought more iCloud drive space, but I already have the photos on my laptop backed up on a NAS drive, so I’d prefer to just transfer the iCloud Photo Library to the computer. So here’s how we did it…
- Quit the macOS Photos app.
- Start up the macOS Photos app while holding down the option key.
- Select to create a new photos library and name it something like “iCloud Photos”.
- Open System Preferences -> iCloud.
- Turn on Photos and click the options button.
- Turn on the iCloud Photo Library.
- In macOS Photos, click “Photos” at the top left.
- Scroll to the bottom and wait for the downloading message to change to “Updated Just Now”.
- Select all the photos and choose Export -> Export Unmodified Original…
- Save the photos in a new folder on the desktop.
- Quit macOS Photos.
- In System Preferences, turn off the iCloud Photo Library.
- Start up the macOS Photos app while holding down the option key.
- Select the original Photos Library.
- Select File -> Import…
- Select the folder you created on the desktop and click “Review for Import”.
- Wait for all the photos to be detected then select them and click “Import All New Items”.
- When the import is done, delete the folder you created on the desktop and the iCloud Photos Library that Photos created in your “Pictures” folder.
- [Proceed if you wish to remove the photos from iCloud, and thus your other devices…] Open System Preferences -> iCloud, then…
- Click the “manage” button at the bottom right.
- Click Photos, then click “Disable and Delete”
I never would have figured this out on my own and I imagine that many of you are just as bewildered as me, that is unless you started taking pictures after the iCloud Photos Library was created.
A couple things to note: 1. Photos you take in other apps (such as in the Messages app, whether they were taken and sent or received) are not in the iCloud Photos Library. 2. The macOS Photos app no longer detects duplicates, so importing photos that you previously synched (before they were uploaded to iCloud) may result in multiple duplicates. There are apps available on the App Store for detecting and removing duplicates.
I’ve posted about Proximitask before. It’s no longer on the app store, despite it’s usefulness (especially when paired with RadBeacons which you can plug into any USB port). I would post a Proximitask download link if any of them worked anymore, but if you still have it on your iPhone and use it all the time like I do for indoor location based reminders via iBeacons, you may have run into one annoying bug: you mark a reminder as done, but the reminder sometimes persists to pop up. Here’s a way to permanently quiet those reminders… Continue reading
If you work for a university and have developed a macOS app (as a part of your academic job) using 3rd party software (e.g. a Java app developed with Eclipse and built with Gradle), you’re probably familiar with telling your users how to deal with the annoying “Unidentified Developer” error they get when they double-click your app:
They get a window saying “<your app> can’t be opened because it is from an unidentified developer“. The user is given no clear option on how to run the app except a vague reference to “security preferences”.
There are things the user can do to get around this error without you becoming an “identified developer”. A user can perform a one-time bypass by right-clicking the app and selecting open or they can muck around with their Security & Privacy System Preferences settings. They can even execute some commands in the Terminal to reveal a setting that has been hidden in the past few versions of macOS to always allow apps from anywhere. But what would be nicer is to eliminate this error so that the user doesn’t have to do any of that. Normally that involves giving Apple money to pay for membership in their developer program, but if you’re in academia, Apple has free such accounts for “Educational Institutions”.
Chances are, your university has already enrolled in this program and all you have to do is hook into that resource. But be aware that universities have an image to uphold and that digital identity extends into the App Store, so they’re not likely to welcome any app to sit alongside their custom campus, reunions, and transit apps. You can belay their fears about your app by noting that you intend to distribute your app outside of the App Store. Users who download your app won’t even ever see the university’s name unless you added it to your app yourself. All you need is a certificate that will allow you to code-sign your app so that Apple can know who you are.
It took me awhile to navigate this system. I initially ran off on this tangent trying to create a free “education” Apple Developer account by digging up and supplying my University’s D-U-N-S number, official address, etc… and ran into a form that asked me to assert that I could commit the university to legally binding agreements, at which point I realized that I was on the wrong path. Free educational institution Apple Developer accounts aren’t per person, faculty, or department. They’re 1 per university. I already had a couple of official university apps on my iPhone, so I knew there already existed an account, and made a number of calls before I got put in touch with the Apple Developer Account “holder”.
Those in charge of the Apple Developer Account here were only familiar with iOS app development, so they didn’t know how to advise me on accomplishing what I wanted to accomplish. My sole goal was to eliminate the “Unidentified Developer” error. No-one knew whether that meant I had to distribute my app on the app store or what, and they were of course concerned about the app showing up alongside all their campus-centric apps. I managed to convince them that I wouldn’t be distributing on the app store and that I believed all I needed was a code-signing certificate. Since no-one here knew how to do that, I called Apple again.
Apple really pushes their developers into Apple’s canned development resources (XCode) to do their development. In fact, even their developer support team members tend not to know anything about code-signing and certificates, because it’s all handled in the background behind XCode. I had numerous phone calls with Apple Developer Support and they proclaimed that it sounded like I was “speaking a different language”. They weren’t even familiar with the “Unidentified Developer” error and immediately referred me to the makers of the 3rd party development apps I was using, implying it was a problem with their software. I persisted however, because I had already tried code-signing using apple’s
codesign command line utility and managed to get them to at least confirm that what I suspected was happening was happening. And that is, that not any certificate will do… but I’m getting ahead of myself.
Years ago, I discovered the convenience of treating the Spotlight search as a calculator. If you paste in an equation, the top result will be what the calculator app produces given the math you’ve typed or paste in. I take a lot of notes in my work and frequently have a simple equation to calculate or numbers to sum or subtract. It’s easy enough to copy and paste an equation into spotlight or paste a set of numbers (with some manual clean-up) to Excel or even search & replace with plus or minus signs & paste into spotlight, but you’d be surprised how much more efficient it feel to do this automatically. You can even have it paste the result after the end of the highlight.
Combine this with the fact that many text editing apps allow you to select columns of text, and it becomes a trivial matter to do things with masses of numbers in any text and any app.
The sum & subtract automator services also conveniently strip out non-number characters, so you can highlight any numbers that have text in between and sum or subtract them.
Let’s start with the Sum service. Here’s an example of how it works:
As seen above, you simply:
- Select text with the numbers you want to sum
- Right-click the selection, and
- Select Services->Sum.
The numbers are parsed and added using Spotlight. In the demo above, I simply tap the escape ket to exit spotlight after seeing the result. But, you could select & copy the result to use it how you wish, directly from the spotlight result listing.
The subtract service works the same way as the Sum Service above, but instead of adding all the numbers, it simply takes the first number and subtracts all the rest. Both services ignore non-numbers and can handle decimals. It even knows the difference between hyphens in words versus negative numbers. However, they may have some trouble with non-standard hyphen characters and periods in full sentences.
Calculate (& Append Result) Service(s)
The Calculate Service (or “Calculate & Append Result”) will take any equation that Spotlight (i.e. the Calculator app) can handle and compute the result. And if you know already that you will want to append the result after the highlighted text in the form of ” = answer”, you can alternatively select the “Calculate & Append Result” Service. Here is a demo using the service:
- Go to the github gist containing the Applescript code for each service
- Copy the code from one of the 3 files in the github gist
- Open Automator.app
- Select service “Service”/gear icon from the dropdown sheet & click “Choose”
- Drag the “Run AppleScript” action into your workflow
- Replace the purple code in the Run AppleScript action with the code you copied in step 1
- Save the workflow and name it however you would like it to appear in the services contextual menu (E.g. “Calculate & Append Result.workflow” – the extension will not appear in the menu)
- Repeat for the remaining 3 services.
The workflows/services will be saved automatically to your Library/Services directory in your home directory. If you right-click the file name at the top of the window in Automator, you can select the Services folder to reveal it in the Finder. You can then copy that file and send it to any other computer you would like to also have that service.
Disclaimers: These services are only intended as a quick and dirty solution to work in any context, & any app. If you have a repeated common use-case, consider other solutions. Note also that any application which reserves the arrow keys for some function when the shift key is held down, other than modifying the most recent selection, this service will fail. Some applications, such as java applications, modify selections using shift-arrow navigation differently, depending on the direction of the mouse drag during text selection. This can produce unexpected results. A work-around for both such issues can be to use the strategy used for Terminal.app, but this would required modification to the code. A few of the features in the script rely on some tricks such as statically set delays and command-line calls, necessary to either wait for an application to respond or to control the focus of various windows. If your computer is very busy or has any configuration issues, the proper functioning of these services may be disrupted. These services were developed and tested on macOS High Sierra, 10.13.4. They may or may not work in other macOS versions.