mirror of
https://github.com/pgbackrest/pgbackrest.git
synced 2024-12-14 10:13:05 +02:00
Add pgBackRest version to Info and Manifest objects.
This was not being exposed previously because it is primarily informational, but now it is needed to reconstruct the backup.info file.
This commit is contained in:
parent
38b72eded4
commit
6d8d0eeba7
@ -40,6 +40,7 @@ Object types
|
|||||||
struct Info
|
struct Info
|
||||||
{
|
{
|
||||||
MemContext *memContext; // Mem context
|
MemContext *memContext; // Mem context
|
||||||
|
const String *backrestVersion; // pgBackRest version
|
||||||
const String *cipherPass; // Cipher passphrase if set
|
const String *cipherPass; // Cipher passphrase if set
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -141,6 +142,7 @@ infoNew(const String *cipherPass)
|
|||||||
|
|
||||||
// Cipher used to encrypt/decrypt subsequent dependent files. Value may be NULL.
|
// Cipher used to encrypt/decrypt subsequent dependent files. Value may be NULL.
|
||||||
this->cipherPass = strDup(cipherPass);
|
this->cipherPass = strDup(cipherPass);
|
||||||
|
this->backrestVersion = STRDEF(PROJECT_VERSION);
|
||||||
}
|
}
|
||||||
MEM_CONTEXT_NEW_END();
|
MEM_CONTEXT_NEW_END();
|
||||||
|
|
||||||
@ -209,6 +211,15 @@ infoLoadCallback(void *data, const String *section, const String *key, const Str
|
|||||||
if (jsonToUInt(value) != REPOSITORY_FORMAT)
|
if (jsonToUInt(value) != REPOSITORY_FORMAT)
|
||||||
THROW_FMT(FormatError, "expected format %d but found %d", REPOSITORY_FORMAT, cvtZToInt(strPtr(value)));
|
THROW_FMT(FormatError, "expected format %d but found %d", REPOSITORY_FORMAT, cvtZToInt(strPtr(value)));
|
||||||
}
|
}
|
||||||
|
// Store pgBackRest version
|
||||||
|
else if (strEq(key, INFO_KEY_VERSION_STR))
|
||||||
|
{
|
||||||
|
MEM_CONTEXT_BEGIN(loadData->info->memContext)
|
||||||
|
{
|
||||||
|
loadData->info->backrestVersion = jsonToStr(value);
|
||||||
|
}
|
||||||
|
MEM_CONTEXT_END();
|
||||||
|
}
|
||||||
// Store checksum to be validated later
|
// Store checksum to be validated later
|
||||||
else if (strEq(key, INFO_KEY_CHECKSUM_STR))
|
else if (strEq(key, INFO_KEY_CHECKSUM_STR))
|
||||||
{
|
{
|
||||||
@ -451,6 +462,18 @@ infoCipherPass(const Info *this)
|
|||||||
FUNCTION_TEST_RETURN(this->cipherPass);
|
FUNCTION_TEST_RETURN(this->cipherPass);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const String *
|
||||||
|
infoBackrestVersion(const Info *this)
|
||||||
|
{
|
||||||
|
FUNCTION_TEST_BEGIN();
|
||||||
|
FUNCTION_TEST_PARAM(INFO, this);
|
||||||
|
FUNCTION_TEST_END();
|
||||||
|
|
||||||
|
ASSERT(this != NULL);
|
||||||
|
|
||||||
|
FUNCTION_TEST_RETURN(this->backrestVersion);
|
||||||
|
}
|
||||||
|
|
||||||
/***********************************************************************************************************************************
|
/***********************************************************************************************************************************
|
||||||
Load info file(s) and throw error for each attempt if none are successful
|
Load info file(s) and throw error for each attempt if none are successful
|
||||||
***********************************************************************************************************************************/
|
***********************************************************************************************************************************/
|
||||||
|
@ -54,6 +54,7 @@ void infoSaveValue(InfoSave *infoSaveData, const String *section, const String *
|
|||||||
Getters
|
Getters
|
||||||
***********************************************************************************************************************************/
|
***********************************************************************************************************************************/
|
||||||
const String *infoCipherPass(const Info *this);
|
const String *infoCipherPass(const Info *this);
|
||||||
|
const String *infoBackrestVersion(const Info *this);
|
||||||
|
|
||||||
/***********************************************************************************************************************************
|
/***********************************************************************************************************************************
|
||||||
Helper functions
|
Helper functions
|
||||||
|
@ -803,6 +803,7 @@ manifestNewLoad(IoRead *read)
|
|||||||
MEM_CONTEXT_END();
|
MEM_CONTEXT_END();
|
||||||
|
|
||||||
this->info = infoNewLoad(read, manifestLoadCallback, &loadData);
|
this->info = infoNewLoad(read, manifestLoadCallback, &loadData);
|
||||||
|
this->data.backrestVersion = infoBackrestVersion(this->info);
|
||||||
|
|
||||||
// Process file defaults
|
// Process file defaults
|
||||||
for (unsigned int fileIdx = 0; fileIdx < manifestFileTotal(this); fileIdx++)
|
for (unsigned int fileIdx = 0; fileIdx < manifestFileTotal(this); fileIdx++)
|
||||||
|
@ -38,6 +38,8 @@ Manifest data
|
|||||||
***********************************************************************************************************************************/
|
***********************************************************************************************************************************/
|
||||||
typedef struct ManifestData
|
typedef struct ManifestData
|
||||||
{
|
{
|
||||||
|
const String *backrestVersion; // pgBackRest version
|
||||||
|
|
||||||
const String *backupLabel; // Backup label (unique identifier for the backup)
|
const String *backupLabel; // Backup label (unique identifier for the backup)
|
||||||
const String *backupLabelPrior; // Backup label for backup this diff/incr is based on
|
const String *backupLabelPrior; // Backup label for backup this diff/incr is based on
|
||||||
time_t backupTimestampCopyStart; // When did the file copy start?
|
time_t backupTimestampCopyStart; // When did the file copy start?
|
||||||
|
@ -118,11 +118,12 @@ testRun(void)
|
|||||||
"[backrest]\n"
|
"[backrest]\n"
|
||||||
"backrest-checksum=\"BOGUS\"\n"
|
"backrest-checksum=\"BOGUS\"\n"
|
||||||
"backrest-format=5\n"
|
"backrest-format=5\n"
|
||||||
"backrest-version=\"2.17\"\n");
|
"backrest-version=\"2.17\"\n"
|
||||||
|
"bogus=\"BOGUS\"\n");
|
||||||
|
|
||||||
TEST_ERROR(
|
TEST_ERROR(
|
||||||
infoNewLoad(ioBufferReadNew(contentLoad), harnessInfoLoadNewCallback, callbackContent), ChecksumError,
|
infoNewLoad(ioBufferReadNew(contentLoad), harnessInfoLoadNewCallback, callbackContent), ChecksumError,
|
||||||
"invalid checksum, actual 'a9e578459485db14eb1093809a7964832be2779a' but expected 'BOGUS'");
|
"invalid checksum, actual 'fe989a75dcf7a0261e57d210707c0db741462763' but expected 'BOGUS'");
|
||||||
TEST_RESULT_STR(strPtr(callbackContent), "", " check callback content");
|
TEST_RESULT_STR(strPtr(callbackContent), "", " check callback content");
|
||||||
|
|
||||||
// Crypto expected
|
// Crypto expected
|
||||||
@ -196,6 +197,7 @@ testRun(void)
|
|||||||
infoNewLoad(ioBufferReadNew(contentLoad), harnessInfoLoadNewCallback, callbackContent), "info with content and cipher");
|
infoNewLoad(ioBufferReadNew(contentLoad), harnessInfoLoadNewCallback, callbackContent), "info with content and cipher");
|
||||||
TEST_RESULT_STR(strPtr(callbackContent), "[c] key=1\n[d] key=1\n", " check callback content");
|
TEST_RESULT_STR(strPtr(callbackContent), "[c] key=1\n[d] key=1\n", " check callback content");
|
||||||
TEST_RESULT_STR(strPtr(infoCipherPass(info)), "somepass", " check cipher pass set");
|
TEST_RESULT_STR(strPtr(infoCipherPass(info)), "somepass", " check cipher pass set");
|
||||||
|
TEST_RESULT_STR(strPtr(infoBackrestVersion(info)), PROJECT_VERSION, " check backrest version");
|
||||||
|
|
||||||
contentSave = bufNew(0);
|
contentSave = bufNew(0);
|
||||||
|
|
||||||
|
@ -417,6 +417,7 @@ testRun(void)
|
|||||||
storagePutNP(storageNewWriteNP(storageTest, strNew(BACKUP_MANIFEST_FILE INFO_COPY_EXT)), content), "write copy");
|
storagePutNP(storageNewWriteNP(storageTest, strNew(BACKUP_MANIFEST_FILE INFO_COPY_EXT)), content), "write copy");
|
||||||
TEST_ASSIGN(manifest, manifestLoadFile(storageTest, STRDEF(BACKUP_MANIFEST_FILE), cipherTypeNone, NULL), "load copy");
|
TEST_ASSIGN(manifest, manifestLoadFile(storageTest, STRDEF(BACKUP_MANIFEST_FILE), cipherTypeNone, NULL), "load copy");
|
||||||
TEST_RESULT_UINT(manifestData(manifest)->pgSystemId, 1000000000000000094, " check file loaded");
|
TEST_RESULT_UINT(manifestData(manifest)->pgSystemId, 1000000000000000094, " check file loaded");
|
||||||
|
TEST_RESULT_STR(strPtr(manifestData(manifest)->backrestVersion), PROJECT_VERSION, " check backrest version");
|
||||||
|
|
||||||
storageRemoveP(storageTest, strNew(BACKUP_MANIFEST_FILE INFO_COPY_EXT), .errorOnMissing = true);
|
storageRemoveP(storageTest, strNew(BACKUP_MANIFEST_FILE INFO_COPY_EXT), .errorOnMissing = true);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user