-
Notifications
You must be signed in to change notification settings - Fork 21
Geofencing service
Geofencing allows you to establish a virtual fence around a predefined geographic area. When one of your app users enters or exits the area, you can set your app to push a message to the user. Infobip IP Messaging Platform supports geolocation based campaigns. This guide explains how you can easily setup your iOS application to support geolocation-based campaigns.
Include NSLocationWhenInUseUsageDescription
and NSLocationAlwaysUsageDescription
keys in your app’s Info.plist. These keys let you describe the reason your app accesses the user’s location information. The system includes the value of these keys in the alert panel displayed to the user when requesting permission to use location services.
MobileMessaging SDK has geofencing service disabled by default.
In order to enable the Geofencing service, use one of the following options:
- In case you are starting MobileMessaging manually:
// Swift
MobileMessaging.withApplicationCode(<#your application code#>, notificationType: <#notification type#>).withGeofencingService.start()
// Objective-C
[[[MobileMessaging withApplicationCode: <#your application code#> notificationType: <#notification type#>] withGeofencingService] start: nil];
- In case you are inheriting your
AppDelegate
fromMobileMessagingAppDelegate
, you overridegeofencingServiceEnabled
variable in yourAppDelegate
:
// Swift
override var geofencingServiceEnabled: Bool {
return true
}
// Objective-C
-(BOOL)geofencingServiceEnabled {
return YES;
}
Once the service is enabled, it starts up after the MobileMessaging.start()
is called and the service will automatically prompt user for permissions for the app to use iOS Location Services. The “Always” authorization level is requested by default for the sake of better monitoring accuracy.
In case you want to change the default authorization level or to implement your own initialization and launching flow the Geofencing service has a convenient API:
// Swift
MobileMessaging.geofencingService.authorize(.WhenInUse) { capabilityStatus in
switch capabilityStatus {
case .Authorized:
// user has authorized the service, you are free to start using it
MobileMessaging.geofencingService.start()
case .Denied:
// user denied the access for Location Service, you can try to talk him out of it :)
case .NotAvailable:
// the service is not available on the device, there is nothing you can do
case .NotDetermined:
break // a fairly unlikely scenario
}
}
// Objective-C
[[MobileMessaging geofencingService] authorize: MMLocationServiceUsageWhenInUse completion:^(enum MMCapabilityStatus capabilityStatus) {
switch (capabilityStatus) {
case MMCapabilityStatusAuthorized:
// user has authorized the service, you are free to start using it
[[MobileMessaging geofencingService] start: nil];
break;
case MMCapabilityStatusDenied:
// user denied the access for Location Service, you can try to talk him out of it :) #>
break;
case MMCapabilityStatusNotAvailable:
// the service is not available on the device, there is nothing you can do #>
break;
case MMCapabilityStatusNotDetermined:
// a fairly unlikely scenario
break;
}
}];
In order to stop the service:
// Swift
MobileMessaging.geofencingService.stop()
// Objective-C
[[MobileMessaging geofencingService] stop];
In order to be notified about the region entered event you can subscribe to MMNotificationGeographicalRegionDidEnter
:
//Swift
NotificationCenter.default.addObserver(self,
selector: #selector(self.geographicalRegionEntered(_:)),
name: NSNotification.Name(rawValue: MMNotificationGeographicalRegionDidEnter),
object: nil)
// Objective-C
[[NSNotificationCenter defaultCenter] addObserver: self
selector: @selector(geographicalRegionEntered:)
name: MMNotificationGeographicalRegionDidEnter
object: nil];
The NSNotification
object will contain the information about the region:
// Swift
@objc func geographicalRegionEntered(_ notification: NSNotification) {
guard let region = notification.userInfo?[MMNotificationKeyGeographicalRegion] as? MMRegion else
{
return
}
print("Region entered: \(region)")
print("Message text: \(region.message?.text)")
<# handle the event the way you like #>
}
// Objective-C
-(void)geographicalRegionEntered:(NSNotification *)notification {
MMRegion * region = notification.userInfo[MMNotificationKeyGeographicalRegion];
NSLog(@"Region entered: %@", region);
NSLog(@"Message text: %@", region.message.text);
<# handle the event the way you like #>
}
If you have any questions or suggestions, feel free to send an email to [email protected] or create an issue.
- Library events
- Server errors
- Users and installations
- Messages and notifications management
- Inbox
Geofencing serviceDEPRECATED- Privacy settings
- In-app chat
- WebRTC Calls and UI