FBSDKAppLinkResolving.h 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. // Copyright (c) 2014-present, Facebook, Inc. All rights reserved.
  2. //
  3. // You are hereby granted a non-exclusive, worldwide, royalty-free license to use,
  4. // copy, modify, and distribute this software in source code or binary form for use
  5. // in connection with the web services and APIs provided by Facebook.
  6. //
  7. // As with any software that integrates with the Facebook platform, your use of
  8. // this software is subject to the Facebook Developer Principles and Policies
  9. // [http://developers.facebook.com/policy/]. This copyright notice shall be
  10. // included in all copies or substantial portions of the software.
  11. //
  12. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  13. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
  14. // FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
  15. // COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
  16. // IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  17. // CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  18. #import <Foundation/Foundation.h>
  19. NS_ASSUME_NONNULL_BEGIN
  20. @class FBSDKAppLink;
  21. /**
  22. Describes the callback for appLinkFromURLInBackground.
  23. @param appLink the FBSDKAppLink representing the deferred App Link
  24. @param error the error during the request, if any
  25. */
  26. typedef void (^FBSDKAppLinkFromURLHandler)(FBSDKAppLink * _Nullable appLink, NSError * _Nullable error);
  27. /**
  28. Describes the callback for appLinkFromURLInBackground.
  29. @param appLinks the FBSDKAppLinks representing the deferred App Links
  30. @param error the error during the request, if any
  31. */
  32. typedef void (^FBSDKAppLinksFromURLArrayHandler)(NSDictionary<NSURL *, FBSDKAppLink *> * appLinks,
  33. NSError * _Nullable error);
  34. /*!
  35. Implement this protocol to provide an alternate strategy for resolving
  36. App Links that may include pre-fetching, caching, or querying for App Link
  37. data from an index provided by a service provider.
  38. */
  39. @protocol FBSDKAppLinkResolving <NSObject>
  40. /**
  41. Asynchronously resolves App Link data for a given URL.
  42. @param url The URL to resolve into an App Link.
  43. @param handler The completion block that will return an App Link for the given URL.
  44. */
  45. - (void)appLinkFromURL:(NSURL *)url handler:(FBSDKAppLinkFromURLHandler)handler
  46. NS_EXTENSION_UNAVAILABLE_IOS("Not available in app extension");
  47. @end
  48. NS_ASSUME_NONNULL_END