1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package org.apache.logging.log4j.core.util;
18
19 import java.io.File;
20 import java.io.IOException;
21 import java.net.URI;
22 import java.net.URISyntaxException;
23 import java.net.URL;
24 import java.nio.file.FileSystems;
25 import java.nio.file.Files;
26 import java.nio.file.Path;
27 import java.nio.file.attribute.GroupPrincipal;
28 import java.nio.file.attribute.PosixFileAttributeView;
29 import java.nio.file.attribute.PosixFilePermission;
30 import java.nio.file.attribute.UserPrincipal;
31 import java.nio.file.attribute.UserPrincipalLookupService;
32 import java.util.Objects;
33 import java.util.Set;
34
35 import org.apache.logging.log4j.Logger;
36 import org.apache.logging.log4j.status.StatusLogger;
37
38
39
40
41 public final class FileUtils {
42
43
44 private static final String PROTOCOL_FILE = "file";
45
46 private static final String JBOSS_FILE = "vfsfile";
47
48 private static final Logger LOGGER = StatusLogger.getLogger();
49
50 private FileUtils() {
51 }
52
53
54
55
56
57
58
59 public static File fileFromUri(URI uri) {
60 if (uri == null) {
61 return null;
62 }
63 if (uri.isAbsolute()) {
64 if (JBOSS_FILE.equals(uri.getScheme())) try {
65
66 uri = new URI(PROTOCOL_FILE, uri.getSchemeSpecificPart(), uri.getFragment());
67 } catch (URISyntaxException use) {
68
69 }
70 try {
71 if (PROTOCOL_FILE.equals(uri.getScheme())) {
72 return new File(uri);
73 }
74 } catch (final Exception ex) {
75 LOGGER.warn("Invalid URI {}", uri);
76 }
77 } else {
78 File file = new File(uri.toString());
79 try {
80 if (file.exists()) {
81 return file;
82 }
83 final String path = uri.getPath();
84 return new File(path);
85 } catch (final Exception ex) {
86 LOGGER.warn("Invalid URI {}", uri);
87 }
88 }
89 return null;
90 }
91
92 public static boolean isFile(final URL url) {
93 return url != null && (url.getProtocol().equals(PROTOCOL_FILE) || url.getProtocol().equals(JBOSS_FILE));
94 }
95
96 public static String getFileExtension(final File file) {
97 final String fileName = file.getName();
98 if (fileName.lastIndexOf(".") != -1 && fileName.lastIndexOf(".") != 0) {
99 return fileName.substring(fileName.lastIndexOf(".") + 1);
100 }
101 return null;
102 }
103
104
105
106
107
108
109
110
111 public static void mkdir(final File dir, final boolean createDirectoryIfNotExisting) throws IOException {
112
113 if (!dir.exists()) {
114 if (!createDirectoryIfNotExisting) {
115 throw new IOException("The directory " + dir.getAbsolutePath() + " does not exist.");
116 }
117 if (!dir.mkdirs()) {
118 throw new IOException("Could not create directory " + dir.getAbsolutePath());
119 }
120 }
121 if (!dir.isDirectory()) {
122 throw new IOException("File " + dir + " exists and is not a directory. Unable to create directory.");
123 }
124 }
125
126
127
128
129
130
131
132 public static void makeParentDirs(final File file) throws IOException {
133 final File parent = Objects.requireNonNull(file, "file").getCanonicalFile().getParentFile();
134 if (parent != null) {
135 mkdir(parent, true);
136 }
137 }
138
139
140
141
142
143
144
145
146
147
148 public static void defineFilePosixAttributeView(final Path path,
149 final Set<PosixFilePermission> filePermissions,
150 final String fileOwner,
151 final String fileGroup) throws IOException {
152 final PosixFileAttributeView view = Files.getFileAttributeView(path, PosixFileAttributeView.class);
153 if (view != null) {
154 final UserPrincipalLookupService lookupService = FileSystems.getDefault()
155 .getUserPrincipalLookupService();
156 if (fileOwner != null) {
157 final UserPrincipal userPrincipal = lookupService.lookupPrincipalByName(fileOwner);
158 if (userPrincipal != null) {
159
160
161
162
163 view.setOwner(userPrincipal);
164 }
165 }
166 if (fileGroup != null) {
167 final GroupPrincipal groupPrincipal = lookupService.lookupPrincipalByGroupName(fileGroup);
168 if (groupPrincipal != null) {
169
170
171 view.setGroup(groupPrincipal);
172 }
173 }
174 if (filePermissions != null) {
175 view.setPermissions(filePermissions);
176 }
177 }
178 }
179
180
181
182
183
184
185 public static boolean isFilePosixAttributeViewSupported() {
186 return FileSystems.getDefault().supportedFileAttributeViews().contains("posix");
187 }
188 }