All notable changes to this project are documented in this file.
This project adheres to Semantic Versioning.
We have begun rewriting the iOS SDK in Swift in order to modernize the code base. Please monitor the changelog for updates to existing interfaces but keep in mind that some interfaces will be unstable during this process. As such, updating to a minor version may introduce compilation issues related to language interoperability. Please bear with us as we work towards providing an improved experience for integrating with the Facebook platform. |
- Added AEM Auto Setup
- The enum
AppLinkNavigation.Type
type has been renamed tpAppLinkNavigationType
. - The initializer
init(appLink:extras:appLinkData:settings:)
inAppLinkNavigation
ignores thesettings
argument if one is passed. - The method
navigation(with:extras:appLinkData:settings:)
inAppLinkNavigation
ignores thesettings
argument if one is passed.
- The
navigation(with:extras:appLinkData:settings:)
method inAppLinkNavigation
is deprecated in favor of theinit(appLink:extras:appLinkData:)
designated init. - The
init(appLink:extras:appLinkData:settings:)
initializer inAppLinkNavigation
is deprecated in favor of theinit(appLink:extras:appLinkData:)
designated init. - The
Profile.enableUpdatesOnAccessTokenChange(_:)
method is deprecated in favor of theProfile.isUpdatedWithAccessTokenChange
property. SettingsProtocol.codelessDebugLogEnabled
is deprecated in favor ofSettingsProtocol.isCodelessDebugLogEnabled
.SettingsProtocol.advertiserIDCollectionEnabled
is deprecated in favor ofSettingsProtocol.isAdvertiserIDCollectionEnabled
.SettingsProtocol.advertiserTrackingEnabled
is deprecated in favor ofSettingsProtocol.isAdvertiserTrackingEnabled
.SettingsProtocol.graphAPIDebugParamValue
is deprecated in favor of its new nameSettingsProtocol.graphAPIDebugParameterValue
Settings.autoLogAppEventsEnabled
is deprecated in favor ofSettings.isAutoLogAppEventsEnabled
.
SettingsProtocol.graphAPIDebugParamValue
has been renamed toSettingsProtocol.graphAPIDebugParameterValue
Profile
conformance toNSCopying
has been removed as well as custom hashability and equatability.
- The documentation for the property list-backed value
Settings.isCodelessDebugLogEnabled
has been corrected to indicate that the default value isfalse
.
- The minimum supported version of iOS and tvOS is now 12.0.
- Support for tvOS is now deprecated and will be removed in Version 16.
- Support for bitcode. Bitcode is no longer needed or supported by Apple as of Xcode 14 - https://developer.apple.com/documentation/xcode-release-notes/xcode-14-release-notes
- Binary artifact sizes are now smaller.
- Fixed GitHub Issue #2082.
- Added server-side AEM rule matching
- Removed deprecated
AEMReporter.configure(networker:appID:)
method. - Removed deprecated
ContextDialogPresenter.showCreateContextDialog(withContent:delegate:)
method. - Removed deprecated
ContextDialogPresenter.showSwitchContextDialog(withContent:delegate:)
method. - Removed deprecated
ContextDialogPresenter.showChooseContextDialog(withContent:delegate:)
method. - Removed deprecated
ContextDialogPresenter.showChooseContextDialog(with:delegate:)
method. - Removed deprecated
ContextDialogPresenter.createContextDialog(withContent:delegate:)
method. - Removed deprecated
ContextDialogPresenter.switchContextDialog(withContent:delegate:)
method. - Removed deprecated
SwitchContextDialog.dialog(content:windowFinder:delegate:)
method. - Removed deprecated
LoginConfiguration.authType(for:)
method. - Removed internal
AuthenticationTokenSettings
protocol.
- Made
LoginManagerLoginResult.token
immutable. - Made
LoginManagerLoginResult.authenticationToken
immutable. - Made
LoginManagerLoginResult.isCancelled
immutable. - Made
LoginManagerLoginResult.grantedPermissions
immutable. - Made
LoginManagerLoginResult.declinedPermissions
immutable. - Made
AccessToken.currentAccessToken
use a Swift name ofcurrent
. - Made
AuthenticationToken.currentAuthenticationToken
use a Swift name ofcurrent
. - Renamed
SharingValidation
protocol toSharingValidatable
. - Corrected type definition for
FBSDKUserIdentifier
to beNSString *
instead ofNSString
for Swift compatibility.
- Fixed an issue in native sharing where hashtags are not automatically added to a post.
The minimum supported version of iOS is now 11.0 for all frameworks. The minimum supported version of tvOS is now 11.0 for all frameworks. The XCFramework binaries are now built with Xcode 13 so Xcode 12 is no longer supported.
Starting with the v13.0 release, client tokens must be included in apps for Graph API calls. An exception is now raised when running apps without a client token. See the instructions for more information.
A number of types have been converted from Objective-C to Swift. As a consequence, developers may need to use modular import statements when using GamingServicesKit and a majority of ShareKit in order to avoid encountering compilation errors in Objective-C.
// When importing a framework in this form:
#import <FBSDKShareKit/FBSDKShareKit.h>
// You may be need to update to this form when unknown symbol warnings appear:
@import FBSDKShareKit;
We have further reduced the use of Objective-C value-type practices in ShareKit. ShareKit content types will no longer implement the following behaviors:
- conformance to the
NSCopying
protocol - custom hashability and equatability
- conformance to
NSSecureCoding
More app event reporting interfaces now use formal app event names and parameter names. Developers working in Swift code are required to use AppEvents.Name
and AppEvents.ParameterName
instances to represent app event names and app event parameter names, respectively.
The example below works without changes in Objective-C:
NSDictionary<NSString *, id> *parameters = @{
FBSDKAppEventParameterNameNumItems: @5,
@"custom_parameter": @"special info"
};
[FBSDKAppEvents logEvent:FBSDKAppEventNamePurchased
parameters:parameters];
This next example is how it would look in Swift for an updated API:
let parameters: [AppEvents.ParameterName: Any] = [
.numItems: 5,
.init("custom_parameter"): "special info"
]
AppEvents.logEvent(.purchased, parameters: parameters)
- Renamed
frictionlessRequestsEnabled
property onGameRequestDialog
in Objective-C; useisFrictionlessRequestsEnabled
andsetIsFrictionlessRequestsEnabled:
instead. - Corrected nullability of
contentURL
in protocolSharingContent
- Renamed
AppInviteDestination
toAppInviteContent.Destination
- Renamed
userGenerated
property onSharePhoto
in Objective-C; useisUserGenerated
andsetIsUserGenerated:
instead.
- Deprecated the
FacebookGamingServices
CocoaPod; please use theFBSDKGamingServicesKit
pod instead. SPM users should continue to useFacebookGamingServices
.
A few types have been moved from FBSDKShareKit to FBSDKGamingServicesKit. If you were using any of these you will have to add @import FBSDKGamingServicesKit
in order to access these:
- GameRequestActionType
- GameRequestContent
- GameRequestDialog
- GameRequestDialogDelegate
- GameRequestFilter
- GameRequestFrictionlessRecipientCache
- GameRequestURLProvider
- Removed
NSObjectProtocol
conformance/inheritance from multiple types in ShareKit. - Removed deprecated
SDKError
type;ErrorFactory
and/orNetworkErrorChecker
should be used instead. - Removed deprecated
ReferralCode
,ReferralManager
,ReferralManagerResult
and related classes. - Removed unused
AppGroupContent
class,AppGroupPrivacy
enum andNSStringFromFBSDKAppGroupPrivacy
function. - Removed
SharingScheme
protocol from ShareKit - Removed deprecated
logInWithURL:handler
fromLoginManager
- Removed deprecated
init
andnew
methods fromAppInviteContent
- Removed deprecated
AppLinkResolverRequestBuilder
- Removed deprecated URL schemes
.facebookApp
,.facebookShareExtension
and.masqueradePlayer
; use.facebookAPI
instead. - Removed deprecated
init
andnew
methods fromCrashHandler
- Removed
init
andnew
methods fromMessageDialog
; useinit(content:delegate:)
instead. - Removed deprecated
init
andnew
methods fromLogger
- Removed deprecated
init
andnew
methods fromFBSDKURLSession
- Removed
init
andnew
methods fromShareDialog
; useinit(viewController:content:delegate:)
instead. - Removed
init
andnew
fromShareCameraEffectContent
; useinit(effectID:contentURL:)
instead. - Removed deprecated
init(appLink:extras:appLinkData:)
fromAppLinkNavigation
; useinit(appLink:extras:appLinkData:settings:)
instead". - Removed class-based factory methods for
SharePhoto
:+photoWithImage:userGenerated:
,+photoWithImageURL:userGenerated:
,+photoWithPhotoAsset:userGenerated:
. Also removedinit
andnew
; use the new convenience initializers instead. - Removed class-based factory methods for
ShareVideo
:+videoWithData:
,+videoWithData:previewPhoto:
,+videoWithVideoAsset:
,+videoWithVideoAsset:previewPhoto:
,+videoWithVideoURL:
,+videoWithVideoURL:previewPhoto:
. Also removedinit
andnew
; use the new convenience initializers instead. - Removed
videoURL
property fromPHAsset
. - Removed
isEqualToHashtag:
andhashtagWithString:
methods from Hashtag. UseisEqual:
andinitWithString:
instead.
Use AppEvents.shared
in places where AppEvents
was used before. (Many class methods and properties in AppEvents have been deprecated in favor of their instance-based equivalents.)
- Removed deprecated
AppEvents.flushBehavior
(useAppEvents.shared.flushBehavior
instead) - Removed deprecated
AppEvents.loggingOverrideAppID
(useAppEvents.shared.loggingOverrideAppID
instead) - Removed deprecated
AppEvents.userID
(useAppEvents.shared.userID
instead) - Removed deprecated
AppEvents.anonymousID
(useAppEvents.shared.anonymousID
instead) - Removed deprecated
AppEvents.logEvent(_:)
(useAppEvents.shared.logEvent(_:)
instead) - Removed deprecated
AppEvents.logEvent(_:valueToSum:)
(useAppEvents.shared.logEvent(_:valueToSum:)
instead) - Removed deprecated
AppEvents.logEvent(_:parameters:)
(useAppEvents.shared.logEvent(_:parameters:)
instead) - Removed deprecated
AppEvents.logEvent(_:valueToSum:parameters:)
(useAppEvents.shared.logEvent(_:valueToSum:parameters:)
instead) - Removed deprecated
AppEvents.logEvent(_:valueToSum:parameters:accessToken:)
(useAppEvents.shared.logEvent(_:valueToSum:parameters:accessToken:)
instead) - Removed deprecated
AppEvents.logPurchase(_:currency:)
(useAppEvents.shared.logPurchase(amount:currency:)
instead) - Removed deprecated
AppEvents.logPurchase(_:currency:parameters:)
(useAppEvents.shared.logPurchase(amount:currency:parameters:)
instead) - Removed deprecated
AppEvents.logPurchase(_:currency:parameters:accessToken:)
(useAppEvents.shared.logPurchase(amount:currency:parameters:accessToken:)
instead) - Removed deprecated
AppEvents.logPushNotificationOpen(_:)
(useAppEvents.shared.logPushNotificationOpen(payload:)
instead) - Removed deprecated
AppEvents.logPushNotificationOpen(_:action:)
(useAppEvents.shared.logPushNotificationOpen(payload:action:)
instead) - Removed deprecated
AppEvents.logProductItem(_:availability:condition:description:imageLink:link:title:priceAmount:currency:gtin:mpn:brand:parameters:)
(useAppEvents.shared.logProductItem(id:availability:condition:description:imageLink:link:title:priceAmount:currency:gtin:mpn:brand:parameters:)
instead) - Removed deprecated
AppEvents.setPushNotificationsDeviceToken(_:)
(useAppEvents.shared.setPushNotificationsDeviceToken(_:)
instead) - Removed deprecated
AppEvents.setPushNotificationsDeviceToken(_:)
(useAppEvents.shared.setPushNotificationsDeviceToken(_:)
instead) - Removed deprecated
AppEvents.flush()
(useAppEvents.shared.flush()
instead) - Removed deprecated
AppEvents.requestForCustomAudienceThirdPartyID(with:)
(useAppEvents.shared.requestForCustomAudienceThirdPartyID(accessToken:)
instead) - Removed deprecated
AppEvents.clearUserID
is deprecated and will be removed in the next major release, please setAppEvents.shared.userID
tonil
instead) - Removed deprecated
AppEvents.augmentHybridWKWebView(_:)
(useAppEvents.shared.augmentHybridWebView(_:)
instead) - Removed deprecated
AppEvents.setIsUnityInit(_:)
(useAppEvents.shared.setIsUnityInitialized(_:)
instead) - Removed deprecated
AppEvents.sendEventBindingsToUnity()
(useAppEvents.shared.sendEventBindingsToUnity()
instead) - Removed deprecated
AppEvents.setUser(email:firstName:lastName:phone:dateOfBirth:gender:city:state:zip:country:)
(useAppEvents.shared.setUser(email:firstName:lastName:phone:dateOfBirth:gender:city:state:zip:country:)
instead) - Removed deprecated
AppEvents.clearUserData()
(useAppEvents.shared.clearUserData()
instead) - Removed deprecated
AppEvents.getUserData()
(useAppEvents.shared.getUserData()
instead) - Removed deprecated
AppEvents.setUserData(_:forType:)
(useAppEvents.shared.setUserData(_:forType:)
instead) - Removed deprecated
AppEvents.clearUserDataForType(_:)
(useAppEvents.shared.clearUserDataForType(_:)
instead)
Use Settings.shared
in places where Settings
was used before. (Many class methods and properties in FBSDKSettings have been deprecated in favor of their instance-based equivalents.)
- Removed deprecated
Settings.sdkVersion
(useSettings.shared.sdkVersion
instead") - Removed deprecated
Settings.defaultGraphAPIVersion
(useSettings.shared.defaultGraphAPIVersion
instead") - Removed deprecated
Settings.JPEGCompressionQuality
(useSettings.shared.JPEGCompressionQuality
instead") - Removed deprecated
Settings.isAutoLogAppEventsEnabled
(useSettings.shared.isAutoLogAppEventsEnabled
instead") - Removed deprecated
Settings.isCodelessDebugLogEnabled
(useSettings.shared.isCodelessDebugLogEnabled
instead") - Removed deprecated
Settings.isAdvertiserIDCollectionEnabled
(useSettings.shared.isAdvertiserIDCollectionEnabled
instead") - Removed deprecated
Settings.isSKAdNetworkReportEnabled
(useSettings.shared.isSKAdNetworkReportEnabled
instead") - Removed deprecated
Settings.shouldLimitEventAndDataUsage
(useSettings.shared.isEventDataUsageLimited
instead") - Removed deprecated
Settings.shouldUseCachedValuesForExpensiveMetadata
(useSettings.shared.shouldUseCachedValuesForExpensiveMetadata
instead") - Removed deprecated
Settings.isGraphErrorRecoveryEnabled
(useSettings.shared.isGraphErrorRecoveryEnabled
instead") - Removed deprecated
Settings.appID
(useSettings.shared.appID
instead") - Removed deprecated
Settings.appURLSchemeSuffix
(useSettings.shared.appURLSchemeSuffix
instead") - Removed deprecated
Settings.clientToken
(useSettings.shared.clientToken
instead") - Removed deprecated
Settings.displayName
(useSettings.shared.displayName
instead") - Removed deprecated
Settings.facebookDomainPart
(useSettings.shared.facebookDomainPart
instead") - Removed deprecated
Settings.loggingBehaviors
(useSettings.shared.loggingBehaviors
instead") - Removed deprecated
Settings.graphAPIVersion
(use theSettings.shared.graphAPIVersion
property instead") - Removed deprecated
Settings.isAdvertiserTrackingEnabled()
(use theSettings.shared.isAdvertiserTrackingEnabled
property instead") - Removed deprecated
Settings.setAdvertiserTrackingEnabled(_:)
(use theSettings.shared.isAdvertiserTrackingEnabled
property to set a value instead") - Removed deprecated
Settings.setDataProcessingOptions(_:)
(use theSettings.shared.setDataProcessingOptions(_:)
method to set the data processing options instead") - Removed deprecated
Settings.setDataProcessingOptions(_:_:_:)
(use theSettings.shared.setDataProcessingOptions(_:_:_:)
method to set the data processing options instead") - Removed deprecated
Settings.enableLoggingBehavior()
(useSettings.shared.enableLoggingBehavior()
instead") - Removed deprecated
Settings.disableLoggingBehavior()
(useSettings.shared.disableLoggingBehavior()
instead")
This release contains various fixes for FBAEMKit
- Fetched AEM config after AEM URL is received
- Added delay between AEM conversion requests
- Moved Catalog Matching logic behind GK
- Fixed missing
defaultComponents
accessor forCoreKitComponents
. Fixes issue #2010.
- Added network error checking protocol (
NetworkErrorChecking
) and concrete implementation (NetworkErrorChecker
) - Added error factory protocol (
ErrorCreating
) and concrete implementation (ErrorFactory
)
- Removed
configureWithWebViewProvider:urlOpener:
fromFBSDKWebDialogView
SDKError
has been deprecated in favor of the newErrorFactory
andNetworkErrorChecker
typesNSStringFromFBSDKShareDialogMode()
has been deprecated in favor ofShareDialog.Mode.description
- Duplicate symbol error when using Swift Package Manager with the
ObjC
linker flag (issue #1972) - Issue using SPM for tvOS projects (issue #1936)
- Fixed regression in sizes for FacebookGamingServices-Static_XCFramework.zip and FacebookSDK-Static_XCFramework.zip
- Potential fix for [FBSDKAppEventsDeviceInfo encodedDeviceInfo] crash (issue #1961)
Note: There is a known issue with using the ObjC
linker flag with this version. We are working on a patch fix. If you rely on the ObjC
linker flag, you will want to wait for the patch fix before upgrading.
- Starting with v12.2.0 apps no longer need to embed numerous custom URL schemes in
LSApplicationQueriesSchemes
for theirInfo.plist
. Only thefbapi
andfb-messenger-share-api
custom URL schemes are needed. With the change to iOS 15 that limitsLSApplicationQueriesSchemes
to 50 schemes, this should relieve some pressure that apps may face when running up against this limit. As part of this change the following symbols are deprecated:URLScheme.facebookApp
URLScheme.facebookShareExtension
URLScheme.masqueradePlayer
- Fixed NSKeyedUnarchiver validateAllowedClass Warnings in Xcode Console. Fixes #1941 and #1930
- An implementation bug in
ApplicationDelegate
where added application observers were notified twice forapplication:didFinishLaunchingWithOptions:
. The return type ofApplicationDelegate.application:didFinishLaunchingWithOptions:
was also incorrectly stated as, "YES if the url was intended for the Facebook SDK, NO if not". In actuality, the method returns whether there are any application observers that themselves return true from calling their implementation ofapplication:didFinishLaunchingWithOptions:
. This fix means that application observers will now only be notified once per app launch, however, ifApplicationDelegate.application:didFinishLaunchingWithOptions:
is called after callingApplicationDelegate.initializeSDK
then the return type will always be false regardless of any application observers. - Using share dialogs via share sheet mode fails to show the dialog (Issue #1938)
- Fixed: aem_conversion_configs should contain an explicit "fields" parameter (Issue #1933)
- The class-based interface of
AppEvents
has been deprecated. Please use the instance properties and methods onAppEvents.shared
instead.
- When using SPM, FacebookAEM and FacebookBasics no longer have to be explicitly included
- FBSDKShareDialog show does nothing the first time (Issue #1919)
- Unable to archive app for distribution using Xcode 12.5.1 and Swift Package Manager (Issue #1917)
- iOS 15: NSKeyedUnarchiver warning (Issued #1887)
- The aggregate FacebookSDK pod is deprecated. Please use one of the individual pods instead (i.e. FBSDKCoreKit, FBSDKShareKit, FBSDKLoginKit, etc.)
FBSDKReferralCode
,FBSDKReferralManager
andFBSDKReferralManagerResult
are deprecated and will be removed in v13.0.0
- Updated release to be built with Xcode 12 for backwards compatibility with Xcode 12
Note: Binaries for v12.0.1 were built with Xcode 13 and will not work with Xcode 12. See #1911. Use release v12.0.2 instead.
- Fixed: Share Dialog not presenting for SDK 12.0.0 including for the FacebookShareSample app #1909
Starting with version 12.0.0, CocoaPods and Swift Package Manager (SPM) are vending pre-built XCFrameworks. You no longer need to build the SDK when using CocoaPods or SPM, which should save you between a few seconds and a few minutes per build.
Because XCFrameworks do not allow embedded frameworks, note the following:
- When you install the SDK by using CocoaPods, the generated Pods project includes the dependencies for you.
- When you install the SDK by using SPM, you must add the dependencies yourself.
- You must include
FacebookAEM
andFacebookBasics
even though you won't use them directly.
- You must include
You can no longer build from source using Carthage. Instead use Carthage to obtain the pre-built XCFrameworks. For instructions, see: https://github.com/Carthage/Carthage#migrating-a-project-from-framework-bundles-to-xcframeworks.
For more details, see https://developers.facebook.com/docs/ios/getting-started.
🚨 IMPORTANT 🚨
Changes to FBSDKLoginButton
when defined in a Storyboard or XIB file: There is a known issue with using XCFrameworks in conjunction with Storyboard or XIB files. If you do not follow the instructions for using Interface Builder at https://developers.facebook.com/docs/facebook-login/ios/advanced/, FBSDKLoginButton
does not load or decorate correctly. Add [FBSDKLoginButton class]
to application:didFinishLaunchingWithOptions:
so that the Storyboard can find it. If you don't, any methods that you call on it may result in a runtime crash.
- The minimum supported version of iOS is now 10.0.
- Formalized the shared instance of
AppEvents
(given the property nameshared
) to start moving away from a class-based interface. FacebookGamingServices
andFBSDKGamingServicesKit
— There are two libraries related to Gaming Services.FBSDKGamingServicesKit
is a superset ofFacebookGamingServices
that includes Objective-C wrapper classes forFBSDKContextDialogPresenter
andFBSDKContextDialogPresenter
. If you don't need an Objective-C interface for these types, we recommend that you use onlyFacebookGamingServices
.- Nullability annotations are added to some types. If you are using Swift (and in some cases Objective-C) and you use a newly annotated type, see the warnings in Xcode for more information.
The following table contains changes to the iOS SDK in version 12.0.0.
Removed or Changed | Version 12.0.0 Replacement or Change |
---|---|
AccessToken convenience initializers that include graphDomain |
— |
AccessToken.graphDomain class property. |
AccessToken.graphDomain instance property. |
AccessToken.refreshCurrentAccessToken(completionHandler:) |
AccessToken.refreshCurrentAccessToken(completion:) |
AppEvents.activateApp class method. |
AppEvents.activateApp instance method that you access on the AppEvents.shared instance. |
FBSDKGraphErrorRecoveryProcessor - you can no longer create new instances without using designated initializers. |
— |
GamingContext.type |
— |
GamingImageUploader.uploadImage(configuration:andResultCompletionHandler:) |
GamingImageUploader.uploadImage(configuration:andResultCompletion:) |
GamingImageUploader.uploadImage(configuration:completionHandler:andProgressHandler:) |
GamingImageUploader.uploadImage(configuration:completion:andProgressHandler:) |
GamingPayload.gameRequestID |
You can obtain the game request ID from GamingPayloadDelegate.parsedGameRequestURLContaining(_:gameRequestID:) |
GamingPayloadDelegate.updatedURLContaining(_:) |
GamingPayloadDelegate.parsedGameRequestURLContaining(_:gameRequestID:) |
GamingPayloadObserver.shared |
You must now create instances of this object by using a delegate. |
GamingServiceResultCompletionHandler |
GamingServiceResultCompletion |
GamingVideoUploader.uploadVideo(configuration:andResultCompletionHandler:) |
GamingVideoUploader.uploadVideo(configuration:andResultCompletion:) |
GamingVideoUploader.uploadVideo(configuration:completionHandler:andProgressHandler:) |
GamingVideoUploader.uploadVideo(configuration:completion:andProgressHandler:) |
GraphRequest.start(completionHandler:) |
GraphRequest.start(completion:) |
GraphRequestBlock |
GraphRequestCompletion |
GraphRequestConnection.add(_:completionHandler:) |
GraphRequestConnection.add(_:completion:) |
GraphRequestConnection.add(_:batchEntryName:completionHandler:) |
GraphRequestConnection.add(_:name:completion:) |
GraphRequestConnection.add(_:batchParameters:completionHandler:) |
GraphRequestConnection.add(_:parameters:completion:) |
- Fixed the App AEM Advertiser Rule match for fb_content
- Fixed: 'FBSDKCoreKitImport.h' file not found. (Issue #1829)
- Added AEM Deeplink handling debugging support
- Support for building with Xcode 13 beta 4 due to change in optionality for NS_EXTENSION_UNAVAILABLE. More information in the Xcode release notes and in issue #1799. Resolved by @S2Ler in #1768
- Reintroduces
initializeSDK
method toFBSDKApplicationDelegate
- Introduced Xcodegen for generating project files. Moving forward, We will now use Xcodegen to generate the project files that are used to build the SDK releases. There should be no impact to SDK users. However, some build settings were restored to Xcode defaults as a result of this change, and output binaries may be affected in unpredictable ways. Contributors to the SDK should run the new, top-level script
generate-projects.sh
to ensure that the project files they are using are the same as those being used in CI and for releases. The next major version will remove the project files from version control. If you experience any of these issues, please open an issue and we will look into it.
- Building the frameworks using Carthage. Carthage is a dependency manager that typically works by building a third party framework using Xcode schemes shared from a
.xcodeproj
file. We are planning to remove the.xcodeproj
files in the next major release as they will be generated on an as needed basis using Xcodegen. There is a strong likelihood that this change will break several integrations that use Carthage. You will still be able to use Carthage by pulling the pre-built binaries or XCFrameworks directly from the release. If this does not work for your use case, we recommend checking out Swift Package Manager as an alternative. - FBSDKGamingServicesKit's
GamingServiceResultCompletionHandler
. Replaced byGamingServiceResultCompletion
which passes a dictionary instead of a string for the result. Additionally the following methods have been updated:uploadImageWithConfiguration:andResultCompletionHandler
is replaced byuploadImageWithConfiguration:andResultCompletion
uploadImageWithConfiguration:completionHandler:andProgressHandler
is replaced byuploadImageWithConfiguration:completion:andProgressHandler:
uploadVideoWithConfiguration:completionHandler:andProgressHandler:
is replaced byuploadVideoWithConfiguration:completion:andProgressHandler:
uploadVideoWithConfiguration:andResultCompletionHandler
is replaced byuploadVideoWithConfiguration:andResultCompletion
FBSDKGamingPayloadObserver
'sshared
instance. Going forward a user should create and retain their own instance of a payload observer for as long as they'd like to receive callbacks from its delegate.
- Initializing the SDK in when UIApplication is unavailable #1748
- Issue caused by
initializeSDK
deprecation #1731
- Add background refresh status logging
- No longer automatically showing UI for GraphErrorRecoveryProcessor
ATTENTION: The Platform SDK v11.0 release introduces a few key changes to how dependencies will be managed moving forward. These changes are being implemented to drive more efficiency in our development process and reduce an over-reliance on singletons and tight coupling.. As part of these changes, we are currently in the process of converting existing types to use injected dependencies. As a result, many types will no longer be usable until the SDK is initialized. In order to ensure that types are configured correctly before being used, you will need to call FBSDKApplicationDelegate.application:didFinishLaunchingWithOptions:
first before attempting to (i) get or set any properties, or (ii) invoke any methods on the SDK.
The source code has been updated to include reminders in the form of exceptions in DEBUG
builds across several locations. These reminders will serve as pointers for Developers to call FBSDKApplicationDelegate.application:didFinishLaunchingWithOptions:
before using the SDK. For more information see: facebook#1763.
- Login with Facebook iOS app now populates a shared
AuthenticationToken
instance. - Added Limited Login support for
user_hometown
,user_location
,user_gender
anduser_link
permissions under public beta. - Updated Profile on Limited Login to include first, middle and last name as separate fields.
- Released
user_messenger_contact
permission to enable Login Connect with Messenger. This new feature allows people to opt in to being contacted by a business on Messenger following the FB Login flow. - Added ability to add
messenger_page_id
param toFBSDKLoginButton
andFBSDKLoginConfiguration
- Added
FBSDKApplicationObserving
- a protocol for describing types that can optional respond to lifecycle events propagated byApplicationDelegate
- Added
addObserver:
andremoveObserver:
toFBSDKApplicationDelegate
- Added
startWithCompletion:
toFBSDKGraphRequest
. ReplacesstartWithCompletionHandler:
- Added
addRequest:completion
toFBSDKGraphRequestConnection
. ReplacesaddRequest:completionHandler:
. - Added
addRequest:name:completion:
toFBSDKGraphRequestConnection
. ReplacesaddRequest:batchEntryName:completionHandler:
. - Added
addRequest:parameters:completion:
toFBSDKGraphRequestConnection
. ReplacesaddRequest:batchParameters:completionHandler:
. - Added instance method
activateApp
toAppEvents
.
FBSDKGraphRequestBlock
. Replaced byFBSDKGraphRequestCompletion
which returns an abstractFBSDKGraphRequestConnection
in the formid<FBSDKGraphRequestConnecting>
(ObjC) orGraphRequestConnecting
(Swift)FBSDKGraphRequest
'sstartWithCompletionHandler:
replaced bystartWithCompletion:
FBSDKGraphRequestConnection
'saddRequest:completionHandler:
replaced byaddRequest:completion:
FBSDKGraphRequestConnection
'saddRequest:batchEntryName:completionHandler:
replaced byaddRequest:name:completion:
FBSDKGraphRequestConnection
'saddRequest:batchParameters:completionHandler:
replaced byaddRequest:parameters:completion:
FBSDKGraphRequestBlock
- Class method
AppEvents.activateApp
. It is replaced by an instance method of the same name.
FBSDKApplicationDelegate.initializeSDK:launchOptions:
. The replacement method isFBSDKApplicationDelegate.application:didFinishLaunchingWithOptions:
FBSDKAppEvents
'updateUserProperties:handler:
method.FBSDKAppEvents
'supdateUserProperties:handler:
method.FBSDKAppLinkReturnToRefererControllerDelegate
FBSDKAppLinkReturnToRefererController
FBSDKIncludeStatusBarInSize
FBSDKAppLinkReturnToRefererViewDelegate
FBAppLinkReturnToRefererView
FBSDKErrorRecoveryAttempting
'sattemptRecoveryFromError:optionIndex:delegate:didRecoverSelector:contextInfo:
FBSDKProfile
'sinitWithUserID:firstName:middleName:lastName:name:linkURL:refreshDate:imageURL:email:
FBSDKProfile
'sinitWithUserID:firstName:middleName:lastName:name:linkURL:refreshDate:imageURL:email:friendIDs:birthday:ageRange:isLimited:
FBSDKProfile
'sinitWithUserID:firstName:middleName:lastName:name:linkURL:refreshDate:imageURL:email:friendIDs:
FBSDKProfile
'sinitWithUserID:firstName:middleName:lastName:name:linkURL:refreshDate:imageURL:email:friendIDs:birthday:ageRange:
FBSDKAccessTokensBlock
FBSDKTestUsersManager
FBSDKGraphErrorRecoveryProcessor
'sdelegate
propertyFBSDKGraphErrorRecoveryProcessor
'sdidPresentErrorWithRecovery:contextInfo:
FBSDKGamingVideoUploader
'suploadVideoWithConfiguration:andCompletionHandler:
FBSDKGamingImageUploader
'suploadImageWithConfiguration:andCompletionHandler:
NOT RELEASED
Reason: The SDK is primarily a means of interacting with the Graph API. The decision was made to skip this version in order to maintain major version parity. Since Graph API is on v11, it did not make sense to release a v10 then immediately release a v11.
Performance Improvements
- Cocoapods: FBSDKCoreKit rebuilds FacebookSDKStrings.bundle so xcode processes the strings files into binary plist format. This strips comments and saves ~181KB in disk space for apps. #1713
- Added AEM (Aggregated Events Measurement) support under public beta.
- Added
external_id
support in advanced matching. GamingServicesKit
changed the Game Request feature flow where if the user has the facebook app installed, they will not see a webview to complete a game request. Instead they will switch to the facebook app and app switch back once the request is sent or the user cancels the dialog.
- Fix for shadowing swift type. #1721
- Optimization for cached token fetching. See the commit message for more details.
- Cocoapods with generate_multiple_pod_projects #1709
- Added Limited Login support for
user_friends
,user_birthday
anduser_age_range
permissions under public beta. - Shared Profile instance will be populated with
birthday
andageRange
fields using the claims from theAuthenticationToken
. (NOTE: birthday and ageRange fields are in public beta mode) - Added a convenience initializer to
Profile
as part of fixing a bug where upgrading from limited to regular login would fail to fetch the profile using the newly available access token. GamingServicesKit
added an observer class where if developers set the delegate we will trigger the delegate method with aGamingPayload
object if any urls contain gaming payload data. (NOTE: This feature is currently under development)
Performance Improvements
- Added in memory cache for carrier and timezone so they are not dynamically loaded on every
didBecomeActive
- Added cached
ASIdentifierManager
to avoid dynamic loading on everydidBecomeActive
- Backgrounds the expensive property creation that happens during AppEvents class initialization.
- Added thread safety for incrementing the serial number used by the logging utility.
- Added early return to Access Token to avoid unnecessary writes to keychain which can cause performance issues.
Bug Fixes
- Fixed using CocoaPods with the
generate_multiple_pod_projects
flag. #1707 - Adhere to flush behavior for logging completion. Will now only flush events if the flush behavior is
explicitOnly
. - Static library binaries are built with
BITCODE_GENERATION_MODE = bitcode
to fix errors where Xcode is unable to build apps with bitcode enabled. #1698
TestUsersManager
. The APIs that back this convenience type still exist but there is no compelling reason to have this be part of the core SDK. See the commit message for more on the rationale.
- Internal type
AudioResourceLoader
.
friendIDs
property added toFBSDKProfile
(NOTE: We are building out thefriendIDs
property in Limited Login with the intention to roll it out in early spring)FBSDKProfile
initializer that includes optionalfriendIDs
argumentclaims
property of typeFBSDKAuthenticationTokenClaims
added toFBSDKAuthenticationToken
- Build Warnings for SPM with Xcode 12.5 Beta 2 #1661
- Memory leak in
FBSDKGraphErrorRecoveryProcessor
- Name conflict for Swift version of
FBSDKURLSessionTask
- Avoids call to
AppEvents
singleton when setting overriding app ID #1647 - CocoaPods now compiles
FBSDKDynamicFrameworkLoader
with ARC. - CocoaPods now uses static frameworks as the prebuilt libraries for the aggregate FacebookSDK podspec
- App Events use the correct token if none have been provided manually (@ptxmac#1670
FBSDKGraphErrorRecoveryProcessor
'sdelegate
propertyFBSDKGraphErrorRecoveryProcessor
'sdidPresentErrorWithRecovery:contextInfo:
methodFBSDKAppLinkReturnToRefererView
FBSDKAppLinkReturnToRefererController
- Internal type
FBSDKErrorRecoveryAttempter
- Add control support for the key FacebookSKAdNetworkReportEnabled in the info.plist
- Add APIs to control SKAdNetwork Report
- Fix deadlock issue between SKAdNetwork Report and AAM/Codeless
- Fix default ATE sync for the first app launch
- Fix build error caused by LoginButton nonce property (@kmcbride in #1616)
- Fix crash on FBSDKWebViewAppLinkResolverWebViewDelegate (@Kry256 in #1624)
- Fix XCFrameworks build issue (#1628)
- Fix deadlock when AppEvents ActivateApp is called without initializing the SDK (#1636)
We have a number of exciting changes in this release! For more information on the v9 release please read our associated blog post!
- Swift Package Manager now supports Mac Catalyst
- Limited Login. Please read the blog post and docs for a general overview and implementation details.
- The default Graph API version is updated to v9.0
- The
linkURL
property ofFBSDKProfile
will only be populated if the user has granted theuser_link
permission. - FBSDKGamingServicesKit will no longer embed FBSDKCoreKit as a dependency. This may affect you if you are manually integrating pre-built binaries.
- The aggregate CocoaPod
FacebookSDK
now vendors XCFrameworks. Note: this may cause conflicts with other CocoaPods that have dependencies on the our libraries, ex: Audience Network. If you encounter a conflict it is easy to resolve by using one or more of the individual library pods instead of the aggregate pod.
- The
autoInitEnabled
option is removed from the SDK. From here on, developers are required to initialize the SDK explicitly with theinitializeSDK
method or implicitly by calling it inapplicationDidFinishLaunching
.
- Swift Package Manager Mac Catalyst support #1577
- Remove SignalHandler to avoid hiding root cause of crashes caused by fatal signals.
- Expose functions in
FBSDKUserDataStore
as public for apps using Audience Network SDK only to use advanced matching.
- Introduced
AppLinkResolverRequestBuilder
for use in cleaning up and adding tests aroundAppLinkResolver
- Removed version checks for iOS 9 since it’s the default version now.
- Refactored
AppLinkResolver
to use a request builder - Refactored and added tests around
FBSDKProfile
andFBSDKProfilePictureView
- Updated
FBSDKSettings
to useADIdentifierManager
for tracking status - Removes usages of deprecated
UI_USER_INTERFACE_IDIOM()
- Issues with Swift names causing warnings - #1522
- Fixes bugs related to crash handling - #1444
- Fixes Carthage distribution to include the correct binary slices when building on Xcode12 - #1484
- Fixes duplicate symbol for
FBSDKVideoUploader
bug #1512 - GET requests now default to having a 'fields' parameter to avoid warnings about missing fields #1403
- Fixes Multithreading issue related to crash reporting - #1550
- Added timestamp for install event in iOS 14
- Added method
setAdvertiserTrackingEnabled
to overwrite theadvertiser_tracking_enabled
flag - Added
SKAdNetwork
support for installs - Added
SKAdNetwork
support for conversion value in iOS 14 - Added
FBSDKReferralManager
for integrating with the web referral dialog - Added method
loginWithURL
toFBSDKLoginManager
for supporting deep link authentication - Added E2E tests for all in-market versions of the SDK that run on server changes to avoid regressions
- Event handling in iOS 14: will drop events if
setAdvertiserTrackingEnabled
is called withfalse
in iOS 14 FBSDKProfile - imageURLForPictureMode:size:
- User profile images will only be available when an access or client token is available
FBSDKSettings - isAutoInitEnabled
- Auto-initialization flag. Will be removed in the next major release. Future versions of the SDK will not utilize the+ load
method to automatically initialize the SDK.
- #1444 - Update crash handling to use sigaction in signal handler and respect SIG_IGN
- #1447 - Login form automatically closing when SDK is not initialized on startup
- #1478 - Minimum iOS deployment target is now 9.0
- #1485 - StoreKit is now added as a weak framework for CocoaPods
- Bug fix for Advanced Matching, which was not working on iOS 14
- Fix data processing options issue
- Introduce DataProcessingOptions
- Remove UserProperties API
🚨🚨🚨Attention! 🚨🚨🚨
This release fixes the ability to parse bad server configuration data. Please upgrade to at least this version to help avoid major outtages such as #1374 and #1427
- Added additional unit tests for FBSDKRestrictiveDataFilterManager
- Added integration test for building with xcodebuild
- Added safer implementation of
NSJSONSerialization
methods toFBSDKTypeUtility
and changed callsites - Added 'fuzz' testing class to test our network response parsing won't crash from bad/unexpected values
- Issue #1401
- Issue #1380
- Previously, we could not remove AAM data if we opt out some rules. Now, we align with Android AAM and add an internalUserData to save AAM data. And we only send back the data of enabled AAM rules.
- Fix a bug where we were not updating Event Deactivation or Restrictive Data Filtering if the
enable()
function was called after theupdate()
function - Restrictive data filtering bug where updating filters would exit early on an empty eventInfo parameter.
- Enabling bitcode by default; we used to disable bitcode globally and enable it for certain versions of iphoneos due to Xcode 6 issue, given we've dropped the support for Xcode 6, it's cleaner to enable bitcode by default.
- Now using
FBSDKTypeUtility
to provide type safety for Dictionaries and Arrays - Updates code so that
NSKeyedUnarchiver
method calls will continue to work no matter what the iOS deployment target is set to. - Skips sending back app events when there are no encoded events.
- MarketingKit
- Using version 7.0 of the Facebook Graph API
- Dropping support for Xcode versions below 11. This is in line with Apple's plans to disallow submission of Apps that do not include the iOS 13 SDK. This means that from v7.0 on, all SDK kits will be built using Xcode 11 and Swift 5.1.
- Include the enhanced Swift interfaces
This primarily matters for how you include CocoaPods
Distribution Channel | Old way | New Way |
---|---|---|
CocoaPods | pod 'FBSDKCoreKit/Swift' |
pod 'FBSDKCoreKit' |
Swift Package Manager | No change | No change |
Carthage | No change | No change |
- FBSDKMarketingKit
- Various bug fixes
- The Swift interface for SharingDelegate should not have a nullable error in the callback.
- Fixes issue with login callback during backgrounding.
- Minor fixes related to Integrity
- More usecase for Integrity is supported.
FBSDKMessageDialog now accepts FBSDKSharePhotoContent.
FBSDKGamingServicesKit/FBSDKGamingImageUploader.h
uploadImageWithConfiguration:andResultCompletionHandler:
uploadImageWithConfiguration:completionHandler:andProgressHandler:
FBSDKGamingServicesKit/FBSDKGamingVideoUploader.h
uploadVideoWithConfiguration:andResultCompletionHandler:
uploadVideoWithConfiguration:completionHandler:andProgressHandler:
FBSDKGamingServicesKit/FBSDKGamingImageUploader.h
uploadImageWithConfiguration:andCompletionHandler:
FBSDKGamingServicesKit/FBSDKGamingVideoUploader.h
uploadVideoWithConfiguration:andCompletionHandler:
Various bug fixes, CI improvements
- Support new event type for suggested events
- Support for Gaming Video Uploads
- Allow Gaming Image Uploader to accept a callback
- Messenger Sharing
- Uses API version 6.0 by default
FBSDKShareDialog
delegate callbacks on apps using iOS 13
- Facebook Messenger Template and OpenGraph Sharing
FBSDKMessengerActionButton
FBSDKShareMessengerGenericTemplateContent
FBSDKShareMessengerGenericTemplateElement
FBSDKShareMessengerMediaTemplateMediaType
FBSDKShareMessengerMediaTemplateContent
FBSDKShareMessengerOpenGraphMusicTemplateContent
FBSDKShareMessengerURLActionButton
FBSDKShareAPI
since it exists to make sharing of open graph objects easier. It also requires the deprecatedpublish_actions
permission which is deprecated.- Property
pageID
fromFBSDKSharingContent
since it only applies to sharing to Facebook Messenger FBSDKShareOpenGraphAction
FBSDKShareOpenGraphContent
FBSDKShareOpenGraphObject
FBSDKShareOpenGraphValueContainer
FBSDKSettings
propertyinstrumentEnabled
- Sharing of open graph objects. This is because the "publish_actions" permission is deprecated so we should not be providing helper methods that encourage its use. For more details see: https://developers.facebook.com/docs/sharing/opengraph
FBSDKAppEventNameSubscriptionHeartbeat
FBSDKLoginBehavior
Login flows no longer support logging in through the native application. This change reflects that.
- fix multi-thread issue for Crash Report
- fix write to file issue for Crash Report
- fix for CocoaPods (i.e. macro
FBSDKCOCOAPODS
) - fixes a bug in for sharing callbacks for apps using SceneDelegate
- SPM Support for tvOS
- fix for CocoaPods static libs (i.e. no
use-frameworks!
) - various bug fixes and unit test additions
- bug fix for address inferencer weights load
- Parameter deactivation
- Update ML model to support non-English input
- Updated suggested events
- Accelerate automatically linked for SPM installs 6c1a7e
- Fixes building for Unity 6a83270
- Updates build scripts, various bug fixes
- Launch event suggestions
- Various bugfixes with SPM implementation
- Support for Swift Package Manager
- Using Graph API version 5.0
- Launch automatic advanced matching: https://www.facebook.com/business/help/2445860982357574
- Nullability annotation in FBSDKCoreKit
- Various bug fixes
- Build scripts (for documentation and to support libraries that include Swift)
- Fixed FB Login for multi-window apps that created via Xcode 11
- Added support for generate_multiple_pod_projects for cocoapods 1.7.0
- Improved performance and stability of crash reporting
- Added user agent suffix for macOS
- Various bug fixes
- Replaced UIWebView with WKWebView as Apple will stop accepting submissions of apps that use UIWebView APIs
- Added support for Catalyst
- Various bug fixes
- Deprecated
+[FBSDKSettings isInstrumentEnabled]
, please use+[FBSDKSettings isAutoLogEnabled]
instead
- Fix Facebook Login for iOS 13 beta
- Various bug fixes
- Add handling for crash and error to make SDK more stable
- Graph API update to v4.0
- Fixed Facebook Login issues
- Fixed Facebook Login on iOS 13 beta
- Various bug fixes
- Various bug fixes
- Fixed a crash caused by sensitive data filtering
- Fixed FB Login for iOS 13
- Various bug fixes
- Various bug fixes
- support manual SDK initialization
- extend coverage of AutoLogAppEventsEnabled flag to all internal analytics events
- Typedefs for public Objective-C blocks
NS_DESIGNATED_INITIALIZER
for required initsNS_TYPED_EXTENSIBLE_ENUM
where made sensegetter
name for certain properties, like booleansNS_ASSUME_NONNULL_BEGIN
,NS_ASSUME_NONNULL_END
, and other nullability annotations- Generics for Arrays, Sets, and Dictionaries
NS_SWIFT_NAME
to remove theFBSDK
prefix where necessary (leftFB
prefix for UI elements)FBSDKLoginManager -logInWithPermissions:fromViewController:handler:
FBSDKLoginButton permissions
FBSDKDeviceLoginButton permissions
FBSDKDeviceLoginViewController permissions
- New
FBSDKAppEventName
values
- Using
instancetype
for inits - All
NSError **
translate to throws on Swift - Updated Xcode Projects and Schemes to most Valid Project settings
- Getter methods changed to
readonly
properties - Getter/Setter methods changed to
readwrite
properties - Dot notation for access to properties
- Collections/Dictionaries became non null when at all possible
- Class creation methods become Swift inits
- Used
NS_REFINED_FOR_SWIFT
where advisable
FBSDKLoginManager -logInWithReadPermissions:fromViewController:handler:
FBSDKLoginManager -logInWithWritePermissions:fromViewController:handler:
FBSDKLoginButton readPermissions
FBSDKLoginButton writePermissions
FBSDKDeviceLoginButton readPermissions
FBSDKDeviceLoginButton writePermissions
FBSDKDeviceLoginViewController readPermissions
FBSDKDeviceLoginViewController writePermissions
FBSDKUtility SHA256HashString
FBSDKUtility SHA256HashData
- Deprecated methods
- Deprecated classes
- Deprecated properties
- Made
init
andnew
unavailable where necessary - Used
NS_SWIFT_UNAVAILABLE
where necessary
- Various bug fixes
- Light-weight generics have been added for Arrays, Sets, and Dictionaries. Make sure you're passing in the proper types.
- Some methods used to have closures as arguments, but did not have them as the final argument. All these methods have been rearranged to have the closure as the final argument.
- Certain string values, like App Event Names and HTTP Method, have been made NSString typedef with the
NS_TYPED_EXTENSIBLE_ENUM
attribute. All your existing code should work just fine.
NS_SWIFT_NAME
was applied where applicable. Most of these changes Xcode can fix automatically.- The
FBSDK
prefix for UI elements has been replaced with the simplerFB
prefix. - The
FBSDK
prefix for all other types has been removed. FBSDKError
is nowCoreError
.
- The
NS_ERROR_ENUM
is used to handling errors now. For more details, view Apple's documentation on Handling Cocoa Errors in Swift.- Certain string values, like App Event Names and HTTP Method, have been made extensible structs with the
NS_TYPED_EXTENSIBLE_ENUM
attribute:FBSDKAppEventNamePurchased
->AppEvents.Name.purchased
"custom_app_event"
->AppEvents.Name("custom_app_event")
- Certain values have been annotated with
NS_REFINED_FOR_SWIFT
and can be customized via either:- The Facebook SDK in Swift (Beta)
- Implementing custom extensions
// Custom extensions
public extension AccessToken {
var permissions: Set<String> {
return Set(__permissions)
}
}
extension AppEvents.Name {
static let customAppEvent = AppEvents.Name("custom_app_event")
}
extension ShareDialog.Mode: CustomStringConvertible {
public var description: String {
return __NSStringFromFBSDKShareDialogMode(self)
}
}
// Later in code
let perms: Set<String> = AccessToken(...).permissions
let event: AppEvents.Name = .customAppEvent
let mode: ShareDialog.Mode = .native
let description: String = "\(mode)"
_inBackground
now indicates correct application state
- Add parameter
_inBackground
for app events
- Various bug fixes
- Support for Xcode 10.2
FBSDKLoginBehaviorNative
FBSDKLoginBehaviorSystemAccount
FBSDKLoginBehaviorWeb
[FBSDKLoginManager renewSystemCredentials]
- Various bug fixes
- Moved directory structure for better separation
- Various bug fixes
- Resolved issues with the release process
- Various bug fixes
- Resolved build failures with Carthage and Cocoapods
- Various bug fixes
- Various bug fixes
- Various bug fixes
2019-01-08 | Full Changelog | Facebook Developer Docs Changelog