mirror of
https://github.com/DarkflameUniverse/DarkflameServer.git
synced 2025-01-25 06:07:00 +00:00
54 lines
3.0 KiB
C
54 lines
3.0 KiB
C
|
/// \file
|
||
|
/// \brief An interface used by AutopatcherServer to get the data necessary to run an autopatcher.
|
||
|
///
|
||
|
/// This file is part of RakNet Copyright 2003 Kevin Jenkins.
|
||
|
///
|
||
|
/// Usage of RakNet is subject to the appropriate license agreement.
|
||
|
/// Creative Commons Licensees are subject to the
|
||
|
/// license found at
|
||
|
/// http://creativecommons.org/licenses/by-nc/2.5/
|
||
|
/// Single application licensees are subject to the license found at
|
||
|
/// http://www.jenkinssoftware.com/SingleApplicationLicense.html
|
||
|
/// Custom license users are subject to the terms therein.
|
||
|
/// GPL license users are subject to the GNU General Public
|
||
|
/// License as published by the Free
|
||
|
/// Software Foundation; either version 2 of the License, or (at your
|
||
|
/// option) any later version.
|
||
|
|
||
|
|
||
|
#ifndef __AUTOPATCHER_REPOSITORY_INTERFACE_H
|
||
|
#define __AUTOPATCHER_REPOSITORY_INTERFACE_H
|
||
|
|
||
|
class FileList;
|
||
|
namespace RakNet
|
||
|
{
|
||
|
class BitStream;
|
||
|
}
|
||
|
|
||
|
/// An interface used by AutopatcherServer to get the data necessary to run an autopatcher. This is up to you to implement for custom repository solutions.
|
||
|
class AutopatcherRepositoryInterface
|
||
|
{
|
||
|
public:
|
||
|
/// Get list of files added and deleted since a certain date. This is used by AutopatcherServer and not usually explicitly called.
|
||
|
/// \param[in] applicationName A null terminated string identifying the application
|
||
|
/// \param[out] addedFiles A list of the current versions of filenames with hashes as their data that were created after \a sinceData
|
||
|
/// \param[out] deletedFiles A list of the current versions of filenames that were deleted after \a sinceData
|
||
|
/// \param[in] An input date, in whatever format your repository uses
|
||
|
/// \param[out] currentDate The current server date, in whatever format your repository uses
|
||
|
/// \return True on success, false on failure.
|
||
|
virtual bool GetChangelistSinceDate(const char *applicationName, FileList *addedFiles, FileList *deletedFiles, const char *sinceDate, char currentDate[64])=0;
|
||
|
|
||
|
/// Get patches (or files) for every file in input, assuming that input has a hash for each of those files.
|
||
|
/// \param[in] applicationName A null terminated string identifying the application
|
||
|
/// \param[in] input A list of files with SHA1_LENGTH byte hashes to get from the database.
|
||
|
/// \param[out] patchList You should return list of files with either the filedata or the patch. This is a subset of \a input. The context data for each file will be either PC_WRITE_FILE (to just write the file) or PC_HASH_WITH_PATCH (to patch). If PC_HASH_WITH_PATCH, then the file contains a SHA1_LENGTH byte patch followed by the hash. The datalength is patchlength + SHA1_LENGTH
|
||
|
/// \param[out] currentDate The current server date, in whatever format your repository uses
|
||
|
/// \return True on success, false on failure.
|
||
|
virtual bool GetPatches(const char *applicationName, FileList *input, FileList *patchList, char currentDate[64])=0;
|
||
|
|
||
|
/// \return Whatever this function returns is sent from the AutopatcherServer to the AutopatcherClient when one of the above functions returns false.
|
||
|
virtual const char *GetLastError(void) const=0;
|
||
|
};
|
||
|
|
||
|
#endif
|