Mandiri
Ringkasan - mandiri
Ringkasan file standalone dapat dibuat dengan membuat objek com.glasswall.analysissummary.FileSummary.
API
Konstruktor
public FileSummary(
Path inputFilePath,
int sessionStatus,
String lastErrorMessage,
String processMessage,
InputStream analysisInputStream,
boolean skipUnsupportedFileTypes
) throws SAXException, ParserConfigurationException, IOException
Parameter:
Path inputFilePath- Jalur file dari file yang diproses.int sessionStatus- Status pengembalian dari GW2RunSession.String lastErrorMessage- Pesan kesalahan dari GW2FileErrorMsg. Jika ini null atau kosong maka ini tidak akan disertakan dalam ringkasan.String processMessage- Pesan proses dari GW2FileSessionStatus. Jika ini null atau kosong maka ini tidak akan disertakan dalam ringkasan.InputStream analysisInputStream- Aliran input yang berisi laporan analisis untuk disertakan.boolean skipUnsupportedFileTypes- boolean yang menunjukkan apakah tipe file yang tidak didukung harus dilewati.
Metode instance
public String getFileName()
Mengembalikan nama file dari file yang diproses.
Mengembalikan: Path file absolut dari file yang diproses.
public String getProcessMessage()
Mengembalikan pesan proses sesi file. Nilainya akan null jika pesan proses tidak ditentukan.
Mengembalikan: Pesan proses sesi file.
public EngineOutcome getEngineOutcome()
Mengembalikan enum EngineOutcome yang menunjukkan apakah file yang diproses adalah Managed, NonConforming, atau Unsupported.
Mengembalikan:
Enum EngineOutcome.
public String getErrorMessage()
Mengembalikan pesan kesalahan jika file bersifat non-conforming. Nilainya akan null jika file dikelola.
Hasil: Pesan kesalahan.
public Map<String, Long> getSanitisedItems()
Mengembalikan map item yang telah disanitasi beserta jumlahnya.
Hasil: Map item yang telah disanitasi beserta jumlahnya.
public Map<String, Long> getAllowedItems()
Mengembalikan map item yang diizinkan beserta jumlahnya.
Hasil: Map item yang diizinkan beserta jumlahnya.
public Map<String, Long> getRemedyItems()
Mengembalikan map item remedy beserta jumlahnya.
Hasil: Map item remedy beserta jumlahnya.
Contoh API
File input_directory = new File("Input");
File output_directory = new File("Output");
output_directory.mkdirs();
for (File file : input_directory.listFiles())
{
if (file.isDirectory())
continue;
try (Core2JavaBridge gw = new Core2JavaBridge())
{
// Create the output path for file and analysis report
String file_output_path = Paths.get(output_directory.getAbsolutePath().toString(), file.getName()).toString();
String analysis_output_path = file_output_path + ".xml";
// Run the file through the Glasswall engine
int session = gw.GW2OpenSession();
gw.GW2RegisterInputFile(session, file.getAbsolutePath());
gw.GW2RegisterAnalysisFile(session, analysis_output_path, 0);
gw.GW2RegisterOutFile(session, file_output_path);
int run_status = gw.GW2RunSession(session);
// Retrieve the error message if the file is non-conforming
String error_message = null;
if (run_status < 0)
error_message = gw.GW2FileErrorMsgString(session);
// Retrieve the session status along with the session description
FileSessionStatus session_status = gw.GW2FileSessionStatusResult(session);
// Create a file summary
try (FileInputStream stream = new FileInputStream(analysis_output_path))
{
FileSummary file_summary = new FileSummary(
file.toPath(),
run_status,
error_message,
session_status.summaryDescription,
stream,
true // true to skip unsupported file types
);
// TODO - do something with the file summary
}
}
catch (Exception ex)
{
System.err.println("Exception occurred: " + ex.getMessage());
}
}