How can I programmatically enable Guided Access (Kiosk mode) on an iPhone?

Question

How do I automate Guided Access mode on an iPhone? I will need to automate the enabling and removal of this feature

Background This application from the State of Iowa uses an iOS app to display your drivers license. The issue is that after handing your phone over to authorities, they have full access to the device.

If I have the source code to this, or a similar application, how can I require a password when switching out of temporary "Kiosk mode", so that photos, emails or text messages are not available from either the phone, or (ideally) from USB.

I found this similar solution for Android, but am now looking for an iOS solution


You can enter and exit guided access mode from within your app. However, to do so the device has to be supervised, and have an MDM profile installed that has the app's bundle ID in the list of applications that can request guided access mode (the key is autonomousSingleAppModePermittedAppIDs.

Once that is done, to enter guided access you do this:

UIAccessibility.requestGuidedAccessSession(true){
    success in
    print("Request guided access success \(success)")
}

Below iOS 7

You can't put iOS device into Kiosk mode programmatically, also you can't do anything on your app for making it a Kiosk app (You can't disable the home button events programmatically and you can't get the events in your app)

For making the device to work on Kiosk mode, you can use Apple's Guided Access. But you can't enable it programmatically. For more info check here


iOS 7 and 7+

You can use:

void UIAccessibilityRequestGuidedAccessSession(BOOL enable, void(^completionHandler)(BOOL didSucceed))

Reference UIAccessibilityRequestGuidedAccessSession

UIAccessibilityRequestGuidedAccessSession

Transitions the app to or from Single App mode asynchronously. Declaration

Swift

func UIAccessibilityRequestGuidedAccessSession(_ enable: Bool, _ completionHandler: ((Bool) -> Void)!)

Objective-C

void UIAccessibilityRequestGuidedAccessSession ( BOOL enable, void (^completionHandler)(BOOL didSucceed) ); Parameters enable

Specify YES to put the device into Single App mode for this app or NO to exit Single App mode.

completionHandler

The block that notifies your app of the success or failure of the operation. This block takes the following parameter: didSucceed

If YES, the app transitioned to or from Single App mode successfully. If NO, the app or device is not eligible for Single App mode or there was some other error. Discussion

You can use this method to lock your app into Single App mode and to release it from that mode later. For example, a test-taking app might enter this mode at the beginning of a test and exit it when the user completes the test. Entering Single App mode is supported only for devices that are supervised using Mobile Device Management (MDM), and the app itself must be enabled for this mode by MDM. You must balance each call to enter Single App mode with a call to exit that mode.

Because entering or exiting Single App mode might take some time, this method executes asynchronously and notifies you of the results using the completionHandler block. Import Statement

import UIKit Availability

Available in iOS 7.0 and later.

Also you can use UIAccessibilityIsGuidedAccessEnabled for checking whether Guided Access is enabled or not.