All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
- 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