8

I'm using Alamofire to make a call to a webservice which takes a pretty long time to load. If the app goes into the background I get stuck with my loader when I return to the app. I imagine it's because the call never returns anything to my completion handler. How can I address this problem?

Marcus Leon
  • 55,199
  • 118
  • 297
  • 429
Recusiwe
  • 1,594
  • 4
  • 31
  • 54

2 Answers2

8

You can use background fetching to solve this problem. It can be done in the following way in Swift 3:

    var backgroundTask: UIBackgroundTaskIdentifier? // global variable        

    backgroundTask = UIApplication.shared.beginBackgroundTask(withName: "backgroundTask") {
        // Cleanup code should be written here so that you won't see the loader

        UIApplication.shared.endBackgroundTask(self.backgroundTask!)
        self.backgroundTask = UIBackgroundTaskInvalid
    }

Call your alamofire service after this line. In the completion handler, end the task using the below lines.

    UIApplication.shared.endBackgroundTask(self.backgroundTask!)
    self.backgroundTask = UIBackgroundTaskInvalid

Please note that the app has some background time (backgroundTimeRemaining property) remaining before it enters the inactive state. You have to get your task done before that time. The handler is called shortly before the remaining background time reaches zero. Also, each call to the method beginBackgroundTask(withName:){} must be balanced by a matching call to the endBackgroundTask: method.

To make the code given above work, you need to adjust settings in your app. Go to "Targets" and click on "Capabilities" to make the following changes

Changes to made in "Target" section

After that, go to your info.plist file, and open it as Source to add the following code.

enter image description here

I hope this helps you. If you need more detailed information, these links might help

Marcus Leon
  • 55,199
  • 118
  • 297
  • 429
KrishnaCA
  • 5,615
  • 1
  • 21
  • 31
0

The problem can be solved by adding:

application.beginBackgroundTask { }

into func applicationDidEnterBackground(_ application: UIApplication) and

application.endBackgroundTask(.invalid)

into func applicationWillEnterForeground(_ application: UIApplication)

Ayan Kurmanbay
  • 119
  • 2
  • 2