1
0
KF2-Dev-Scripts/Engine/Classes/OnlineCommunityContentInterface.uc
2020-12-13 18:01:13 +03:00

219 lines
9.0 KiB
Ucode

/**
* This interface deals with uploading, finding, and downloading of in game
* created binary data (screenshots, demo recordings, ghosts, etc.)
*
* Copyright 1998-2013 Epic Games, Inc. All Rights Reserved.
*/
interface OnlineCommunityContentInterface
dependson(OnlineSubsystem);
/**
* Initializes the community content object
*
* @return true if the initialization succeeded, false otherwise
*/
function bool Init();
/**
* Shuts down the community content object
*/
function Exit();
/**
* Starts the async task that reads the list of content that this person can download. The resulting
* data includes the information for that file (meta data and rating/download information)
*
* @param PlayerNum the controller number associated with the player
* @param StartAt used to read from a list starting a known offset
* @param NumToRead the number of items to retrieve (-1 means all)
*
* @return true if the async task succeeded in starting up, false otherwise
*/
function bool ReadContentList(byte PlayerNum,UniqueNetId NetId,optional string Path="",optional int StartAt = 0,optional int NumToRead = 0);
/**
* Delegate fired when the async read task has completed
*
* @param bWasSuccessful true if the async action completed without error, false if there was an error
*/
delegate OnReadContentListComplete(bool bWasSuccessful, array<CommunityContentFile> ContentFiles);
/**
* Adds the delegate to the list that will be notified when the task completes
*
* @param ReadContentListCompleteDelegate the delegate to use for notifications
*/
function AddReadContentListCompleteDelegate(delegate<OnReadContentListComplete> ReadContentListCompleteDelegate);
/**
* Removes the delegate from the list of notifications
*
* @param ReadContentListCompleteDelegate the delegate to use for notifications
*/
function ClearReadContentListCompleteDelegate(delegate<OnReadContentListComplete> ReadContentListCompleteDelegate);
/**
* Copies the content file information for the specified player
*
* @param PlayerNum the controller number associated with the player
* @param ContentFiles out array that is populated with the file list
*
* @return true if the copy succeeded, false otherwise (still in process, etc.)
*/
function bool GetContentList(byte PlayerNum,out array<CommunityContentFile> ContentFiles);
/**
* Starts the async task that reads the list of content that this person can download. The resulting
* data includes the information for that file (meta data and rating/download information)
*
* @param PlayerNum the controller number associated with the player
* @param Friends the set of friends to read the content files for
* @param StartAt used to read from a list starting a known offset
* @param NumToRead the number of items to retrieve (-1 means all)
*
* @return true if the async task succeeded in starting up, false otherwise
*/
function bool ReadFriendsContentList(byte PlayerNum,const out array<OnlineFriend> Friends,optional int StartAt = 0,optional int NumToRead = -1);
/**
* Delegate fired when the async read task has completed
*
* @param bWasSuccessful true if the async action completed without error, false if there was an error
*/
delegate OnReadFriendsContentListComplete(bool bWasSuccessful);
/**
* Adds the delegate to the list that will be notified when the task completes
*
* @param ReadFriendsContentListCompleteDelegate the delegate to use for notifications
*/
function AddReadFriendsContentListCompleteDelegate(delegate<OnReadFriendsContentListComplete> ReadFriendsContentListCompleteDelegate);
/**
* Removes the delegate from the list of notifications
*
* @param ReadFriendsContentListCompleteDelegate the delegate to use for notifications
*/
function ClearReadFriendsContentListCompleteDelegate(delegate<OnReadFriendsContentListComplete> ReadFriendsContentListCompleteDelegate);
/**
* Copies the content file information for the specified player
*
* @param PlayerNum the controller number associated with the player
* @param Friend the friend to copy the file list for
* @param ContentFiles out array that is populated with the file list
*
* @return true if the copy succeeded, false otherwise (still in process, etc.)
*/
function bool GetFriendsContentList(byte PlayerNum,const out OnlineFriend Friend,out array<CommunityContentFile> ContentFiles);
/**
* Uploads the contents of the blob to the content server(s)
*
* @param PlayerNum the controller number associated with the player
* @param Payload the data that is being uploaded
* @param Metadata metadata describing the content
*
* @return true if the async upload task started successfully, false otherwise
*/
function bool UploadContent(byte PlayerNum,const out array<byte> Payload,const out CommunityContentMetadata Metadata);
/**
* Delegate fired when the async upload task has completed
*
* @param bWasSuccessful true if the async action completed without error, false if there was an error
* @param UploadedFile the corresponding meta data that was associated with the content
*/
delegate OnUploadContentComplete(bool bWasSuccessful,CommunityContentFile UploadedFile);
/**
* Adds the delegate to the list that will be notified when the task completes
*
* @param UploadContentCompleteDelegate the delegate to use for notifications
*/
function AddUploadContentCompleteDelegate(delegate<OnUploadContentComplete> UploadContentCompleteDelegate);
/**
* Removes the delegate from the list of notifications
*
* @param UploadContentCompleteDelegate the delegate to use for notifications
*/
function ClearUploadContentCompleteDelegate(delegate<OnUploadContentComplete> UploadContentCompleteDelegate);
/**
* Downloads the contents of the specified file
*
* @param PlayerNum the controller number associated with the player
* @param FileToDownload the file information that tells the system what to download
*
* @return true if the async Download task started successfully, false otherwise
*/
function bool DownloadContent(byte PlayerNum,const out CommunityContentFile FileToDownload);
/**
* Delegate fired when the async download task has completed
*
* @param bWasSuccessful true if the async action completed without error, false if there was an error
* @param FileDownloaded the information for the file that was downloaded
*/
delegate OnDownloadContentComplete(bool bWasSuccessful,CommunityContentFile FileDownloaded, array<byte> Payload);
/**
* Adds the delegate to the list that will be notified when the task completes
*
* @param DownloadContentCompleteDelegate the delegate to use for notifications
*/
function AddDownloadContentCompleteDelegate(delegate<OnDownloadContentComplete> DownloadContentCompleteDelegate);
/**
* Removes the delegate from the list of notifications
*
* @param DownloadContentCompleteDelegate the delegate to use for notifications
*/
function ClearDownloadContentCompleteDelegate(delegate<OnDownloadContentComplete> DownloadContentCompleteDelegate);
/**
* Copies the contents of the payload into the specified array for the specified file owned
* by the specified player
*
* @param PlayerNum the controller number associated with the player
* @param FileDownloaded the information for the file that was downloaded
*
* @return true if the async Download task started successfully, false otherwise
*/
function bool GetContentPayload(byte PlayerNum,const out CommunityContentFile FileDownloaded);
/**
* Delegate fired when the async get content payload task has completed
*
* @param bWasSuccessful true if the async action completed without error, false if there was an error
* @param FileDownloaded the information for the file that was downloaded
* @param Payload the out array that receives contents of the file/blob data that was downloaded
*/
delegate OnGetContentPayloadComplete(bool bWasSuccessful,CommunityContentFile FileDownloaded,const out array<byte> Payload);
/**
* Adds the delegate to the list that will be notified when the task completes
*
* @param GetContentPayloadCompleteDelegate the delegate to use for notifications
*/
function AddGetContentPayloadCompleteDelegate(delegate<OnGetContentPayloadComplete> GetContentPayloadCompleteDelegate);
/**
* Removes the delegate from the list of notifications
*
* @param GetContentPayloadCompleteDelegate the delegate to use for notifications
*/
function ClearGetContentPayloadCompleteDelegate(delegate<OnGetContentPayloadComplete> GetContentPayloadCompleteDelegate);
/**
* Supplies a player defined rating for the specified content
*
* @param PlayerNum the controller number associated with the player
* @param FileToRate the information for the file that is being rated
* @param NewRating the new rating the player has given for this content
*
* @return true if the rating was successfully started, false otherwise (still in progress, can't find, etc.)
*/
function RateContent(byte PlayerNum,const out CommunityContentFile FileToRate,int NewRating);