2009-05-15 13:07:06 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2009 The Android Open Source Project
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2009-05-05 18:50:51 +00:00
|
|
|
#ifndef _UTILS_BACKUP_HELPERS_H
|
|
|
|
#define _UTILS_BACKUP_HELPERS_H
|
|
|
|
|
2009-05-15 13:07:06 +00:00
|
|
|
#include <utils/Errors.h>
|
|
|
|
#include <utils/String8.h>
|
2009-06-18 20:11:18 +00:00
|
|
|
#include <utils/KeyedVector.h>
|
2009-05-15 13:07:06 +00:00
|
|
|
|
|
|
|
namespace android {
|
|
|
|
|
2009-05-19 20:41:21 +00:00
|
|
|
enum {
|
|
|
|
BACKUP_HEADER_ENTITY_V1 = 0x61746144, // Data (little endian)
|
|
|
|
};
|
2009-05-05 18:50:51 +00:00
|
|
|
|
2009-05-15 22:20:19 +00:00
|
|
|
typedef struct {
|
2009-05-19 20:41:21 +00:00
|
|
|
int type; // BACKUP_HEADER_ENTITY_V1
|
2009-05-15 22:20:19 +00:00
|
|
|
int keyLen; // length of the key name, not including the null terminator
|
2009-05-19 20:41:21 +00:00
|
|
|
int dataSize; // size of the data, not including the padding, -1 means delete
|
2009-05-15 22:20:19 +00:00
|
|
|
} entity_header_v1;
|
|
|
|
|
2009-06-18 20:11:18 +00:00
|
|
|
struct SnapshotHeader {
|
|
|
|
int magic0;
|
|
|
|
int fileCount;
|
|
|
|
int magic1;
|
|
|
|
int totalSize;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct FileState {
|
|
|
|
int modTime_sec;
|
|
|
|
int modTime_nsec;
|
2009-06-23 20:03:00 +00:00
|
|
|
int mode;
|
2009-06-18 20:11:18 +00:00
|
|
|
int size;
|
|
|
|
int crc32;
|
|
|
|
int nameLen;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct FileRec {
|
|
|
|
String8 file;
|
|
|
|
bool deleted;
|
|
|
|
FileState s;
|
|
|
|
};
|
|
|
|
|
2009-05-15 22:20:19 +00:00
|
|
|
|
2009-05-15 13:07:06 +00:00
|
|
|
/**
|
2009-05-15 22:20:19 +00:00
|
|
|
* Writes the data.
|
2009-05-15 13:07:06 +00:00
|
|
|
*
|
|
|
|
* If an error occurs, it poisons this object and all write calls will fail
|
|
|
|
* with the error that occurred.
|
|
|
|
*/
|
|
|
|
class BackupDataWriter
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
BackupDataWriter(int fd);
|
|
|
|
// does not close fd
|
|
|
|
~BackupDataWriter();
|
|
|
|
|
|
|
|
status_t WriteEntityHeader(const String8& key, size_t dataSize);
|
|
|
|
status_t WriteEntityData(const void* data, size_t size);
|
|
|
|
|
2009-06-19 03:10:37 +00:00
|
|
|
void SetKeyPrefix(const String8& keyPrefix);
|
|
|
|
|
2009-05-15 13:07:06 +00:00
|
|
|
private:
|
|
|
|
explicit BackupDataWriter();
|
|
|
|
status_t write_padding_for(int n);
|
|
|
|
|
|
|
|
int m_fd;
|
|
|
|
status_t m_status;
|
|
|
|
ssize_t m_pos;
|
|
|
|
int m_entityCount;
|
2009-06-19 03:10:37 +00:00
|
|
|
String8 m_keyPrefix;
|
2009-05-15 13:07:06 +00:00
|
|
|
};
|
|
|
|
|
2009-05-15 22:20:19 +00:00
|
|
|
/**
|
|
|
|
* Reads the data.
|
|
|
|
*
|
|
|
|
* If an error occurs, it poisons this object and all write calls will fail
|
|
|
|
* with the error that occurred.
|
|
|
|
*/
|
|
|
|
class BackupDataReader
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
BackupDataReader(int fd);
|
|
|
|
// does not close fd
|
|
|
|
~BackupDataReader();
|
|
|
|
|
|
|
|
status_t Status();
|
2009-06-16 20:31:35 +00:00
|
|
|
status_t ReadNextHeader(bool* done, int* type);
|
2009-05-15 22:20:19 +00:00
|
|
|
|
|
|
|
bool HasEntities();
|
|
|
|
status_t ReadEntityHeader(String8* key, size_t* dataSize);
|
2009-05-19 20:41:21 +00:00
|
|
|
status_t SkipEntityData(); // must be called with the pointer at the begining of the data.
|
2009-06-17 23:20:55 +00:00
|
|
|
ssize_t ReadEntityData(void* data, size_t size);
|
2009-05-15 22:20:19 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
explicit BackupDataReader();
|
|
|
|
status_t skip_padding();
|
|
|
|
|
|
|
|
int m_fd;
|
2009-06-16 20:31:35 +00:00
|
|
|
bool m_done;
|
2009-05-15 22:20:19 +00:00
|
|
|
status_t m_status;
|
|
|
|
ssize_t m_pos;
|
2009-06-16 20:31:35 +00:00
|
|
|
ssize_t m_dataEndPos;
|
2009-05-15 22:20:19 +00:00
|
|
|
int m_entityCount;
|
|
|
|
union {
|
|
|
|
int type;
|
|
|
|
entity_header_v1 entity;
|
|
|
|
} m_header;
|
2009-06-19 01:23:43 +00:00
|
|
|
String8 m_key;
|
2009-05-15 22:20:19 +00:00
|
|
|
};
|
|
|
|
|
2009-05-19 20:41:21 +00:00
|
|
|
int back_up_files(int oldSnapshotFD, BackupDataWriter* dataStream, int newSnapshotFD,
|
2009-06-11 00:07:15 +00:00
|
|
|
char const* const* files, char const* const *keys, int fileCount);
|
2009-05-19 20:41:21 +00:00
|
|
|
|
2009-06-18 20:11:18 +00:00
|
|
|
class RestoreHelperBase
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
RestoreHelperBase();
|
|
|
|
~RestoreHelperBase();
|
|
|
|
|
|
|
|
status_t WriteFile(const String8& filename, BackupDataReader* in);
|
|
|
|
status_t WriteSnapshot(int fd);
|
|
|
|
|
|
|
|
private:
|
|
|
|
void* m_buf;
|
|
|
|
KeyedVector<String8,FileRec> m_files;
|
|
|
|
};
|
2009-05-19 20:41:21 +00:00
|
|
|
|
|
|
|
#define TEST_BACKUP_HELPERS 1
|
2009-05-05 18:50:51 +00:00
|
|
|
|
|
|
|
#if TEST_BACKUP_HELPERS
|
|
|
|
int backup_helper_test_empty();
|
|
|
|
int backup_helper_test_four();
|
|
|
|
int backup_helper_test_files();
|
2009-06-11 00:07:15 +00:00
|
|
|
int backup_helper_test_null_base();
|
2009-06-11 18:27:16 +00:00
|
|
|
int backup_helper_test_missing_file();
|
2009-05-15 13:07:06 +00:00
|
|
|
int backup_helper_test_data_writer();
|
2009-05-15 22:20:19 +00:00
|
|
|
int backup_helper_test_data_reader();
|
2009-05-05 18:50:51 +00:00
|
|
|
#endif
|
|
|
|
|
2009-05-15 13:07:06 +00:00
|
|
|
} // namespace android
|
|
|
|
|
2009-05-05 18:50:51 +00:00
|
|
|
#endif // _UTILS_BACKUP_HELPERS_H
|