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