JobResult.java
5.64 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
/*
* Decompiled with CFR 0_118.
*
* Could not load the following classes:
* com.adobe.pdfg.logging.PDFGLogger
*/
package com.adobe.pdfg.common;
import com.adobe.pdfg.common.FileUtilities;
import com.adobe.pdfg.logging.PDFGLogger;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.FilenameFilter;
import java.io.IOException;
public class JobResult {
public static final String RESULT_FILE_NAME = "_done_";
public static final String ERROR_FILE_NAME = "_error_";
public static final String DELETE_FILE_NAME = "_delete_";
public static final String DEST_DIR = "destdir";
private static final int GENERIC_ERROR = -1;
private static final PDFGLogger logger = PDFGLogger.getPDFGLogger(JobResult.class);
public static File getJobDestDir(String jobID) {
return JobResult.getJobDestDir(FileUtilities.getGuidDir(jobID));
}
public static File getJobDestDir(File parentDir) {
return new File(parentDir, "destdir");
}
public static File createJobDestDir(String jobID) {
File destdir = new File(FileUtilities.getGuidDir(jobID), "destdir");
destdir.mkdirs();
return destdir;
}
public static void setJobDone(String jobID) throws IOException {
File destdir = JobResult.getJobDestDir(jobID);
File donefile = new File(destdir, "_done_");
donefile.createNewFile();
}
public static boolean isJobDone(String jobID) {
File rootdir = FileUtilities.getGuidDir(jobID);
File destdir = new File(rootdir, "destdir");
File[] files = destdir.listFiles(new FilenameFilter(){
public boolean accept(File dir, String name) {
return name.equals("_done_");
}
});
return files.length > 0;
}
public static boolean deleteJobFiles(String jobID) {
File directory = FileUtilities.getGuidDir(jobID);
return FileUtilities.deleteDir(directory);
}
public static void cleanupJobFiles(String jobId) {
File directory = FileUtilities.getGuidDir(jobId);
File[] files = directory.listFiles();
if (files != null && files.length > 0) {
for (int count = 0; count < files.length; ++count) {
String name;
File candidate = files[count];
if (!candidate.isFile() || "_done_".equals(name = candidate.getName()) || "_error_".equals(name) || "_delete_".equals(name) || candidate.delete()) continue;
logger.debug("Unable to cleanup file: " + candidate.getAbsolutePath());
}
}
}
public static boolean isJobDeleted(String jobID) {
boolean result = false;
if (!JobResult.isJobDirectoryExtant(jobID)) {
result = true;
} else {
File deletefile = JobResult.getDeleteFile(jobID);
result = deletefile.exists();
}
return result;
}
private static File getDeleteFile(String jobID) {
File deletefile = new File(FileUtilities.getGuidDir(jobID), "_delete_");
return deletefile;
}
public static boolean isJobDirectoryExtant(String jobId) {
File rootdir = FileUtilities.getGuidDir(jobId);
boolean result = rootdir.exists();
return result;
}
public static boolean markJobDeleted(String jobID) throws IOException {
File deletefile = JobResult.getDeleteFile(jobID);
deletefile.createNewFile();
return true;
}
public static boolean hasJobError(String jobID) {
File destdir = JobResult.getJobDestDir(jobID);
File errorfile = new File(destdir, "_error_");
return errorfile.exists();
}
public static void setJobErrCode(String jobID, int errCode) throws FileNotFoundException, IOException {
File destdir = JobResult.getJobDestDir(jobID);
File errorFile = new File(destdir, "_error_");
String str = String.valueOf(errCode);
byte[] bytes = str.getBytes("UTF-8");
FileOutputStream fos = new FileOutputStream(errorFile);
fos.write(bytes);
fos.close();
}
public static int getJobErrCode(String jobID) {
int errCode = -1;
try {
if (JobResult.hasJobError(jobID)) {
int tmp;
File destdir = JobResult.getJobDestDir(jobID);
File errorFile = new File(destdir, "_error_");
FileInputStream fis = new FileInputStream(errorFile);
ByteArrayOutputStream baos = new ByteArrayOutputStream();
while ((tmp = fis.read()) != -1) {
baos.write(tmp);
}
fis.close();
String errCodeStr = new String(baos.toByteArray());
errCode = Integer.parseInt(errCodeStr);
}
}
catch (Exception e) {
logger.debug(e.getMessage(), null, (Throwable)e);
}
return errCode;
}
public static String displayTime(long msec) {
long sec = 0;
long min = 0;
long hr = 0;
if (msec < 1000) {
return "" + msec + " millisecs";
}
sec = msec / 1000;
msec %= 1000;
if (sec >= 60) {
min = sec / 60;
sec %= 60;
if (min >= 60) {
hr = min / 60;
min %= 60;
}
}
String tmStr = "" + sec + "." + msec + " secs";
if (min > 0) {
tmStr = "" + min + " min " + tmStr;
}
if (hr > 0) {
tmStr = "" + hr + " hr " + tmStr;
}
return tmStr;
}
}