Lewati ke konten utama

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());
}
}