2 tdb2restore -- construct a tdb from tdbdump output.
3 Copyright (C) Volker Lendecke 2010
4 Copyright (C) Simon McVittie 2005
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 3 of the License, or
9 (at your option) any later version.
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with this program. If not, see <http://www.gnu.org/licenses/>.
23 #ifdef HAVE_LIBREPLACE
25 #include <system/filesys.h>
27 #include <sys/types.h>
34 #define debug_fprintf(file, fmt, ...) do {/*nothing*/} while (0)
36 static int read_linehead(FILE *f)
51 for (i=0; i<sizeof(prefix); i++) {
61 if (i == sizeof(prefix)) {
66 if (sscanf(prefix, "%d) = ", &num_bytes) != 1) {
72 static int read_hex(void) {
76 fprintf(stderr, "Unexpected EOF in data\n");
78 } else if (c == '"') {
79 fprintf(stderr, "Unexpected \\\" sequence\n");
81 } else if ('0' <= c && c <= '9') {
83 } else if ('A' <= c && c <= 'F') {
85 } else if ('a' <= c && c <= 'f') {
88 fprintf(stderr, "Invalid hex: %c\n", c);
93 static int read_data(FILE *f, struct tdb_data *d, size_t size) {
97 d->dptr = (unsigned char *)malloc(size);
98 if (d->dptr == NULL) {
103 for (i=0; i<size; i++) {
106 fprintf(stderr, "Unexpected EOF in data\n");
108 } else if (c == '"') {
110 } else if (c == '\\') {
116 assert(high == (high & 0xf0));
121 assert(low == (low & 0x0f));
122 d->dptr[i] = (low|high);
130 static int swallow(FILE *f, const char *s, int *eof)
134 if (fgets(line, sizeof(line), f) == NULL) {
140 if (strcmp(line, s) != 0) {
146 static bool read_rec(FILE *f, struct tdb_context *tdb, int *eof)
149 struct tdb_data key, data;
156 if (swallow(f, "{\n", eof) == -1) {
159 length = read_linehead(f);
163 if (read_data(f, &key, length) == -1) {
166 if (swallow(f, "\"\n", NULL) == -1) {
169 length = read_linehead(f);
173 if (read_data(f, &data, length) == -1) {
176 if ((swallow(f, "\"\n", NULL) == -1)
177 || (swallow(f, "}\n", NULL) == -1)) {
180 e = tdb_store(tdb, key, data, TDB_INSERT);
181 if (e != TDB_SUCCESS) {
182 fprintf(stderr, "TDB error: %s\n", tdb_errorstr(e));
193 static int restore_tdb(const char *fname)
195 struct tdb_context *tdb;
197 tdb = tdb_open(fname, 0, O_RDWR|O_CREAT|O_EXCL, 0666, NULL);
200 fprintf(stderr, "Failed to open %s\n", fname);
206 if (!read_rec(stdin, tdb, &eof)) {
213 if (tdb_close(tdb)) {
214 fprintf(stderr, "Error closing tdb\n");
217 fprintf(stderr, "EOF\n");
221 int main(int argc, char *argv[])
226 printf("Usage: %s dbname < tdbdump_output\n", argv[0]);
232 return restore_tdb(fname);