// Copyright (c) 2014-present, Facebook, Inc. All rights reserved. // // You are hereby granted a non-exclusive, worldwide, royalty-free license to use, // copy, modify, and distribute this software in source code or binary form for use // in connection with the web services and APIs provided by Facebook. // // As with any software that integrates with the Facebook platform, your use of // this software is subject to the Facebook Developer Principles and Policies // [http://developers.facebook.com/policy/]. This copyright notice shall be // included in all copies or substantial portions of the software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS // FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR // COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER // IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN // CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. #import #import #import "FBSDKCoreKitImport.h" #import "FBSDKShareMediaContent.h" #import "FBSDKSharingValidation.h" NS_ASSUME_NONNULL_BEGIN @class FBSDKSharePhoto; @class PHAsset; /** A video for sharing. */ NS_SWIFT_NAME(ShareVideo) @interface FBSDKShareVideo : NSObject /** Convenience method to build a new video object from raw data. - Parameter data: The NSData object that holds the raw video data. */ + (instancetype)videoWithData:(NSData *)data; /** Convenience method to build a new video object with NSData and a previewPhoto. - Parameter data: The NSData object that holds the raw video data. - Parameter previewPhoto: The photo that represents the video. */ + (instancetype)videoWithData:(NSData *)data previewPhoto:(FBSDKSharePhoto *)previewPhoto; /** Convenience method to build a new video object with a PHAsset. @param videoAsset The PHAsset that represents the video in the Photos library. */ + (instancetype)videoWithVideoAsset:(PHAsset *)videoAsset; /** Convenience method to build a new video object with a PHAsset and a previewPhoto. @param videoAsset The PHAsset that represents the video in the Photos library. @param previewPhoto The photo that represents the video. */ + (instancetype)videoWithVideoAsset:(PHAsset *)videoAsset previewPhoto:(FBSDKSharePhoto *)previewPhoto; /** Convenience method to build a new video object with a videoURL. @param videoURL The URL to the video. */ + (instancetype)videoWithVideoURL:(NSURL *)videoURL; /** Convenience method to build a new video object with a videoURL and a previewPhoto. @param videoURL The URL to the video. @param previewPhoto The photo that represents the video. */ + (instancetype)videoWithVideoURL:(NSURL *)videoURL previewPhoto:(FBSDKSharePhoto *)previewPhoto; /** The raw video data. - Returns: The video data. */ @property (nonatomic, strong, nullable) NSData *data; /** The representation of the video in the Photos library. @return PHAsset that represents the video in the Photos library. */ @property (nonatomic, copy, nullable) PHAsset *videoAsset; /** The file URL to the video. @return URL that points to the location of the video on disk */ @property (nonatomic, copy, nullable) NSURL *videoURL; /** The photo that represents the video. @return The photo */ @property (nonatomic, copy, nullable) FBSDKSharePhoto *previewPhoto; /** Compares the receiver to another video. @param video The other video @return YES if the receiver's values are equal to the other video's values; otherwise NO */ - (BOOL)isEqualToShareVideo:(FBSDKShareVideo *)video; @end @interface PHAsset (FBSDKShareVideo) @property (nonatomic, copy, readonly) NSURL *videoURL; @end NS_ASSUME_NONNULL_END