There are plenty of things to explore and write about. Today, I would like to write about my first steps and attempts to outsmart limited SiriKit capability given to us, developers in iOS 10. Was I successful? Hop in and check out yourself. Seven getting started tips will get you on board faster.

Sample scenario

For my little experiment I have used an imaginary help desk app. It helps customers to search for answers in FAQ, Knowledge Base Articles and Community threads.

You may notice that Siri integration would be nice here – you could ask her a question and she would return a list of matching results. All that possible without launching an app and typing a question yourself.

Getting started

Getting started with SiriKit would not be that hard if it was not for Xcode 8 beta. James’ Quave tutorial and Apple’s Siri Integration Guide come in handy. You can find links to both in references. Xcode 8 beta is sometimes not stable enough and its new code signing features may be initially in your way.

Tip 1: How to debug Intent

First question that may come to your mind is how to debug Intent?

NOTE: You should debug on a device.

Step 1: Build and run your base app from Xcode as usual

Step 2: Then select Intent scheme, build and run it.

Tip 2: Cannot debug – ‘Cannot attach…’ error

Following Tip 1 may not be enough. My debugger could not attach to Intent and I still have no clear answer how to deal with it. A combination of restarting Xcode, iPhone, removing an app and using Xcode 8 code signing switches fixed the issue. My best bet is code signing issues. Try to redownload profiles or reinstall developer profile. Unchecking and rechecking automatic signing feature in Xcode 8 may help too.

Tip 3: Enable an app in Siri Settings

Your app should be enabled in Siri Settings. You can achieve it in two ways:
Go to Siri in Settings app and enable your app.
Request it from the app, similarly to requesting other capabilites like push notifications.

Tip 4: Remove print statements

If you want to use print debugging in IntentHandling methods make sure to launch them on the main queue. At the time of writing (Xcode 8 beta 2) print function seems to be broken, so you may experience some throws or even crashes. Hopefully, this will get better in beta 3. For now it is better to experiment without it.

Tip 5: Do not leave empty protocol methods

If you leave IntentHandling methods empty, you can get all sorts of weird behaviors from Siri. ‘Sorry, YourApp is incompatible’ or ‘Sorry, You will have to continue in the app’ are examples. Luckily, usually all methods apart from handle are optional so you can quickly get started and then add new methods as you progress.

Tip 6: Siri Entitlement

This is new to Xcode 8 beta 2. To be able to play with SiriKit you should enable Siri in Capabilities tab of your app’s target:

Tip 7: Fill plist with supported Intents

Many features in iOS require this. It is similar for SiriKit. Your SiriKit Intent Extension contains separate Info.plist file. Under NSExtension -> NSExtensionAttributes there is IntentsSupported array that should be filled with supported Intents.

Let’s get back to our challenge. Is it possible to use SiriKit Intents when our app has little to do with them? Can you also get a nice experience for your users?

There is no generic Intent that would fit into our app’s context. So we will pretend to be a messaging app as there is Intent for that.

Let’s take a look at a very simple implementation of Intent Handling:

extension IntentHandler: INSearchForMessagesIntentHandling{
    func handle(searchForMessages intent: INSearchForMessagesIntent,
     completion: (INSearchForMessagesIntentResponse) -> Void){
        let userActivity = NSUserActivity(activityType: String(INSearchForMessagesIntent.self))
        let response = INSearchForMessagesIntentResponse(code: .success,
         userActivity: userActivity)
        response.messages = [SupportMe.articles[0]]

What is up there?

This struct works as data store of our app. From this store we will provide content for Siri to handle.

IntentHandler is a class generated automatically when you create Intent Extension. As good Swift citizens we add conformance to INSearchForMessagesIntentHandling in an extension.

You may have noticed that we do not process intent at all. It just returns a hardcoded answer. That is because we want to check if we get our handler launched and response returned when we speak to Siri without the context of specified Intent.

Doing it like Siri expects

Our app has INSearchForMessagesIntent defined. Siri will expect messaging app behaviours from it.

We test INSearchForMessagesIntent heavily here. As it comes out the ‘Search’ word in this Intent definition is obligatory. When trying to use synonyms like ‘Look in’ or ‘Browse in’ we end up with web searches rather than being attached to our app.

What about ‘message’ in commands?

To be honest there is nothing wrong with the word search in Siri commands. We would also search for answers in SupportMe app. ‘messages’ is more disturbing. Knowledge Base Articles or Community threads have little to do with messages.

Sorry, no luck here. Apparently we are forced to use very strict syntax that INSearchForMessagesIntent understands. Without ‘search’ and ‘message’ words Siri will not pass intent to our app extension.


Experiment that we have conducted proves that SiriKit in a current version is quite limited and not that customisable. For now if you want to use SiriKit you will need to conform to strict Intents vocabulary. It may feel awkward for users, so we should think twice before implementing it.

Talk to Us