1 package org
.asamk
.signal
.util
;
4 import java
.io
.IOException
;
5 import java
.io
.InputStream
;
6 import java
.io
.StringWriter
;
7 import java
.nio
.charset
.Charset
;
8 import java
.nio
.file
.Files
;
9 import java
.nio
.file
.Path
;
10 import java
.nio
.file
.attribute
.PosixFilePermission
;
11 import java
.nio
.file
.attribute
.PosixFilePermissions
;
12 import java
.util
.EnumSet
;
15 import static java
.nio
.file
.attribute
.PosixFilePermission
.OWNER_EXECUTE
;
16 import static java
.nio
.file
.attribute
.PosixFilePermission
.OWNER_READ
;
17 import static java
.nio
.file
.attribute
.PosixFilePermission
.OWNER_WRITE
;
19 public class IOUtils
{
24 public static File
createTempFile() throws IOException
{
25 return File
.createTempFile("signal_tmp_", ".tmp");
28 public static String
readAll(InputStream
in, Charset charset
) throws IOException
{
29 StringWriter output
= new StringWriter();
30 byte[] buffer
= new byte[4096];
32 while (-1 != (n
= in.read(buffer
))) {
33 output
.write(new String(buffer
, 0, n
, charset
));
35 return output
.toString();
38 public static void createPrivateDirectories(String directoryPath
) throws IOException
{
39 final File file
= new File(directoryPath
);
44 final Path path
= file
.toPath();
46 Set
<PosixFilePermission
> perms
= EnumSet
.of(OWNER_READ
, OWNER_WRITE
, OWNER_EXECUTE
);
47 Files
.createDirectories(path
, PosixFilePermissions
.asFileAttribute(perms
));
48 } catch (UnsupportedOperationException e
) {
49 Files
.createDirectories(path
);
53 public static void createPrivateFile(String path
) throws IOException
{
54 final Path file
= new File(path
).toPath();
56 Set
<PosixFilePermission
> perms
= EnumSet
.of(OWNER_READ
, OWNER_WRITE
);
57 Files
.createFile(file
, PosixFilePermissions
.asFileAttribute(perms
));
58 } catch (UnsupportedOperationException e
) {
59 Files
.createFile(file
);
63 public static String
getDataHomeDir() {
64 String dataHome
= System
.getenv("XDG_DATA_HOME");
65 if (dataHome
!= null) {
69 return System
.getProperty("user.home") + "/.local/share";