mirror of
https://github.com/overcuriousity/autopsy-flatpak.git
synced 2025-07-15 09:17:42 +00:00
Marked internal/log/exception strings with NOI18N.
Created Bundle_ja.properties.
This commit is contained in:
parent
e2615c3f93
commit
2a851dd267
@ -57,7 +57,7 @@ class AndroidIngestModule implements DataSourceIngestModule {
|
||||
return IngestModule.ProcessResult.OK;
|
||||
}
|
||||
} catch (Exception e) {
|
||||
errors.add("Error getting Contacts");
|
||||
errors.add("Error getting Contacts"); //NOI18N
|
||||
}
|
||||
|
||||
try {
|
||||
@ -67,7 +67,7 @@ class AndroidIngestModule implements DataSourceIngestModule {
|
||||
return IngestModule.ProcessResult.OK;
|
||||
}
|
||||
} catch (Exception e) {
|
||||
errors.add("Error getting Call Logs");
|
||||
errors.add("Error getting Call Logs"); //NOI18N
|
||||
}
|
||||
|
||||
try {
|
||||
@ -77,7 +77,7 @@ class AndroidIngestModule implements DataSourceIngestModule {
|
||||
return IngestModule.ProcessResult.OK;
|
||||
}
|
||||
} catch (Exception e) {
|
||||
errors.add("Error getting Text Messages");
|
||||
errors.add("Error getting Text Messages"); //NOI18N
|
||||
}
|
||||
|
||||
try {
|
||||
@ -87,7 +87,7 @@ class AndroidIngestModule implements DataSourceIngestModule {
|
||||
return IngestModule.ProcessResult.OK;
|
||||
}
|
||||
} catch (Exception e) {
|
||||
errors.add("Error getting Tango Messages");
|
||||
errors.add("Error getting Tango Messages"); //NOI18N
|
||||
}
|
||||
|
||||
try {
|
||||
@ -97,7 +97,7 @@ class AndroidIngestModule implements DataSourceIngestModule {
|
||||
return IngestModule.ProcessResult.OK;
|
||||
}
|
||||
} catch (Exception e) {
|
||||
errors.add("Error getting Words with Friends Messages");
|
||||
errors.add("Error getting Words with Friends Messages"); //NOI18N
|
||||
}
|
||||
|
||||
try {
|
||||
@ -107,7 +107,7 @@ class AndroidIngestModule implements DataSourceIngestModule {
|
||||
return IngestModule.ProcessResult.OK;
|
||||
}
|
||||
} catch (Exception e) {
|
||||
errors.add("Error getting Google Map Locations");
|
||||
errors.add("Error getting Google Map Locations"); //NOI18N
|
||||
}
|
||||
|
||||
try {
|
||||
@ -117,14 +117,14 @@ class AndroidIngestModule implements DataSourceIngestModule {
|
||||
return IngestModule.ProcessResult.OK;
|
||||
}
|
||||
} catch (Exception e) {
|
||||
errors.add("Error getting Browser Locations");
|
||||
errors.add("Error getting Browser Locations"); //NOI18N
|
||||
}
|
||||
|
||||
try {
|
||||
CacheLocationAnalyzer.findGeoLocations();
|
||||
progressBar.progress(8);
|
||||
} catch (Exception e) {
|
||||
errors.add("Error getting Cache Locations");
|
||||
errors.add("Error getting Cache Locations"); //NOI18N
|
||||
}
|
||||
|
||||
// create the final message for inbox
|
||||
@ -133,20 +133,20 @@ class AndroidIngestModule implements DataSourceIngestModule {
|
||||
IngestMessage.MessageType msgLevel = IngestMessage.MessageType.INFO;
|
||||
if (errors.isEmpty() == false) {
|
||||
msgLevel = IngestMessage.MessageType.ERROR;
|
||||
errorMessage.append("Errors were encountered");
|
||||
errorMessage.append("Errors were encountered"); //NOI18N
|
||||
for (String msg : errors) {
|
||||
errorMessage.append("<li>").append(msg).append("</li>\n"); //NON-NLS
|
||||
}
|
||||
errorMessage.append("</ul>\n"); //NON-NLS
|
||||
|
||||
if (errors.size() == 1) {
|
||||
errorMsgSubject = "One error was found";
|
||||
errorMsgSubject = "One error was found"; //NOI18N
|
||||
} else {
|
||||
errorMsgSubject = "errors found: " + errors.size();
|
||||
errorMsgSubject = "errors found: " + errors.size(); //NOI18N
|
||||
}
|
||||
} else {
|
||||
errorMessage.append("No errors");
|
||||
errorMsgSubject = "No errors";
|
||||
errorMessage.append("No errors"); //NOI18N
|
||||
errorMsgSubject = "No errors"; //NOI18N
|
||||
}
|
||||
|
||||
services.postMessage(IngestMessage.createMessage(msgLevel, AndroidModuleFactory.getModuleName(), "Finished Analysis: " + errorMsgSubject, errorMessage.toString()));
|
||||
|
@ -43,7 +43,7 @@ class BrowserLocationAnalyzer {
|
||||
public static void findGeoLocations() {
|
||||
try {
|
||||
SleuthkitCase skCase = Case.getCurrentCase().getSleuthkitCase();
|
||||
List<AbstractFile> abstractFiles = skCase.findAllFilesWhere("name LIKE 'CachedGeoposition%.db'"); //get exact file names
|
||||
List<AbstractFile> abstractFiles = skCase.findAllFilesWhere("name LIKE 'CachedGeoposition%.db'"); //NOI18N //get exact file names
|
||||
|
||||
for (AbstractFile abstractFile : abstractFiles) {
|
||||
try {
|
||||
@ -54,11 +54,11 @@ class BrowserLocationAnalyzer {
|
||||
ContentUtils.writeToFile(abstractFile, jFile);
|
||||
findGeoLocationsInDB(jFile.toString(), abstractFile);
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error parsing Browser Location files", e);
|
||||
logger.log(Level.SEVERE, "Error parsing Browser Location files", e); //NOI18N
|
||||
}
|
||||
}
|
||||
} catch (TskCoreException e) {
|
||||
logger.log(Level.SEVERE, "Error finding Browser Location files", e);
|
||||
logger.log(Level.SEVERE, "Error finding Browser Location files", e); //NOI18N
|
||||
|
||||
}
|
||||
}
|
||||
@ -71,22 +71,22 @@ class BrowserLocationAnalyzer {
|
||||
return;
|
||||
}
|
||||
try {
|
||||
Class.forName("org.sqlite.JDBC"); //load JDBC driver
|
||||
connection = DriverManager.getConnection("jdbc:sqlite:" + DatabasePath);
|
||||
Class.forName("org.sqlite.JDBC"); //NOI18N //load JDBC driver
|
||||
connection = DriverManager.getConnection("jdbc:sqlite:" + DatabasePath); //NOI18N
|
||||
statement = connection.createStatement();
|
||||
} catch (ClassNotFoundException | SQLException e) {
|
||||
logger.log(Level.SEVERE, "Error connecting to sql database", e);
|
||||
logger.log(Level.SEVERE, "Error connecting to sql database", e); //NOI18N
|
||||
return;
|
||||
}
|
||||
|
||||
try {
|
||||
resultSet = statement.executeQuery(
|
||||
"Select timestamp, latitude, longitude, accuracy FROM CachedPosition;");
|
||||
"Select timestamp, latitude, longitude, accuracy FROM CachedPosition;"); //NOI18N
|
||||
|
||||
while (resultSet.next()) {
|
||||
Long timestamp = Long.valueOf(resultSet.getString("timestamp")) / 1000;
|
||||
double latitude = Double.valueOf(resultSet.getString("latitude"));
|
||||
double longitude = Double.valueOf(resultSet.getString("longitude"));
|
||||
Long timestamp = Long.valueOf(resultSet.getString("timestamp")) / 1000; //NOI18N
|
||||
double latitude = Double.valueOf(resultSet.getString("latitude")); //NOI18N
|
||||
double longitude = Double.valueOf(resultSet.getString("longitude")); //NOI18N
|
||||
|
||||
BlackboardArtifact bba = f.newArtifact(BlackboardArtifact.ARTIFACT_TYPE.TSK_GPS_TRACKPOINT);
|
||||
bba.addAttribute(new BlackboardAttribute(BlackboardAttribute.ATTRIBUTE_TYPE.TSK_GEO_LATITUDE.getTypeID(), moduleName, latitude));
|
||||
@ -96,7 +96,7 @@ class BrowserLocationAnalyzer {
|
||||
// bba.addAttribute(new BlackboardAttribute(BlackboardAttribute.ATTRIBUTE_TYPE.TSK_VALUE.getTypeID(),moduleName, accuracy));
|
||||
}
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error Putting artifacts to Blackboard", e);
|
||||
logger.log(Level.SEVERE, "Error Putting artifacts to Blackboard", e); //NOI18N
|
||||
} finally {
|
||||
try {
|
||||
if (resultSet != null) {
|
||||
@ -105,7 +105,7 @@ class BrowserLocationAnalyzer {
|
||||
statement.close();
|
||||
connection.close();
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error closing database", e);
|
||||
logger.log(Level.SEVERE, "Error closing database", e); //NOI18N
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -43,7 +43,7 @@ class CacheLocationAnalyzer {
|
||||
|
||||
try {
|
||||
SleuthkitCase skCase = Case.getCurrentCase().getSleuthkitCase();
|
||||
List<AbstractFile> abstractFiles = skCase.findAllFilesWhere("name ='cache.cell' OR name='cache.wifi'"); //get exact file names
|
||||
List<AbstractFile> abstractFiles = skCase.findAllFilesWhere("name ='cache.cell' OR name='cache.wifi'"); //NOI18N //get exact file names
|
||||
|
||||
for (AbstractFile abstractFile : abstractFiles) {
|
||||
try {
|
||||
@ -55,11 +55,11 @@ class CacheLocationAnalyzer {
|
||||
|
||||
findGeoLocationsInFile(jFile, abstractFile);
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error parsing cached Location files", e);
|
||||
logger.log(Level.SEVERE, "Error parsing cached Location files", e); //NOI18N
|
||||
}
|
||||
}
|
||||
} catch (TskCoreException e) {
|
||||
logger.log(Level.SEVERE, "Error finding cached Location files", e);
|
||||
logger.log(Level.SEVERE, "Error finding cached Location files", e); //NOI18N
|
||||
}
|
||||
}
|
||||
|
||||
@ -124,7 +124,7 @@ class CacheLocationAnalyzer {
|
||||
}
|
||||
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error parsing Cached GPS locations to Blackboard", e);
|
||||
logger.log(Level.SEVERE, "Error parsing Cached GPS locations to Blackboard", e); //NOI18N
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -47,11 +47,11 @@ class CallLogAnalyzer {
|
||||
|
||||
/** the where clause(without 'where' of sql select statement to choose call
|
||||
* log dbs, update the list of file names to include more files */
|
||||
private static final String fileNameQuery = Stream.of("'logs.db'", "'contacts2.db'", "'contacts.db'")
|
||||
.collect(Collectors.joining(" OR name = ", "name = ", ""));
|
||||
private static final String fileNameQuery = Stream.of("'logs.db'", "'contacts2.db'", "'contacts.db'") //NOI18N
|
||||
.collect(Collectors.joining(" OR name = ", "name = ", "")); //NOI18N
|
||||
|
||||
/** the names of tables that potentially hold call logs in the dbs */
|
||||
private static final Iterable<String> tableNames = Arrays.asList("calls", "logs");
|
||||
private static final Iterable<String> tableNames = Arrays.asList("calls", "logs"); //NOI18N
|
||||
|
||||
public static void findCallLogs() {
|
||||
try {
|
||||
@ -63,11 +63,11 @@ class CallLogAnalyzer {
|
||||
ContentUtils.writeToFile(abstractFile, file);
|
||||
findCallLogsInDB(file.toString(), abstractFile);
|
||||
} catch (IOException e) {
|
||||
logger.log(Level.SEVERE, "Error writing temporary call log db to disk", e);
|
||||
logger.log(Level.SEVERE, "Error writing temporary call log db to disk", e); //NOI18N
|
||||
}
|
||||
}
|
||||
} catch (TskCoreException e) {
|
||||
logger.log(Level.SEVERE, "Error finding call logs", e);
|
||||
logger.log(Level.SEVERE, "Error finding call logs", e); //NOI18N
|
||||
}
|
||||
}
|
||||
|
||||
@ -76,20 +76,20 @@ class CallLogAnalyzer {
|
||||
if (DatabasePath == null || DatabasePath.isEmpty()) {
|
||||
return;
|
||||
}
|
||||
try (Connection connection = DriverManager.getConnection("jdbc:sqlite:" + DatabasePath);
|
||||
try (Connection connection = DriverManager.getConnection("jdbc:sqlite:" + DatabasePath); //NOI18N
|
||||
Statement statement = connection.createStatement();) {
|
||||
|
||||
for (String tableName : tableNames) {
|
||||
try (ResultSet resultSet = statement.executeQuery(
|
||||
"SELECT number,date,duration,type, name FROM " + tableName + " ORDER BY date DESC;");) {
|
||||
logger.log(Level.INFO, "Reading call log from table {0} in db {1}", new Object[]{tableName, DatabasePath});
|
||||
"SELECT number,date,duration,type, name FROM " + tableName + " ORDER BY date DESC;");) { //NOI18N
|
||||
logger.log(Level.INFO, "Reading call log from table {0} in db {1}", new Object[]{tableName, DatabasePath}); //NOI18N
|
||||
while (resultSet.next()) {
|
||||
Long date = resultSet.getLong("date") / 1000;
|
||||
final CallDirection direction = CallDirection.fromType(resultSet.getInt("type"));
|
||||
final CallDirection direction = CallDirection.fromType(resultSet.getInt("type")); //NOI18N
|
||||
String directionString = direction != null ? direction.getDisplayName() : "";
|
||||
final String number = resultSet.getString("number");
|
||||
final long duration = resultSet.getLong("duration");//duration of call is in seconds
|
||||
final String name = resultSet.getString("name");// name of person dialed or called. null if unregistered
|
||||
final String number = resultSet.getString("number"); //NOI18N
|
||||
final long duration = resultSet.getLong("duration"); //NOI18N //duration of call is in seconds
|
||||
final String name = resultSet.getString("name"); //NOI18N // name of person dialed or called. null if unregistered
|
||||
|
||||
try {
|
||||
BlackboardArtifact bba = f.newArtifact(BlackboardArtifact.ARTIFACT_TYPE.TSK_CALLLOG); //create a call log and then add attributes from result set.
|
||||
@ -104,21 +104,21 @@ class CallLogAnalyzer {
|
||||
bba.addAttribute(new BlackboardAttribute(ATTRIBUTE_TYPE.TSK_DIRECTION.getTypeID(), moduleName, directionString));
|
||||
bba.addAttribute(new BlackboardAttribute(ATTRIBUTE_TYPE.TSK_NAME.getTypeID(), moduleName, name));
|
||||
} catch (TskCoreException ex) {
|
||||
logger.log(Level.SEVERE, "Error posting call log record to the Blackboard", ex);
|
||||
logger.log(Level.SEVERE, "Error posting call log record to the Blackboard", ex); //NOI18N
|
||||
}
|
||||
}
|
||||
} catch (SQLException e) {
|
||||
logger.log(Level.WARNING, "Could not read table {0} in db {1}", new Object[]{tableName, DatabasePath});
|
||||
logger.log(Level.WARNING, "Could not read table {0} in db {1}", new Object[]{tableName, DatabasePath}); //NOI18N
|
||||
}
|
||||
}
|
||||
} catch (SQLException e) {
|
||||
logger.log(Level.SEVERE, "Could not parse call log; error connecting to db " + DatabasePath, e);
|
||||
logger.log(Level.SEVERE, "Could not parse call log; error connecting to db " + DatabasePath, e); //NOI18N
|
||||
}
|
||||
}
|
||||
|
||||
private static enum CallDirection {
|
||||
|
||||
INCOMING(1, "Incoming"), OUTGOING(2, "Outgoing"), MISSED(3, "Missed");
|
||||
INCOMING(1, "Incoming"), OUTGOING(2, "Outgoing"), MISSED(3, "Missed"); //NOI18N
|
||||
|
||||
private final int type;
|
||||
|
||||
|
@ -45,7 +45,7 @@ class ContactAnalyzer {
|
||||
List<AbstractFile> absFiles;
|
||||
try {
|
||||
SleuthkitCase skCase = Case.getCurrentCase().getSleuthkitCase();
|
||||
absFiles = skCase.findAllFilesWhere("name ='contacts2.db' OR name ='contacts.db'"); //get exact file names
|
||||
absFiles = skCase.findAllFilesWhere("name ='contacts2.db' OR name ='contacts.db'"); //NOI18N //get exact file names
|
||||
if (absFiles.isEmpty()) {
|
||||
return;
|
||||
}
|
||||
@ -55,11 +55,11 @@ class ContactAnalyzer {
|
||||
ContentUtils.writeToFile(AF, jFile);
|
||||
findContactsInDB(jFile.toString(), AF);
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error parsing Contacts", e);
|
||||
logger.log(Level.SEVERE, "Error parsing Contacts", e); //NOI18N
|
||||
}
|
||||
}
|
||||
} catch (TskCoreException e) {
|
||||
logger.log(Level.SEVERE, "Error finding Contacts", e);
|
||||
logger.log(Level.SEVERE, "Error finding Contacts", e); //NOI18N
|
||||
}
|
||||
}
|
||||
|
||||
@ -78,11 +78,11 @@ class ContactAnalyzer {
|
||||
return;
|
||||
}
|
||||
try {
|
||||
Class.forName("org.sqlite.JDBC"); //load JDBC driver
|
||||
connection = DriverManager.getConnection("jdbc:sqlite:" + DatabasePath);
|
||||
Class.forName("org.sqlite.JDBC"); //NOI18N //load JDBC driver
|
||||
connection = DriverManager.getConnection("jdbc:sqlite:" + DatabasePath); //NOI18N
|
||||
statement = connection.createStatement();
|
||||
} catch (ClassNotFoundException | SQLException e) {
|
||||
logger.log(Level.SEVERE, "Error opening database", e);
|
||||
logger.log(Level.SEVERE, "Error opening database", e); //NOI18N
|
||||
return;
|
||||
}
|
||||
|
||||
@ -90,13 +90,13 @@ class ContactAnalyzer {
|
||||
// get display_name, mimetype(email or phone number) and data1 (phonenumber or email address depending on mimetype)
|
||||
//sorted by name, so phonenumber/email would be consecutive for a person if they exist.
|
||||
resultSet = statement.executeQuery(
|
||||
"SELECT mimetype,data1, name_raw_contact.display_name AS display_name \n"
|
||||
+ "FROM raw_contacts JOIN contacts ON (raw_contacts.contact_id=contacts._id) \n"
|
||||
+ "JOIN raw_contacts AS name_raw_contact ON(name_raw_contact_id=name_raw_contact._id) "
|
||||
+ "LEFT OUTER JOIN data ON (data.raw_contact_id=raw_contacts._id) \n"
|
||||
+ "LEFT OUTER JOIN mimetypes ON (data.mimetype_id=mimetypes._id) \n"
|
||||
+ "WHERE mimetype = 'vnd.android.cursor.item/phone_v2' OR mimetype = 'vnd.android.cursor.item/email_v2'\n"
|
||||
+ "ORDER BY name_raw_contact.display_name ASC;");
|
||||
"SELECT mimetype,data1, name_raw_contact.display_name AS display_name \n" //NOI18N
|
||||
+ "FROM raw_contacts JOIN contacts ON (raw_contacts.contact_id=contacts._id) \n" //NOI18N
|
||||
+ "JOIN raw_contacts AS name_raw_contact ON(name_raw_contact_id=name_raw_contact._id) " //NOI18N
|
||||
+ "LEFT OUTER JOIN data ON (data.raw_contact_id=raw_contacts._id) \n" //NOI18N
|
||||
+ "LEFT OUTER JOIN mimetypes ON (data.mimetype_id=mimetypes._id) \n" //NOI18N
|
||||
+ "WHERE mimetype = 'vnd.android.cursor.item/phone_v2' OR mimetype = 'vnd.android.cursor.item/email_v2'\n" //NOI18N
|
||||
+ "ORDER BY name_raw_contact.display_name ASC;"); //NOI18N
|
||||
|
||||
BlackboardArtifact bba;
|
||||
bba = f.newArtifact(BlackboardArtifact.ARTIFACT_TYPE.TSK_CONTACT);
|
||||
@ -105,15 +105,15 @@ class ContactAnalyzer {
|
||||
String mimetype; // either phone or email
|
||||
String data1; // the phone number or email
|
||||
while (resultSet.next()) {
|
||||
name = resultSet.getString("display_name");
|
||||
data1 = resultSet.getString("data1");
|
||||
mimetype = resultSet.getString("mimetype");
|
||||
name = resultSet.getString("display_name"); //NOI18N
|
||||
data1 = resultSet.getString("data1"); //NOI18N
|
||||
mimetype = resultSet.getString("mimetype"); //NOI18N
|
||||
// System.out.println(resultSet.getString("data1") + resultSet.getString("mimetype") + resultSet.getString("display_name")); //Test code
|
||||
if (name.equals(oldName) == false) {
|
||||
bba = f.newArtifact(BlackboardArtifact.ARTIFACT_TYPE.TSK_CONTACT);
|
||||
bba.addAttribute(new BlackboardAttribute(BlackboardAttribute.ATTRIBUTE_TYPE.TSK_NAME.getTypeID(), moduleName, name));
|
||||
}
|
||||
if (mimetype.equals("vnd.android.cursor.item/phone_v2")) {
|
||||
if (mimetype.equals("vnd.android.cursor.item/phone_v2")) { //NOI18N
|
||||
bba.addAttribute(new BlackboardAttribute(BlackboardAttribute.ATTRIBUTE_TYPE.TSK_PHONE_NUMBER.getTypeID(), moduleName, data1));
|
||||
} else {
|
||||
bba.addAttribute(new BlackboardAttribute(BlackboardAttribute.ATTRIBUTE_TYPE.TSK_EMAIL.getTypeID(), moduleName, data1));
|
||||
@ -122,7 +122,7 @@ class ContactAnalyzer {
|
||||
}
|
||||
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error parsing Contacts to Blackboard", e);
|
||||
logger.log(Level.SEVERE, "Error parsing Contacts to Blackboard", e); //NOI18N
|
||||
} finally {
|
||||
try {
|
||||
if (resultSet != null) {
|
||||
@ -131,7 +131,7 @@ class ContactAnalyzer {
|
||||
statement.close();
|
||||
connection.close();
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error closing database", e);
|
||||
logger.log(Level.SEVERE, "Error closing database", e); //NOI18N
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -44,7 +44,7 @@ class GoogleMapLocationAnalyzer {
|
||||
List<AbstractFile> absFiles;
|
||||
try {
|
||||
SleuthkitCase skCase = Case.getCurrentCase().getSleuthkitCase();
|
||||
absFiles = skCase.findAllFilesWhere("name ='da_destination_history'"); //get exact file name
|
||||
absFiles = skCase.findAllFilesWhere("name ='da_destination_history'"); //NOI18N //get exact file name
|
||||
if (absFiles.isEmpty()) {
|
||||
return;
|
||||
}
|
||||
@ -54,11 +54,11 @@ class GoogleMapLocationAnalyzer {
|
||||
ContentUtils.writeToFile(abstractFile, jFile);
|
||||
findGeoLocationsInDB(jFile.toString(), abstractFile);
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error parsing Google map locations", e);
|
||||
logger.log(Level.SEVERE, "Error parsing Google map locations", e); //NOI18N
|
||||
}
|
||||
}
|
||||
} catch (TskCoreException e) {
|
||||
logger.log(Level.SEVERE, "Error finding Google map locations", e);
|
||||
logger.log(Level.SEVERE, "Error finding Google map locations", e); //NOI18N
|
||||
}
|
||||
}
|
||||
|
||||
@ -71,27 +71,27 @@ class GoogleMapLocationAnalyzer {
|
||||
return;
|
||||
}
|
||||
try {
|
||||
Class.forName("org.sqlite.JDBC"); //load JDBC driver
|
||||
connection = DriverManager.getConnection("jdbc:sqlite:" + DatabasePath);
|
||||
Class.forName("org.sqlite.JDBC"); //NOI18N //load JDBC driver
|
||||
connection = DriverManager.getConnection("jdbc:sqlite:" + DatabasePath); //NOI18N
|
||||
statement = connection.createStatement();
|
||||
} catch (ClassNotFoundException | SQLException e) {
|
||||
logger.log(Level.SEVERE, "Error opening database", e);
|
||||
logger.log(Level.SEVERE, "Error opening database", e); //NOI18N
|
||||
return;
|
||||
}
|
||||
|
||||
try {
|
||||
resultSet = statement.executeQuery(
|
||||
"Select time,dest_lat,dest_lng,dest_title,dest_address,source_lat,source_lng FROM destination_history;");
|
||||
"Select time,dest_lat,dest_lng,dest_title,dest_address,source_lat,source_lng FROM destination_history;"); //NOI18N
|
||||
|
||||
while (resultSet.next()) {
|
||||
Long time = Long.valueOf(resultSet.getString("time")) / 1000;
|
||||
String dest_title = resultSet.getString("dest_title");
|
||||
String dest_address = resultSet.getString("dest_address");
|
||||
Long time = Long.valueOf(resultSet.getString("time")) / 1000; //NOI18N
|
||||
String dest_title = resultSet.getString("dest_title"); //NOI18N
|
||||
String dest_address = resultSet.getString("dest_address"); //NOI18N
|
||||
|
||||
double dest_lat = convertGeo(resultSet.getString("dest_lat"));
|
||||
double dest_lng = convertGeo(resultSet.getString("dest_lng"));
|
||||
double source_lat = convertGeo(resultSet.getString("source_lat"));
|
||||
double source_lng = convertGeo(resultSet.getString("source_lng"));
|
||||
double dest_lat = convertGeo(resultSet.getString("dest_lat")); //NOI18N
|
||||
double dest_lng = convertGeo(resultSet.getString("dest_lng")); //NOI18N
|
||||
double source_lat = convertGeo(resultSet.getString("source_lat")); //NOI18N
|
||||
double source_lng = convertGeo(resultSet.getString("source_lng")); //NOI18N
|
||||
|
||||
|
||||
// bba = f.newArtifact(BlackboardArtifact.ARTIFACT_TYPE.TSK_GPS_TRACKPOINT);//src
|
||||
@ -123,7 +123,7 @@ class GoogleMapLocationAnalyzer {
|
||||
}
|
||||
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error parsing Google map locations to the Blackboard", e);
|
||||
logger.log(Level.SEVERE, "Error parsing Google map locations to the Blackboard", e); //NOI18N
|
||||
} finally {
|
||||
try {
|
||||
if (resultSet != null) {
|
||||
@ -132,7 +132,7 @@ class GoogleMapLocationAnalyzer {
|
||||
statement.close();
|
||||
connection.close();
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error closing the database", e);
|
||||
logger.log(Level.SEVERE, "Error closing the database", e); //NOI18N
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -45,18 +45,18 @@ class TangoMessageAnalyzer {
|
||||
List<AbstractFile> absFiles;
|
||||
try {
|
||||
SleuthkitCase skCase = Case.getCurrentCase().getSleuthkitCase();
|
||||
absFiles = skCase.findAllFilesWhere("name ='tc.db' "); //get exact file names
|
||||
absFiles = skCase.findAllFilesWhere("name ='tc.db' "); //NOI18N //get exact file names
|
||||
for (AbstractFile abstractFile : absFiles) {
|
||||
try {
|
||||
File jFile = new File(Case.getCurrentCase().getTempDirectory(), abstractFile.getName());
|
||||
ContentUtils.writeToFile(abstractFile, jFile);
|
||||
findTangoMessagesInDB(jFile.toString(), abstractFile);
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error parsing Tango messages", e);
|
||||
logger.log(Level.SEVERE, "Error parsing Tango messages", e); //NOI18N
|
||||
}
|
||||
}
|
||||
} catch (TskCoreException e) {
|
||||
logger.log(Level.SEVERE, "Error finding Tango messages", e);
|
||||
logger.log(Level.SEVERE, "Error finding Tango messages", e); //NOI18N
|
||||
}
|
||||
}
|
||||
|
||||
@ -69,31 +69,31 @@ class TangoMessageAnalyzer {
|
||||
return;
|
||||
}
|
||||
try {
|
||||
Class.forName("org.sqlite.JDBC"); //load JDBC driver
|
||||
connection = DriverManager.getConnection("jdbc:sqlite:" + DatabasePath);
|
||||
Class.forName("org.sqlite.JDBC"); //NOI18N //load JDBC driver
|
||||
connection = DriverManager.getConnection("jdbc:sqlite:" + DatabasePath); //NOI18N
|
||||
statement = connection.createStatement();
|
||||
} catch (ClassNotFoundException | SQLException e) {
|
||||
logger.log(Level.SEVERE, "Error opening database", e);
|
||||
logger.log(Level.SEVERE, "Error opening database", e); //NOI18N
|
||||
return;
|
||||
}
|
||||
|
||||
try {
|
||||
resultSet = statement.executeQuery(
|
||||
"Select conv_id, create_time,direction,payload FROM messages ORDER BY create_time DESC;");
|
||||
"Select conv_id, create_time,direction,payload FROM messages ORDER BY create_time DESC;"); //NOI18N
|
||||
|
||||
String conv_id; // seems to wrap around the message found in payload after decoding from base-64
|
||||
String direction; // 1 incoming, 2 outgoing
|
||||
String payload; // seems to be a base64 message wrapped by the conv_id
|
||||
|
||||
while (resultSet.next()) {
|
||||
conv_id = resultSet.getString("conv_id");
|
||||
Long create_time = Long.valueOf(resultSet.getString("create_time")) / 1000;
|
||||
if (resultSet.getString("direction").equals("1")) {
|
||||
direction = "Incoming";
|
||||
conv_id = resultSet.getString("conv_id"); //NOI18N
|
||||
Long create_time = Long.valueOf(resultSet.getString("create_time")) / 1000; //NOI18N
|
||||
if (resultSet.getString("direction").equals("1")) { //NOI18N
|
||||
direction = "Incoming"; //NOI18N
|
||||
} else {
|
||||
direction = "Outgoing";
|
||||
direction = "Outgoing"; //NOI18N
|
||||
}
|
||||
payload = resultSet.getString("payload");
|
||||
payload = resultSet.getString("payload"); //NOI18N
|
||||
|
||||
BlackboardArtifact bba = f.newArtifact(BlackboardArtifact.ARTIFACT_TYPE.TSK_MESSAGE); //create a call log and then add attributes from result set.
|
||||
bba.addAttribute(new BlackboardAttribute(BlackboardAttribute.ATTRIBUTE_TYPE.TSK_DATETIME.getTypeID(), moduleName, create_time));
|
||||
@ -104,7 +104,7 @@ class TangoMessageAnalyzer {
|
||||
}
|
||||
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error parsing Tango messages to the Blackboard", e);
|
||||
logger.log(Level.SEVERE, "Error parsing Tango messages to the Blackboard", e); //NOI18N
|
||||
} finally {
|
||||
try {
|
||||
if (resultSet != null) {
|
||||
@ -113,7 +113,7 @@ class TangoMessageAnalyzer {
|
||||
statement.close();
|
||||
connection.close();
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error closing database", e);
|
||||
logger.log(Level.SEVERE, "Error closing database", e); //NOI18N
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -126,7 +126,7 @@ class TangoMessageAnalyzer {
|
||||
String Z = new String(decoded, "UTF-8");
|
||||
result = Z.split(wrapper)[1];
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error decoding a Tango message", e);
|
||||
logger.log(Level.SEVERE, "Error decoding a Tango message", e); //NOI18N
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
@ -43,7 +43,7 @@ class TextMessageAnalyzer {
|
||||
public static void findTexts() {
|
||||
try {
|
||||
SleuthkitCase skCase = Case.getCurrentCase().getSleuthkitCase();
|
||||
List<AbstractFile> absFiles = skCase.findAllFilesWhere("name ='mmssms.db'"); //get exact file name
|
||||
List<AbstractFile> absFiles = skCase.findAllFilesWhere("name ='mmssms.db'"); //NOI18N //get exact file name
|
||||
|
||||
for (AbstractFile abstractFile : absFiles) {
|
||||
try {
|
||||
@ -51,11 +51,11 @@ class TextMessageAnalyzer {
|
||||
ContentUtils.writeToFile(abstractFile, jFile);
|
||||
findTextsInDB(jFile.toString(), abstractFile);
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error parsing text messages", e);
|
||||
logger.log(Level.SEVERE, "Error parsing text messages", e); //NOI18N
|
||||
}
|
||||
}
|
||||
} catch (TskCoreException e) {
|
||||
logger.log(Level.SEVERE, "Error finding text messages", e);
|
||||
logger.log(Level.SEVERE, "Error finding text messages", e); //NOI18N
|
||||
}
|
||||
}
|
||||
|
||||
@ -68,17 +68,17 @@ class TextMessageAnalyzer {
|
||||
return;
|
||||
}
|
||||
try {
|
||||
Class.forName("org.sqlite.JDBC"); //load JDBC driver
|
||||
connection = DriverManager.getConnection("jdbc:sqlite:" + DatabasePath);
|
||||
Class.forName("org.sqlite.JDBC"); //NOI18N //load JDBC driver
|
||||
connection = DriverManager.getConnection("jdbc:sqlite:" + DatabasePath); //NOI18N
|
||||
statement = connection.createStatement();
|
||||
} catch (ClassNotFoundException | SQLException e) {
|
||||
logger.log(Level.SEVERE, "Error opening database", e);
|
||||
logger.log(Level.SEVERE, "Error opening database", e); //NOI18N
|
||||
return;
|
||||
}
|
||||
|
||||
try {
|
||||
resultSet = statement.executeQuery(
|
||||
"Select address,date,read,type,subject,body FROM sms;");
|
||||
"Select address,date,read,type,subject,body FROM sms;"); //NOI18N
|
||||
|
||||
String address; // may be phone number, or other addresses
|
||||
|
||||
@ -87,15 +87,15 @@ class TextMessageAnalyzer {
|
||||
Integer read; // may be unread = 0, read = 1
|
||||
String body; //message body
|
||||
while (resultSet.next()) {
|
||||
address = resultSet.getString("address");
|
||||
Long date = Long.valueOf(resultSet.getString("date")) / 1000;
|
||||
address = resultSet.getString("address"); //NOI18N
|
||||
Long date = Long.valueOf(resultSet.getString("date")) / 1000; //NOI18N
|
||||
|
||||
read = resultSet.getInt("read");
|
||||
subject = resultSet.getString("subject");
|
||||
body = resultSet.getString("body");
|
||||
read = resultSet.getInt("read"); //NOI18N
|
||||
subject = resultSet.getString("subject"); //NOI18N
|
||||
body = resultSet.getString("body"); //NOI18N
|
||||
|
||||
BlackboardArtifact bba = f.newArtifact(BlackboardArtifact.ARTIFACT_TYPE.TSK_MESSAGE); //create Message artifact and then add attributes from result set.
|
||||
if (resultSet.getString("type").equals("1")) {
|
||||
if (resultSet.getString("type").equals("1")) { //NOI18N
|
||||
bba.addAttribute(new BlackboardAttribute(BlackboardAttribute.ATTRIBUTE_TYPE.TSK_DIRECTION.getTypeID(), moduleName, "Incoming"));
|
||||
bba.addAttribute(new BlackboardAttribute(BlackboardAttribute.ATTRIBUTE_TYPE.TSK_PHONE_NUMBER_FROM.getTypeID(), moduleName, address));
|
||||
} else {
|
||||
@ -111,7 +111,7 @@ class TextMessageAnalyzer {
|
||||
}
|
||||
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error parsing text messages to Blackboard", e);
|
||||
logger.log(Level.SEVERE, "Error parsing text messages to Blackboard", e); //NOI18N
|
||||
} finally {
|
||||
try {
|
||||
if (resultSet != null) {
|
||||
@ -120,7 +120,7 @@ class TextMessageAnalyzer {
|
||||
statement.close();
|
||||
connection.close();
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error closing database", e);
|
||||
logger.log(Level.SEVERE, "Error closing database", e); //NOI18N
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -44,7 +44,7 @@ class WWFMessageAnalyzer {
|
||||
List<AbstractFile> absFiles;
|
||||
try {
|
||||
SleuthkitCase skCase = Case.getCurrentCase().getSleuthkitCase();
|
||||
absFiles = skCase.findAllFilesWhere("name ='WordsFramework' "); //get exact file names
|
||||
absFiles = skCase.findAllFilesWhere("name ='WordsFramework' "); //NOI18N //get exact file names
|
||||
|
||||
for (AbstractFile abstractFile : absFiles) {
|
||||
try {
|
||||
@ -53,11 +53,11 @@ class WWFMessageAnalyzer {
|
||||
|
||||
findWWFMessagesInDB(jFile.toString(), abstractFile);
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error parsing WWF messages", e);
|
||||
logger.log(Level.SEVERE, "Error parsing WWF messages", e); //NOI18N
|
||||
}
|
||||
}
|
||||
} catch (TskCoreException e) {
|
||||
logger.log(Level.SEVERE, "Error finding WWF messages", e);
|
||||
logger.log(Level.SEVERE, "Error finding WWF messages", e); //NOI18N
|
||||
}
|
||||
}
|
||||
|
||||
@ -74,23 +74,23 @@ class WWFMessageAnalyzer {
|
||||
connection = DriverManager.getConnection("jdbc:sqlite:" + DatabasePath);
|
||||
statement = connection.createStatement();
|
||||
} catch (ClassNotFoundException | SQLException e) {
|
||||
logger.log(Level.SEVERE, "Error opening database", e);
|
||||
logger.log(Level.SEVERE, "Error opening database", e); //NOI18N
|
||||
return;
|
||||
}
|
||||
|
||||
try {
|
||||
resultSet = statement.executeQuery(
|
||||
"SELECT message,strftime('%s' ,created_at) as datetime,user_id,game_id FROM chat_messages ORDER BY game_id DESC, created_at DESC;");
|
||||
"SELECT message,strftime('%s' ,created_at) as datetime,user_id,game_id FROM chat_messages ORDER BY game_id DESC, created_at DESC;"); //NOI18N
|
||||
|
||||
String message; // WWF Message
|
||||
String user_id; // the ID of the user who sent the message.
|
||||
String game_id; // ID of the game which the the message was sent.
|
||||
|
||||
while (resultSet.next()) {
|
||||
message = resultSet.getString("message");
|
||||
Long created_at = resultSet.getLong("datetime");
|
||||
user_id = resultSet.getString("user_id");
|
||||
game_id = resultSet.getString("game_id");
|
||||
message = resultSet.getString("message"); //NOI18N
|
||||
Long created_at = resultSet.getLong("datetime"); //NOI18N
|
||||
user_id = resultSet.getString("user_id"); //NOI18N
|
||||
game_id = resultSet.getString("game_id"); //NOI18N
|
||||
|
||||
BlackboardArtifact bba = f.newArtifact(BlackboardArtifact.ARTIFACT_TYPE.TSK_MESSAGE); //create a call log and then add attributes from result set.
|
||||
bba.addAttribute(new BlackboardAttribute(BlackboardAttribute.ATTRIBUTE_TYPE.TSK_DATETIME.getTypeID(), moduleName, created_at));
|
||||
@ -100,7 +100,7 @@ class WWFMessageAnalyzer {
|
||||
bba.addAttribute(new BlackboardAttribute(BlackboardAttribute.ATTRIBUTE_TYPE.TSK_MESSAGE_TYPE.getTypeID(), moduleName, "Words With Friends Message"));
|
||||
}
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error parsing WWF messages to the Blackboard", e);
|
||||
logger.log(Level.SEVERE, "Error parsing WWF messages to the Blackboard", e); //NOI18N
|
||||
} finally {
|
||||
try {
|
||||
if (resultSet != null) {
|
||||
@ -109,7 +109,7 @@ class WWFMessageAnalyzer {
|
||||
statement.close();
|
||||
connection.close();
|
||||
} catch (Exception e) {
|
||||
logger.log(Level.SEVERE, "Error closing database", e);
|
||||
logger.log(Level.SEVERE, "Error closing database", e); //NOI18N
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user