File: extraFieldPreserve.cpp

package info (click to toggle)
fuse-zip 0.7.2-3
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 9,776 kB
  • sloc: cpp: 5,509; sh: 2,587; makefile: 193
file content (226 lines) | stat: -rw-r--r-- 6,192 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
#include <cassert>
#include <cstdlib>
#include <memory>

#include <syslog.h>
#include <zip.h>

#include "fileNode.h"

void zip_stat_init(struct zip_stat *sb) {
    memset(sb, 0, sizeof(struct zip_stat));
}

void initTest() {
    // hide almost all messages
    setlogmask(LOG_MASK(LOG_EMERG));
}

uint16_t extrafld_type;
bool input_exist;
uint16_t input_len, expected_len;
const uint8_t *input_data, *expected_data;

zip_int16_t zip_file_extra_fields_count(struct zip *, zip_uint64_t, zip_flags_t) {
    return 1;
}

zip_int16_t zip_file_extra_fields_count_by_id(struct zip *, zip_uint64_t, zip_uint16_t, zip_flags_t) {
    return (input_exist) ? 1 : 0;
}

const zip_uint8_t *zip_file_extra_field_get(struct zip *, zip_uint64_t, zip_uint16_t,
        zip_uint16_t *idp, zip_uint16_t *lenp, zip_flags_t) {
    *idp = extrafld_type;
    *lenp = input_len;
    return input_data;
}

const zip_uint8_t *zip_file_extra_field_get_by_id(struct zip *, zip_uint64_t, zip_uint16_t, zip_uint16_t, zip_uint16_t *, zip_flags_t) {
    assert(false);
    return NULL;
}

int zip_file_extra_field_delete(struct zip *, zip_uint64_t, zip_uint16_t, zip_flags_t) {
    return 0;
}

int zip_file_extra_field_set(struct zip *, zip_uint64_t, zip_uint16_t id, zip_uint16_t,
        const zip_uint8_t *data, zip_uint16_t len, zip_flags_t) {
    if (id == extrafld_type) {
        assert(len == expected_len);
        for (unsigned int i = 0; i < len; ++i) {
            assert(data[i] == expected_data[i]);
        }
    }
    return 0;
}

int zip_file_get_external_attributes(struct zip *, zip_uint64_t, zip_flags_t, zip_uint8_t *opsysPtr, zip_uint32_t *attrPtr) {
    *opsysPtr = ZIP_OPSYS_UNIX;
    *attrPtr = 0;
    return 0;
}

int zip_file_set_external_attributes(struct zip *, zip_uint64_t, zip_flags_t, zip_uint8_t, zip_uint32_t) {
    return 0;
}

int zip_stat_index(struct zip *, zip_uint64_t, zip_flags_t, struct zip_stat *zs) {
    zs->valid = ZIP_STAT_NAME | ZIP_STAT_INDEX | ZIP_STAT_SIZE | ZIP_STAT_MTIME;
    zs->name = "test";
    zs->index = 0;
    zs->size = 0;
    zs->mtime = 1234567890; // Fri Feb 13 23:31:30 GMT 2009
    return 0;
}

struct zip_file *zip_fopen_index(struct zip *, zip_uint64_t, zip_flags_t) {
    assert(false);
    return NULL;
}

zip_int64_t zip_fread(struct zip_file *, void *, zip_uint64_t) {
    assert(false);
    return 0;
}

int zip_fclose(struct zip_file *) {
    assert(false);
    return 0;
}

zip_int64_t zip_file_add(struct zip *, const char *, struct zip_source *, zip_flags_t) {
    assert(false);
    return 0;
}

int zip_file_replace(struct zip *, zip_uint64_t, struct zip_source *, zip_flags_t) {
    return 0;
}

struct zip_source *zip_source_function(struct zip *, zip_source_callback, void *) {
    assert(false);
    return NULL;
}

void zip_source_free(struct zip_source *) {
    assert(false);
}

const char *zip_get_name(struct zip *, zip_uint64_t, zip_flags_t) {
    assert(false);
    return NULL;
}

const char *zip_file_strerror(struct zip_file *) {
    assert(false);
    return NULL;
}

const char *zip_strerror(struct zip *) {
    assert(false);
    return NULL;
}

const char *zip_get_archive_comment(zip_t *, int *, zip_flags_t) {
    return NULL;
}

int zip_set_archive_comment(zip_t *, const char *, zip_uint16_t) {
    assert(false);
    return 0;
}

const char *zip_file_get_comment(zip_t *, zip_uint64_t, zip_uint32_t *, zip_flags_t) {
    return NULL;
}

int zip_file_set_comment(zip_t *, zip_uint64_t, const char *, zip_uint16_t, zip_flags_t) {
    assert(false);
    return 0;
}

void ntfs_extra_field_create() {
    const zip_uint8_t expected[] = {
        0x00, 0x00, 0x00, 0x00, // reserved
        0x01, 0x00, // tag 1
        0x18, 0x00, // size
        0xFF, 0x60, 0x4A, 0x5E, 0xF3, 0x21, 0xD5, 0x01, // mtime
        0x87, 0xCB, 0xA9, 0x32, 0x33, 0x8E, 0xC9, 0x01, // atime
        0x00, 0xF5, 0x96, 0x32, 0x33, 0x8E, 0xC9, 0x01  // btime
    };

    extrafld_type = 0x000A;
    input_exist = false;
    expected_data = expected;
    expected_len = sizeof(expected);

    std::unique_ptr<FileNode> n (FileNode::createNodeForZipEntry((zip*)1, "test", 0, S_IFREG | 0666));
    struct timespec atime, mtime;
    mtime.tv_sec  = 1560435721;
    mtime.tv_nsec = 999999900;
    atime.tv_sec  = 1234567890;
    atime.tv_nsec = 123456700;
    n->setTimes(atime, mtime);

    n->saveMetadata(true);
}

void ntfs_extra_field_edit() {
    const uint8_t data[] = {
        0x12, 0x34, 0x56, 0x78, // reserved
        0x01, 0x00, // tag 1
        0x18, 0x00, // size
        0x00, 0x80, 0x3E, 0xD5, 0xDE, 0xB1, 0x9D, 0x01, // ctime
        0x00, 0x80, 0x3E, 0xD5, 0xDE, 0xB1, 0x9D, 0x01, // atime
        0x00, 0x80, 0x3E, 0xD5, 0xDE, 0xB1, 0x9D, 0x01, // btime
        0xEF, 0xDC, // unknown tag
        0x03, 0x00, // size
        0x01, 0x02, 0x03, // unhandled data
        0x01, 0x00, // tag 1 (again)
        0x18, 0x00, // size
        0x1B, 0xFA, 0x1F, 0x5E, 0xF3, 0x21, 0xD5, 0x01, // ctime
        0x87, 0xCB, 0xA9, 0x32, 0x33, 0x8E, 0xC9, 0x01, // atime
        0xFF, 0x80, 0x3E, 0xD5, 0xDE, 0xB1, 0x9D, 0x01  // btime
    };
    const zip_uint8_t expected[] = {
        0x12, 0x34, 0x56, 0x78, // reserved
        0xEF, 0xDC, // unknown tag
        0x03, 0x00, // size
        0x01, 0x02, 0x03, // unhandled data
        0x01, 0x00, // tag 1
        0x18, 0x00, // size
        0xFF, 0x60, 0x4A, 0x5E, 0xF3, 0x21, 0xD5, 0x01, // mtime
        0x87, 0xCB, 0xA9, 0x32, 0x33, 0x8E, 0xC9, 0x01, // atime
        0xFF, 0x80, 0x3E, 0xD5, 0xDE, 0xB1, 0x9D, 0x01  // btime
    };

    extrafld_type = 0x000A;
    input_exist = true;
    input_data = data;
    input_len = sizeof(data);
    expected_data = expected;
    expected_len = sizeof(expected);

    std::unique_ptr<FileNode> n (FileNode::createNodeForZipEntry((zip*)1, "test", 0, S_IFREG | 0666));
    struct timespec atime, mtime;
    mtime.tv_sec  = 1560435721;
    mtime.tv_nsec = 999999900;
    atime.tv_sec  = 1234567890;
    atime.tv_nsec = 123456700;
    n->setTimes(atime, mtime);

    n->saveMetadata(true);
}

// no extra field - create

int main(int, char **) {
    initTest();

    ntfs_extra_field_create();
    ntfs_extra_field_edit();

    return EXIT_SUCCESS;
}