CMakeLists: enable optimization: -O3
[rrq/fuse_xattrs.git] / utils.c
1 /*
2   fuse_xattrs - Add xattrs support using sidecar files
3
4   Copyright (C) 2016  Felipe Barriga Richards <felipe {at} felipebarriga.cl>
5
6   This program can be distributed under the terms of the GNU GPL.
7   See the file COPYING.
8 */
9
10 #include <stdio.h>
11 #include <stdlib.h>
12 #include <string.h>
13
14 #include "utils.h"
15 #include "fuse_xattrs_config.h"
16
17 char *prepend_source_directory(const char *a, const char *b) {
18     size_t len = strlen(a) + strlen(b) + 1;
19     char *dst = (char*) malloc(sizeof(char) * len);
20     sprintf(dst, "%s%s", a, b);
21
22     return dst;
23 }
24
25 char *get_sidecar_path(const char *path)
26 {
27     const size_t path_len = strlen(path);
28     const size_t sidecar_ext_len = strlen(BINARY_SIDECAR_EXT); // this can be optimized
29     const size_t sidecar_path_len = path_len + sidecar_ext_len + 1;
30     char *sidecar_path = (char *) malloc(sidecar_path_len);
31     memset(sidecar_path, '\0', sidecar_path_len);
32     memcpy(sidecar_path, path, path_len);
33     memcpy(sidecar_path + path_len, BINARY_SIDECAR_EXT, sidecar_ext_len);
34
35     return sidecar_path;
36 }
37
38 // TODO: make it work for binary data
39 char *sanitize_value(const char *value, size_t value_size)
40 {
41     char *sanitized = malloc(value_size + 1);
42     memcpy(sanitized, value, value_size);
43     sanitized[value_size] = '\0';
44     return sanitized;
45 }
46
47
48 const size_t BINARY_SIDECAR_EXT_SIZE = strlen(BINARY_SIDECAR_EXT);
49
50 const int filename_is_sidecar(const char *string) {
51     if(string == NULL)
52         return 0;
53
54     size_t size = strlen(string);
55     if (size <= BINARY_SIDECAR_EXT_SIZE)
56         return 0;
57
58     if (memcmp(string+size-BINARY_SIDECAR_EXT_SIZE, BINARY_SIDECAR_EXT, BINARY_SIDECAR_EXT_SIZE) == 0) {
59         return 1;
60     }
61
62     return 0;
63 }
64
65 #define USER_NAMESPACE "user."
66 #define SYSTEM_NAMESPACE "system."
67 #define SECURITY_NAMESPACE "security."
68 #define TRUSTED_NAMESPACE "trusted."
69
70 const size_t USER_NAMESPACE_SIZE     = strlen(USER_NAMESPACE);
71 const size_t SYSTEM_NAMESPACE_SIZE   = strlen(SYSTEM_NAMESPACE);
72 const size_t SECURITY_NAMESPACE_SIZE = strlen(SECURITY_NAMESPACE);
73 const size_t THRUSTED_NAMESPACE_SIZE = strlen(TRUSTED_NAMESPACE);
74
75 enum namespace get_namespace(const char *name) {
76     size_t name_size = strlen(name);
77
78     if (name_size > USER_NAMESPACE_SIZE && memcmp(name, USER_NAMESPACE, USER_NAMESPACE_SIZE) == 0) {
79         return USER;
80     }
81
82     if (name_size > SYSTEM_NAMESPACE_SIZE && memcmp(name, SYSTEM_NAMESPACE, SYSTEM_NAMESPACE_SIZE) == 0) {
83         return SYSTEM;
84     }
85
86     if (name_size > SECURITY_NAMESPACE_SIZE && memcmp(name, SECURITY_NAMESPACE, SECURITY_NAMESPACE_SIZE) == 0) {
87         return SECURITY;
88     }
89
90     if (name_size > THRUSTED_NAMESPACE_SIZE && memcmp(name, TRUSTED_NAMESPACE, THRUSTED_NAMESPACE_SIZE) == 0) {
91         return TRUSTED;
92     }
93
94     error_print("invalid namespace for key: %s\n", name);
95     return ERROR;
96 }