1 /*
2 * Copyright (C) 2020-2021 Bareos GmbH & Co. KG
3 * Copyright (C) 2010 SCALITY SA. All rights reserved.
4 * http://www.scality.com
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions are
8 * met:
9 *
10 * Redistributions of source code must retain the above copyright notice,
11 * this list of conditions and the following disclaimer.
12 *
13 * Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
16 *
17 * THIS SOFTWARE IS PROVIDED BY SCALITY SA ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
19 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
20 * DISCLAIMED. IN NO EVENT SHALL SCALITY SA OR CONTRIBUTORS BE LIABLE FOR
21 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
25 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
26 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 * POSSIBILITY OF SUCH DAMAGE.
28 *
29 * The views and conclusions contained in the software and documentation
30 * are those of the authors and should not be interpreted as representing
31 * official policies, either expressed or implied, of SCALITY SA.
32 *
33 * https://github.com/scality/Droplet
34 */
35 #include "dropletp.h"
36
37 //#define DPRINTF(fmt,...) fprintf(stderr, fmt, ##__VA_ARGS__)
38 #define DPRINTF(fmt, ...)
39
dpl_sysmd_dup(const dpl_sysmd_t * sysmd)40 dpl_sysmd_t* dpl_sysmd_dup(const dpl_sysmd_t* sysmd)
41 {
42 dpl_sysmd_t* nsysmd;
43
44 nsysmd = malloc(sizeof(*nsysmd));
45 if (NULL == nsysmd) return NULL;
46
47 // for now simple ocpy
48 memcpy(nsysmd, sysmd, sizeof(*sysmd));
49
50 return nsysmd;
51 }
52
dpl_sysmd_free(dpl_sysmd_t * sysmd)53 void dpl_sysmd_free(dpl_sysmd_t* sysmd) { free(sysmd); }
54
dpl_sysmd_print(dpl_sysmd_t * sysmd,FILE * f)55 void dpl_sysmd_print(dpl_sysmd_t* sysmd, FILE* f)
56 {
57 int i;
58
59 if (sysmd->mask & DPL_SYSMD_MASK_ID) fprintf(f, "id=%s\n", sysmd->id);
60
61 if (sysmd->mask & DPL_SYSMD_MASK_VERSION)
62 fprintf(f, "version=%s\n", sysmd->version);
63
64 if (sysmd->mask & DPL_SYSMD_MASK_ENTERPRISE_NUMBER)
65 fprintf(f, "enterprise_number=%u\n", sysmd->enterprise_number);
66
67 if (sysmd->mask & DPL_SYSMD_MASK_PARENT_ID)
68 fprintf(f, "parent_id=%s\n", sysmd->parent_id);
69
70 if (sysmd->mask & DPL_SYSMD_MASK_FTYPE)
71 fprintf(f, "ftype=%s\n", dpl_object_type_str(sysmd->ftype));
72
73 if (sysmd->mask & DPL_SYSMD_MASK_CANNED_ACL)
74 fprintf(f, "canned_acl=%s\n", dpl_canned_acl_str(sysmd->canned_acl));
75
76 if (sysmd->mask & DPL_SYSMD_MASK_STORAGE_CLASS)
77 fprintf(f, "storage_class=%s\n",
78 dpl_storage_class_str(sysmd->storage_class));
79
80 if (sysmd->mask & DPL_SYSMD_MASK_SIZE) fprintf(f, "size=%lu\n", sysmd->size);
81
82 if (sysmd->mask & DPL_SYSMD_MASK_ATIME)
83 fprintf(f, "atime=%lu\n", sysmd->atime);
84
85 if (sysmd->mask & DPL_SYSMD_MASK_MTIME)
86 fprintf(f, "mtime=%lu\n", sysmd->mtime);
87
88 if (sysmd->mask & DPL_SYSMD_MASK_CTIME)
89 fprintf(f, "ctime=%lu\n", sysmd->ctime);
90
91 if (sysmd->mask & DPL_SYSMD_MASK_ETAG) fprintf(f, "etag=%s\n", sysmd->etag);
92
93 if (sysmd->mask & DPL_SYSMD_MASK_LOCATION_CONSTRAINT)
94 fprintf(f, "location_constraint=%s\n",
95 dpl_location_constraint_str(sysmd->location_constraint));
96
97 if (sysmd->mask & DPL_SYSMD_MASK_OWNER)
98 fprintf(f, "owner=%s\n", sysmd->owner);
99
100 if (sysmd->mask & DPL_SYSMD_MASK_GROUP)
101 fprintf(f, "group=%s\n", sysmd->group);
102
103 if (sysmd->mask & DPL_SYSMD_MASK_ACL) {
104 for (i = 0; i < sysmd->n_aces; i++) {
105 fprintf(f, "ace%d: type=0x%x flag=0x%x access_mask=0x%x who=0x%x\n", i,
106 sysmd->aces[i].type, sysmd->aces[i].flag,
107 sysmd->aces[i].access_mask, sysmd->aces[i].who);
108 }
109 }
110
111 if (sysmd->mask & DPL_SYSMD_MASK_PATH) fprintf(f, "path=%s\n", sysmd->path);
112 }
113