mirror of
https://github.com/overcuriousity/autopsy-flatpak.git
synced 2025-07-12 16:06:15 +00:00
Merge remote-tracking branch 'upstream/develop' into 3879_userMetrics
This commit is contained in:
commit
c37bc2f360
@ -1,70 +0,0 @@
|
|||||||
/*
|
|
||||||
* Central Repository
|
|
||||||
*
|
|
||||||
* Copyright 2015-2017 Basis Technology Corp.
|
|
||||||
* Contact: carrier <at> sleuthkit <dot> org
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
package org.sleuthkit.autopsy.centralrepository.contentviewer;
|
|
||||||
|
|
||||||
import java.util.Objects;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Used as a key to ensure we eliminate duplicates from the result set by not overwriting CR correlation instances.
|
|
||||||
*/
|
|
||||||
final class ArtifactKey {
|
|
||||||
|
|
||||||
private final String dataSourceID;
|
|
||||||
private final String filePath;
|
|
||||||
|
|
||||||
ArtifactKey(String theDataSource, String theFilePath) {
|
|
||||||
dataSourceID = theDataSource;
|
|
||||||
filePath = theFilePath.toLowerCase();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @return the dataSourceID device ID
|
|
||||||
*/
|
|
||||||
String getDataSourceID() {
|
|
||||||
return dataSourceID;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @return the filPath including the filename and extension.
|
|
||||||
*/
|
|
||||||
String getFilePath() {
|
|
||||||
return filePath;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean equals(Object other) {
|
|
||||||
if (other instanceof ArtifactKey) {
|
|
||||||
return ((ArtifactKey) other).getDataSourceID().equals(dataSourceID) && ((ArtifactKey) other).getFilePath().equals(filePath);
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int hashCode() {
|
|
||||||
//int hash = 7;
|
|
||||||
//hash = 67 * hash + this.dataSourceID.hashCode();
|
|
||||||
//hash = 67 * hash + this.filePath.hashCode();
|
|
||||||
|
|
||||||
return Objects.hash(dataSourceID, filePath);
|
|
||||||
}
|
|
||||||
}
|
|
@ -18,7 +18,9 @@
|
|||||||
*/
|
*/
|
||||||
package org.sleuthkit.autopsy.centralrepository.contentviewer;
|
package org.sleuthkit.autopsy.centralrepository.contentviewer;
|
||||||
|
|
||||||
|
import java.awt.Color;
|
||||||
import java.awt.Component;
|
import java.awt.Component;
|
||||||
|
import java.awt.Dimension;
|
||||||
import java.awt.event.ActionEvent;
|
import java.awt.event.ActionEvent;
|
||||||
import java.awt.event.ActionListener;
|
import java.awt.event.ActionListener;
|
||||||
import java.io.BufferedWriter;
|
import java.io.BufferedWriter;
|
||||||
@ -31,19 +33,30 @@ import java.util.Collection;
|
|||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.Objects;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
import org.sleuthkit.autopsy.coreutils.Logger;
|
import org.sleuthkit.autopsy.coreutils.Logger;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
import javax.swing.GroupLayout;
|
||||||
import javax.swing.JFileChooser;
|
import javax.swing.JFileChooser;
|
||||||
|
import javax.swing.JLabel;
|
||||||
import javax.swing.JMenuItem;
|
import javax.swing.JMenuItem;
|
||||||
import javax.swing.JOptionPane;
|
import javax.swing.JOptionPane;
|
||||||
import static javax.swing.JOptionPane.DEFAULT_OPTION;
|
import static javax.swing.JOptionPane.DEFAULT_OPTION;
|
||||||
import static javax.swing.JOptionPane.PLAIN_MESSAGE;
|
import static javax.swing.JOptionPane.PLAIN_MESSAGE;
|
||||||
import static javax.swing.JOptionPane.ERROR_MESSAGE;
|
import static javax.swing.JOptionPane.ERROR_MESSAGE;
|
||||||
|
import javax.swing.JPanel;
|
||||||
|
import javax.swing.JPopupMenu;
|
||||||
|
import javax.swing.JScrollPane;
|
||||||
|
import javax.swing.JTable;
|
||||||
|
import javax.swing.LayoutStyle;
|
||||||
|
import javax.swing.ListSelectionModel;
|
||||||
import javax.swing.filechooser.FileNameExtensionFilter;
|
import javax.swing.filechooser.FileNameExtensionFilter;
|
||||||
import javax.swing.table.TableCellRenderer;
|
import javax.swing.table.TableCellRenderer;
|
||||||
import javax.swing.table.TableColumn;
|
import javax.swing.table.TableColumn;
|
||||||
|
import org.openide.awt.Mnemonics;
|
||||||
import org.openide.nodes.Node;
|
import org.openide.nodes.Node;
|
||||||
|
import org.openide.util.NbBundle;
|
||||||
import org.openide.util.NbBundle.Messages;
|
import org.openide.util.NbBundle.Messages;
|
||||||
import org.openide.util.lookup.ServiceProvider;
|
import org.openide.util.lookup.ServiceProvider;
|
||||||
import org.sleuthkit.autopsy.casemodule.Case;
|
import org.sleuthkit.autopsy.casemodule.Case;
|
||||||
@ -65,14 +78,16 @@ import org.sleuthkit.datamodel.TskException;
|
|||||||
import org.sleuthkit.autopsy.centralrepository.datamodel.EamDb;
|
import org.sleuthkit.autopsy.centralrepository.datamodel.EamDb;
|
||||||
import org.sleuthkit.datamodel.SleuthkitCase;
|
import org.sleuthkit.datamodel.SleuthkitCase;
|
||||||
import org.sleuthkit.datamodel.TskData;
|
import org.sleuthkit.datamodel.TskData;
|
||||||
|
import org.sleuthkit.datamodel.TskDataException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* View correlation results from other cases
|
* View correlation results from other cases
|
||||||
*/
|
*/
|
||||||
|
@SuppressWarnings("PMD.SingularField") // UI widgets cause lots of false positives
|
||||||
@ServiceProvider(service = DataContentViewer.class, position = 8)
|
@ServiceProvider(service = DataContentViewer.class, position = 8)
|
||||||
@Messages({"DataContentViewerOtherCases.title=Other Occurrences",
|
@Messages({"DataContentViewerOtherCases.title=Other Occurrences",
|
||||||
"DataContentViewerOtherCases.toolTip=Displays instances of the selected file/artifact from other occurrences.",})
|
"DataContentViewerOtherCases.toolTip=Displays instances of the selected file/artifact from other occurrences.",})
|
||||||
public class DataContentViewerOtherCases extends javax.swing.JPanel implements DataContentViewer {
|
public class DataContentViewerOtherCases extends JPanel implements DataContentViewer {
|
||||||
|
|
||||||
private final static Logger LOGGER = Logger.getLogger(DataContentViewerOtherCases.class.getName());
|
private final static Logger LOGGER = Logger.getLogger(DataContentViewerOtherCases.class.getName());
|
||||||
|
|
||||||
@ -451,12 +466,12 @@ public class DataContentViewerOtherCases extends javax.swing.JPanel implements D
|
|||||||
*
|
*
|
||||||
* @return A collection of correlated artifact instances from other cases
|
* @return A collection of correlated artifact instances from other cases
|
||||||
*/
|
*/
|
||||||
private Map<ArtifactKey, CorrelationAttributeInstance> getCorrelatedInstances(CorrelationAttribute corAttr, String dataSourceName, String deviceId) {
|
private Map<UniquePathKey,CorrelationAttributeInstance> getCorrelatedInstances(CorrelationAttribute corAttr, String dataSourceName, String deviceId) {
|
||||||
// @@@ Check exception
|
// @@@ Check exception
|
||||||
try {
|
try {
|
||||||
final Case openCase = Case.getCurrentCase();
|
final Case openCase = Case.getCurrentCase();
|
||||||
String caseUUID = openCase.getName();
|
String caseUUID = openCase.getName();
|
||||||
HashMap<ArtifactKey, CorrelationAttributeInstance> artifactInstances = new HashMap<>();
|
HashMap<UniquePathKey,CorrelationAttributeInstance> artifactInstances = new HashMap<>();
|
||||||
|
|
||||||
if (EamDb.isEnabled()) {
|
if (EamDb.isEnabled()) {
|
||||||
EamDb dbManager = EamDb.getInstance();
|
EamDb dbManager = EamDb.getInstance();
|
||||||
@ -464,8 +479,7 @@ public class DataContentViewerOtherCases extends javax.swing.JPanel implements D
|
|||||||
.filter(artifactInstance -> !artifactInstance.getCorrelationCase().getCaseUUID().equals(caseUUID)
|
.filter(artifactInstance -> !artifactInstance.getCorrelationCase().getCaseUUID().equals(caseUUID)
|
||||||
|| !artifactInstance.getCorrelationDataSource().getName().equals(dataSourceName)
|
|| !artifactInstance.getCorrelationDataSource().getName().equals(dataSourceName)
|
||||||
|| !artifactInstance.getCorrelationDataSource().getDeviceID().equals(deviceId))
|
|| !artifactInstance.getCorrelationDataSource().getDeviceID().equals(deviceId))
|
||||||
.collect(Collectors.toMap(
|
.collect(Collectors.toMap(correlationAttr -> new UniquePathKey(correlationAttr.getCorrelationDataSource().getDeviceID(), correlationAttr.getFilePath()),
|
||||||
correlationAttr -> new ArtifactKey(correlationAttr.getCorrelationDataSource().getDeviceID(), correlationAttr.getFilePath()),
|
|
||||||
correlationAttr -> correlationAttr)));
|
correlationAttr -> correlationAttr)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -507,29 +521,59 @@ public class DataContentViewerOtherCases extends javax.swing.JPanel implements D
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addOrUpdateAttributeInstance(final Case openCase, Map<ArtifactKey, CorrelationAttributeInstance> artifactInstances, AbstractFile caseDbFile) throws TskCoreException, EamDbException {
|
/**
|
||||||
CorrelationCase caze = new CorrelationCase(openCase.getNumber(), openCase.getDisplayName());
|
* Adds the file to the artifactInstances map if it does not already exist
|
||||||
CorrelationDataSource dataSource = CorrelationDataSource.fromTSKDataSource(caze, caseDbFile.getDataSource());
|
*
|
||||||
String filePath = caseDbFile.getParentPath() + caseDbFile.getName();
|
* @param autopsyCase
|
||||||
ArtifactKey instKey = new ArtifactKey(dataSource.getDeviceID(), filePath);
|
* @param artifactInstances
|
||||||
CorrelationAttributeInstance caseDbInstance = new CorrelationAttributeInstance(caze, dataSource, filePath, "", caseDbFile.getKnown());
|
* @param newFile
|
||||||
TskData.FileKnown knownStatus = caseDbInstance.getKnownStatus();
|
* @throws TskCoreException
|
||||||
// If not known, check Tags for known and set
|
* @throws EamDbException
|
||||||
TskData.FileKnown knownBad = TskData.FileKnown.BAD;
|
*/
|
||||||
if (!knownStatus.equals(knownBad)) {
|
private void addOrUpdateAttributeInstance(final Case autopsyCase, Map<UniquePathKey,CorrelationAttributeInstance> artifactInstances, AbstractFile newFile) throws TskCoreException, EamDbException {
|
||||||
List<ContentTag> fileMatchTags = openCase.getServices().getTagsManager().getContentTagsByContent(caseDbFile);
|
|
||||||
|
// figure out if the casedb file is known via either hash or tags
|
||||||
|
TskData.FileKnown localKnown = newFile.getKnown();
|
||||||
|
|
||||||
|
if (localKnown != TskData.FileKnown.BAD) {
|
||||||
|
List<ContentTag> fileMatchTags = autopsyCase.getServices().getTagsManager().getContentTagsByContent(newFile);
|
||||||
for (ContentTag tag : fileMatchTags) {
|
for (ContentTag tag : fileMatchTags) {
|
||||||
TskData.FileKnown tagKnownStatus = tag.getName().getKnownStatus();
|
TskData.FileKnown tagKnownStatus = tag.getName().getKnownStatus();
|
||||||
if (tagKnownStatus.equals(knownBad)) {
|
if (tagKnownStatus.equals(TskData.FileKnown.BAD)) {
|
||||||
caseDbInstance.setKnownStatus(knownBad);
|
localKnown = TskData.FileKnown.BAD;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// If known, or not in CR, add
|
// make a key to see if the file is already in the map
|
||||||
if (caseDbInstance.getKnownStatus().equals(knownBad) || !artifactInstances.containsKey(instKey)) {
|
String filePath = newFile.getParentPath() + newFile.getName();
|
||||||
artifactInstances.put(instKey, caseDbInstance);
|
String deviceId;
|
||||||
|
try {
|
||||||
|
deviceId = autopsyCase.getSleuthkitCase().getDataSource(newFile.getDataSource().getId()).getDeviceId();
|
||||||
|
} catch (TskDataException | TskCoreException ex) {
|
||||||
|
LOGGER.log(Level.WARNING, "Error getting data source info: " + ex);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
UniquePathKey uniquePathKey = new UniquePathKey(deviceId, filePath);
|
||||||
|
|
||||||
|
// double check that the CR version is BAD if the caseDB version is BAD.
|
||||||
|
if (artifactInstances.containsKey(uniquePathKey)) {
|
||||||
|
if (localKnown == TskData.FileKnown.BAD) {
|
||||||
|
CorrelationAttributeInstance prevInstance = artifactInstances.get(uniquePathKey);
|
||||||
|
prevInstance.setKnownStatus(localKnown);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// add the data from the case DB by pushing data into CorrelationAttributeInstance class
|
||||||
|
else {
|
||||||
|
// NOTE: If we are in here, it is likely because CR is not enabled. So, we cannot rely
|
||||||
|
// on any of the methods that query the DB.
|
||||||
|
CorrelationCase correlationCase = new CorrelationCase(autopsyCase.getName(), autopsyCase.getDisplayName());
|
||||||
|
|
||||||
|
CorrelationDataSource correlationDataSource = CorrelationDataSource.fromTSKDataSource(correlationCase, newFile.getDataSource());
|
||||||
|
|
||||||
|
CorrelationAttributeInstance caseDbInstance = new CorrelationAttributeInstance(correlationCase, correlationDataSource, filePath, "", localKnown);
|
||||||
|
artifactInstances.put(uniquePathKey, caseDbInstance);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -588,7 +632,7 @@ public class DataContentViewerOtherCases extends javax.swing.JPanel implements D
|
|||||||
// get the attributes we can correlate on
|
// get the attributes we can correlate on
|
||||||
correlationAttributes.addAll(getCorrelationAttributesFromNode(node));
|
correlationAttributes.addAll(getCorrelationAttributesFromNode(node));
|
||||||
for (CorrelationAttribute corAttr : correlationAttributes) {
|
for (CorrelationAttribute corAttr : correlationAttributes) {
|
||||||
Map<ArtifactKey, CorrelationAttributeInstance> corAttrInstances = new HashMap<>(0);
|
Map<UniquePathKey, CorrelationAttributeInstance> corAttrInstances = new HashMap<>(0);
|
||||||
|
|
||||||
// get correlation and reference set instances from DB
|
// get correlation and reference set instances from DB
|
||||||
corAttrInstances.putAll(getCorrelatedInstances(corAttr, dataSourceName, deviceId));
|
corAttrInstances.putAll(getCorrelatedInstances(corAttr, dataSourceName, deviceId));
|
||||||
@ -608,6 +652,7 @@ public class DataContentViewerOtherCases extends javax.swing.JPanel implements D
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (correlationAttributes.isEmpty()) {
|
if (correlationAttributes.isEmpty()) {
|
||||||
|
// @@@ BC: We should have a more descriptive message than this. Mention that the file didn't have a MD5, etc.
|
||||||
displayMessageOnTableStatusPanel(Bundle.DataContentViewerOtherCases_table_noArtifacts());
|
displayMessageOnTableStatusPanel(Bundle.DataContentViewerOtherCases_table_noArtifacts());
|
||||||
} else if (0 == tableModel.getRowCount()) {
|
} else if (0 == tableModel.getRowCount()) {
|
||||||
displayMessageOnTableStatusPanel(Bundle.DataContentViewerOtherCases_table_isempty());
|
displayMessageOnTableStatusPanel(Bundle.DataContentViewerOtherCases_table_isempty());
|
||||||
@ -645,131 +690,170 @@ public class DataContentViewerOtherCases extends javax.swing.JPanel implements D
|
|||||||
// <editor-fold defaultstate="collapsed" desc="Generated Code">//GEN-BEGIN:initComponents
|
// <editor-fold defaultstate="collapsed" desc="Generated Code">//GEN-BEGIN:initComponents
|
||||||
private void initComponents() {
|
private void initComponents() {
|
||||||
|
|
||||||
rightClickPopupMenu = new javax.swing.JPopupMenu();
|
rightClickPopupMenu = new JPopupMenu();
|
||||||
selectAllMenuItem = new javax.swing.JMenuItem();
|
selectAllMenuItem = new JMenuItem();
|
||||||
exportToCSVMenuItem = new javax.swing.JMenuItem();
|
exportToCSVMenuItem = new JMenuItem();
|
||||||
showCaseDetailsMenuItem = new javax.swing.JMenuItem();
|
showCaseDetailsMenuItem = new JMenuItem();
|
||||||
showCommonalityMenuItem = new javax.swing.JMenuItem();
|
showCommonalityMenuItem = new JMenuItem();
|
||||||
CSVFileChooser = new javax.swing.JFileChooser();
|
CSVFileChooser = new JFileChooser();
|
||||||
otherCasesPanel = new javax.swing.JPanel();
|
otherCasesPanel = new JPanel();
|
||||||
tableContainerPanel = new javax.swing.JPanel();
|
tableContainerPanel = new JPanel();
|
||||||
tableScrollPane = new javax.swing.JScrollPane();
|
tableScrollPane = new JScrollPane();
|
||||||
otherCasesTable = new javax.swing.JTable();
|
otherCasesTable = new JTable();
|
||||||
tableStatusPanel = new javax.swing.JPanel();
|
tableStatusPanel = new JPanel();
|
||||||
tableStatusPanelLabel = new javax.swing.JLabel();
|
tableStatusPanelLabel = new JLabel();
|
||||||
|
|
||||||
org.openide.awt.Mnemonics.setLocalizedText(selectAllMenuItem, org.openide.util.NbBundle.getMessage(DataContentViewerOtherCases.class, "DataContentViewerOtherCases.selectAllMenuItem.text")); // NOI18N
|
Mnemonics.setLocalizedText(selectAllMenuItem, NbBundle.getMessage(DataContentViewerOtherCases.class, "DataContentViewerOtherCases.selectAllMenuItem.text")); // NOI18N
|
||||||
rightClickPopupMenu.add(selectAllMenuItem);
|
rightClickPopupMenu.add(selectAllMenuItem);
|
||||||
|
|
||||||
org.openide.awt.Mnemonics.setLocalizedText(exportToCSVMenuItem, org.openide.util.NbBundle.getMessage(DataContentViewerOtherCases.class, "DataContentViewerOtherCases.exportToCSVMenuItem.text")); // NOI18N
|
Mnemonics.setLocalizedText(exportToCSVMenuItem, NbBundle.getMessage(DataContentViewerOtherCases.class, "DataContentViewerOtherCases.exportToCSVMenuItem.text")); // NOI18N
|
||||||
rightClickPopupMenu.add(exportToCSVMenuItem);
|
rightClickPopupMenu.add(exportToCSVMenuItem);
|
||||||
|
|
||||||
org.openide.awt.Mnemonics.setLocalizedText(showCaseDetailsMenuItem, org.openide.util.NbBundle.getMessage(DataContentViewerOtherCases.class, "DataContentViewerOtherCases.showCaseDetailsMenuItem.text")); // NOI18N
|
Mnemonics.setLocalizedText(showCaseDetailsMenuItem, NbBundle.getMessage(DataContentViewerOtherCases.class, "DataContentViewerOtherCases.showCaseDetailsMenuItem.text")); // NOI18N
|
||||||
rightClickPopupMenu.add(showCaseDetailsMenuItem);
|
rightClickPopupMenu.add(showCaseDetailsMenuItem);
|
||||||
|
|
||||||
org.openide.awt.Mnemonics.setLocalizedText(showCommonalityMenuItem, org.openide.util.NbBundle.getMessage(DataContentViewerOtherCases.class, "DataContentViewerOtherCases.showCommonalityMenuItem.text")); // NOI18N
|
Mnemonics.setLocalizedText(showCommonalityMenuItem, NbBundle.getMessage(DataContentViewerOtherCases.class, "DataContentViewerOtherCases.showCommonalityMenuItem.text")); // NOI18N
|
||||||
rightClickPopupMenu.add(showCommonalityMenuItem);
|
rightClickPopupMenu.add(showCommonalityMenuItem);
|
||||||
|
|
||||||
setMinimumSize(new java.awt.Dimension(1500, 10));
|
setMinimumSize(new Dimension(1500, 10));
|
||||||
setOpaque(false);
|
setOpaque(false);
|
||||||
setPreferredSize(new java.awt.Dimension(1500, 44));
|
setPreferredSize(new Dimension(1500, 44));
|
||||||
|
|
||||||
otherCasesPanel.setPreferredSize(new java.awt.Dimension(1500, 144));
|
otherCasesPanel.setPreferredSize(new Dimension(1500, 144));
|
||||||
|
|
||||||
tableContainerPanel.setPreferredSize(new java.awt.Dimension(1500, 63));
|
tableContainerPanel.setPreferredSize(new Dimension(1500, 63));
|
||||||
|
|
||||||
tableScrollPane.setPreferredSize(new java.awt.Dimension(1500, 30));
|
tableScrollPane.setPreferredSize(new Dimension(1500, 30));
|
||||||
|
|
||||||
otherCasesTable.setAutoCreateRowSorter(true);
|
otherCasesTable.setAutoCreateRowSorter(true);
|
||||||
otherCasesTable.setModel(tableModel);
|
otherCasesTable.setModel(tableModel);
|
||||||
otherCasesTable.setToolTipText(org.openide.util.NbBundle.getMessage(DataContentViewerOtherCases.class, "DataContentViewerOtherCases.table.toolTip.text")); // NOI18N
|
otherCasesTable.setToolTipText(NbBundle.getMessage(DataContentViewerOtherCases.class, "DataContentViewerOtherCases.table.toolTip.text")); // NOI18N
|
||||||
otherCasesTable.setComponentPopupMenu(rightClickPopupMenu);
|
otherCasesTable.setComponentPopupMenu(rightClickPopupMenu);
|
||||||
otherCasesTable.setSelectionMode(javax.swing.ListSelectionModel.SINGLE_INTERVAL_SELECTION);
|
otherCasesTable.setSelectionMode(ListSelectionModel.SINGLE_INTERVAL_SELECTION);
|
||||||
tableScrollPane.setViewportView(otherCasesTable);
|
tableScrollPane.setViewportView(otherCasesTable);
|
||||||
|
|
||||||
tableStatusPanel.setPreferredSize(new java.awt.Dimension(1500, 16));
|
tableStatusPanel.setPreferredSize(new Dimension(1500, 16));
|
||||||
|
|
||||||
tableStatusPanelLabel.setForeground(new java.awt.Color(255, 0, 51));
|
tableStatusPanelLabel.setForeground(new Color(255, 0, 51));
|
||||||
|
|
||||||
javax.swing.GroupLayout tableStatusPanelLayout = new javax.swing.GroupLayout(tableStatusPanel);
|
GroupLayout tableStatusPanelLayout = new GroupLayout(tableStatusPanel);
|
||||||
tableStatusPanel.setLayout(tableStatusPanelLayout);
|
tableStatusPanel.setLayout(tableStatusPanelLayout);
|
||||||
tableStatusPanelLayout.setHorizontalGroup(
|
tableStatusPanelLayout.setHorizontalGroup(tableStatusPanelLayout.createParallelGroup(GroupLayout.Alignment.LEADING)
|
||||||
tableStatusPanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
|
||||||
.addGap(0, 0, Short.MAX_VALUE)
|
.addGap(0, 0, Short.MAX_VALUE)
|
||||||
.addGroup(tableStatusPanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
.addGroup(tableStatusPanelLayout.createParallelGroup(GroupLayout.Alignment.LEADING)
|
||||||
.addGroup(tableStatusPanelLayout.createSequentialGroup()
|
.addGroup(tableStatusPanelLayout.createSequentialGroup()
|
||||||
.addContainerGap()
|
.addContainerGap()
|
||||||
.addComponent(tableStatusPanelLabel, javax.swing.GroupLayout.DEFAULT_SIZE, 780, Short.MAX_VALUE)
|
.addComponent(tableStatusPanelLabel, GroupLayout.DEFAULT_SIZE, 780, Short.MAX_VALUE)
|
||||||
.addContainerGap()))
|
.addContainerGap()))
|
||||||
);
|
);
|
||||||
tableStatusPanelLayout.setVerticalGroup(
|
tableStatusPanelLayout.setVerticalGroup(tableStatusPanelLayout.createParallelGroup(GroupLayout.Alignment.LEADING)
|
||||||
tableStatusPanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
|
||||||
.addGap(0, 16, Short.MAX_VALUE)
|
.addGap(0, 16, Short.MAX_VALUE)
|
||||||
.addGroup(tableStatusPanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
.addGroup(tableStatusPanelLayout.createParallelGroup(GroupLayout.Alignment.LEADING)
|
||||||
.addGroup(tableStatusPanelLayout.createSequentialGroup()
|
.addGroup(tableStatusPanelLayout.createSequentialGroup()
|
||||||
.addComponent(tableStatusPanelLabel, javax.swing.GroupLayout.PREFERRED_SIZE, 16, javax.swing.GroupLayout.PREFERRED_SIZE)
|
.addComponent(tableStatusPanelLabel, GroupLayout.PREFERRED_SIZE, 16, GroupLayout.PREFERRED_SIZE)
|
||||||
.addGap(0, 0, Short.MAX_VALUE)))
|
.addGap(0, 0, Short.MAX_VALUE)))
|
||||||
);
|
);
|
||||||
|
|
||||||
javax.swing.GroupLayout tableContainerPanelLayout = new javax.swing.GroupLayout(tableContainerPanel);
|
GroupLayout tableContainerPanelLayout = new GroupLayout(tableContainerPanel);
|
||||||
tableContainerPanel.setLayout(tableContainerPanelLayout);
|
tableContainerPanel.setLayout(tableContainerPanelLayout);
|
||||||
tableContainerPanelLayout.setHorizontalGroup(
|
tableContainerPanelLayout.setHorizontalGroup(tableContainerPanelLayout.createParallelGroup(GroupLayout.Alignment.LEADING)
|
||||||
tableContainerPanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
.addComponent(tableScrollPane, GroupLayout.Alignment.TRAILING, GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
|
||||||
.addComponent(tableScrollPane, javax.swing.GroupLayout.Alignment.TRAILING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
|
.addComponent(tableStatusPanel, GroupLayout.Alignment.TRAILING, GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
|
||||||
.addComponent(tableStatusPanel, javax.swing.GroupLayout.Alignment.TRAILING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
|
|
||||||
);
|
);
|
||||||
tableContainerPanelLayout.setVerticalGroup(
|
tableContainerPanelLayout.setVerticalGroup(tableContainerPanelLayout.createParallelGroup(GroupLayout.Alignment.LEADING)
|
||||||
tableContainerPanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
|
||||||
.addGroup(tableContainerPanelLayout.createSequentialGroup()
|
.addGroup(tableContainerPanelLayout.createSequentialGroup()
|
||||||
.addComponent(tableScrollPane, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
|
.addComponent(tableScrollPane, GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
|
||||||
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
|
||||||
.addComponent(tableStatusPanel, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
|
.addComponent(tableStatusPanel, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
|
||||||
.addContainerGap())
|
.addContainerGap())
|
||||||
);
|
);
|
||||||
|
|
||||||
javax.swing.GroupLayout otherCasesPanelLayout = new javax.swing.GroupLayout(otherCasesPanel);
|
GroupLayout otherCasesPanelLayout = new GroupLayout(otherCasesPanel);
|
||||||
otherCasesPanel.setLayout(otherCasesPanelLayout);
|
otherCasesPanel.setLayout(otherCasesPanelLayout);
|
||||||
otherCasesPanelLayout.setHorizontalGroup(
|
otherCasesPanelLayout.setHorizontalGroup(otherCasesPanelLayout.createParallelGroup(GroupLayout.Alignment.LEADING)
|
||||||
otherCasesPanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
|
||||||
.addGap(0, 1500, Short.MAX_VALUE)
|
.addGap(0, 1500, Short.MAX_VALUE)
|
||||||
.addGroup(otherCasesPanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
.addGroup(otherCasesPanelLayout.createParallelGroup(GroupLayout.Alignment.LEADING)
|
||||||
.addComponent(tableContainerPanel, javax.swing.GroupLayout.Alignment.TRAILING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
|
.addComponent(tableContainerPanel, GroupLayout.Alignment.TRAILING, GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
|
||||||
);
|
);
|
||||||
otherCasesPanelLayout.setVerticalGroup(
|
otherCasesPanelLayout.setVerticalGroup(otherCasesPanelLayout.createParallelGroup(GroupLayout.Alignment.LEADING)
|
||||||
otherCasesPanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
|
||||||
.addGap(0, 60, Short.MAX_VALUE)
|
.addGap(0, 60, Short.MAX_VALUE)
|
||||||
.addGroup(otherCasesPanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
.addGroup(otherCasesPanelLayout.createParallelGroup(GroupLayout.Alignment.LEADING)
|
||||||
.addGroup(otherCasesPanelLayout.createSequentialGroup()
|
.addGroup(otherCasesPanelLayout.createSequentialGroup()
|
||||||
.addComponent(tableContainerPanel, javax.swing.GroupLayout.DEFAULT_SIZE, 60, Short.MAX_VALUE)
|
.addComponent(tableContainerPanel, GroupLayout.DEFAULT_SIZE, 60, Short.MAX_VALUE)
|
||||||
.addGap(0, 0, 0)))
|
.addGap(0, 0, 0)))
|
||||||
);
|
);
|
||||||
|
|
||||||
javax.swing.GroupLayout layout = new javax.swing.GroupLayout(this);
|
GroupLayout layout = new GroupLayout(this);
|
||||||
this.setLayout(layout);
|
this.setLayout(layout);
|
||||||
layout.setHorizontalGroup(
|
layout.setHorizontalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
|
||||||
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
.addComponent(otherCasesPanel, GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
|
||||||
.addComponent(otherCasesPanel, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
|
|
||||||
);
|
);
|
||||||
layout.setVerticalGroup(
|
layout.setVerticalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
|
||||||
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
.addComponent(otherCasesPanel, GroupLayout.DEFAULT_SIZE, 60, Short.MAX_VALUE)
|
||||||
.addComponent(otherCasesPanel, javax.swing.GroupLayout.DEFAULT_SIZE, 60, Short.MAX_VALUE)
|
|
||||||
);
|
);
|
||||||
}// </editor-fold>//GEN-END:initComponents
|
}// </editor-fold>//GEN-END:initComponents
|
||||||
|
|
||||||
|
|
||||||
// Variables declaration - do not modify//GEN-BEGIN:variables
|
// Variables declaration - do not modify//GEN-BEGIN:variables
|
||||||
private javax.swing.JFileChooser CSVFileChooser;
|
private JFileChooser CSVFileChooser;
|
||||||
private javax.swing.JMenuItem exportToCSVMenuItem;
|
private JMenuItem exportToCSVMenuItem;
|
||||||
private javax.swing.JPanel otherCasesPanel;
|
private JPanel otherCasesPanel;
|
||||||
private javax.swing.JTable otherCasesTable;
|
private JTable otherCasesTable;
|
||||||
private javax.swing.JPopupMenu rightClickPopupMenu;
|
private JPopupMenu rightClickPopupMenu;
|
||||||
private javax.swing.JMenuItem selectAllMenuItem;
|
private JMenuItem selectAllMenuItem;
|
||||||
private javax.swing.JMenuItem showCaseDetailsMenuItem;
|
private JMenuItem showCaseDetailsMenuItem;
|
||||||
private javax.swing.JMenuItem showCommonalityMenuItem;
|
private JMenuItem showCommonalityMenuItem;
|
||||||
private javax.swing.JPanel tableContainerPanel;
|
private JPanel tableContainerPanel;
|
||||||
private javax.swing.JScrollPane tableScrollPane;
|
private JScrollPane tableScrollPane;
|
||||||
private javax.swing.JPanel tableStatusPanel;
|
private JPanel tableStatusPanel;
|
||||||
private javax.swing.JLabel tableStatusPanelLabel;
|
private JLabel tableStatusPanelLabel;
|
||||||
// End of variables declaration//GEN-END:variables
|
// End of variables declaration//GEN-END:variables
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Used as a key to ensure we eliminate duplicates from the result set by not overwriting CR correlation instances.
|
||||||
|
*/
|
||||||
|
static final class UniquePathKey {
|
||||||
|
|
||||||
|
private final String dataSourceID;
|
||||||
|
private final String filePath;
|
||||||
|
|
||||||
|
UniquePathKey(String theDataSource, String theFilePath) {
|
||||||
|
super();
|
||||||
|
dataSourceID = theDataSource;
|
||||||
|
filePath = theFilePath.toLowerCase();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @return the dataSourceID device ID
|
||||||
|
*/
|
||||||
|
String getDataSourceID() {
|
||||||
|
return dataSourceID;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @return the filPath including the filename and extension.
|
||||||
|
*/
|
||||||
|
String getFilePath() {
|
||||||
|
return filePath;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object other) {
|
||||||
|
if (other instanceof UniquePathKey) {
|
||||||
|
return ((UniquePathKey) other).getDataSourceID().equals(dataSourceID) && ((UniquePathKey) other).getFilePath().equals(filePath);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
//int hash = 7;
|
||||||
|
//hash = 67 * hash + this.dataSourceID.hashCode();
|
||||||
|
//hash = 67 * hash + this.filePath.hashCode();
|
||||||
|
return Objects.hash(dataSourceID, filePath);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user