19 package org.sleuthkit.autopsy.datamodel;
 
   21 import java.beans.PropertyChangeEvent;
 
   22 import java.beans.PropertyChangeListener;
 
   23 import java.sql.ResultSet;
 
   24 import java.sql.SQLException;
 
   25 import java.util.ArrayList;
 
   26 import java.util.Collections;
 
   27 import java.util.EnumSet;
 
   28 import java.util.HashMap;
 
   29 import java.util.HashSet;
 
   30 import java.util.LinkedHashMap;
 
   31 import java.util.List;
 
   33 import java.util.Objects;
 
   34 import java.util.Observable;
 
   35 import java.util.Observer;
 
   37 import java.util.logging.Level;
 
   38 import org.openide.nodes.ChildFactory;
 
   39 import org.openide.nodes.Children;
 
   40 import org.openide.nodes.Node;
 
   41 import org.openide.nodes.Sheet;
 
   42 import org.openide.util.NbBundle;
 
   43 import org.openide.util.lookup.Lookups;
 
   52 import org.
sleuthkit.datamodel.BlackboardArtifact.ARTIFACT_TYPE;
 
   53 import org.
sleuthkit.datamodel.BlackboardAttribute.ATTRIBUTE_TYPE;
 
   55 import org.
sleuthkit.datamodel.SleuthkitCase.CaseDbQuery;
 
   64     private static final String 
HASHSET_HITS = BlackboardArtifact.ARTIFACT_TYPE.TSK_HASHSET_HIT.getLabel();
 
   65     private static final String 
DISPLAY_NAME = BlackboardArtifact.ARTIFACT_TYPE.TSK_HASHSET_HIT.getDisplayName();
 
   91         this.datasourceObjId = objId;
 
   97         return visitor.
visit(
this);
 
  114         List<String> getSetNames() {
 
  117                 names = 
new ArrayList<>(hashSetHitsMap.keySet());
 
  119             Collections.sort(names);
 
  123         Set<Long> getArtifactIds(String hashSetName) {
 
  125                 return hashSetHitsMap.get(hashSetName);
 
  129         @SuppressWarnings(
"deprecation")
 
  130         final 
void update() {
 
  132                 hashSetHitsMap.clear();
 
  135             if (skCase == null) {
 
  139             int setNameId = ATTRIBUTE_TYPE.TSK_SET_NAME.getTypeID();
 
  140             int artId = ARTIFACT_TYPE.TSK_HASHSET_HIT.getTypeID();
 
  141             String query = 
"SELECT value_text,blackboard_attributes.artifact_id,attribute_type_id "  
  142                     + 
"FROM blackboard_attributes,blackboard_artifacts WHERE "  
  143                     + 
"attribute_type_id=" + setNameId 
 
  144                     + 
" AND blackboard_attributes.artifact_id=blackboard_artifacts.artifact_id"  
  145                     + 
" AND blackboard_artifacts.artifact_type_id=" + artId; 
 
  146             if (Objects.equals(CasePreferences.getGroupItemsInTreeByDataSource(), 
true)) {
 
  147                 query +=  
"  AND blackboard_artifacts.data_source_obj_id = " + 
datasourceObjId;
 
  150             try (CaseDbQuery dbQuery = skCase.executeQuery(query)) {
 
  151                 ResultSet resultSet = dbQuery.getResultSet();
 
  153                     while (resultSet.next()) {
 
  154                         String setName = resultSet.getString(
"value_text"); 
 
  155                         long artifactId = resultSet.getLong(
"artifact_id"); 
 
  156                         if (!hashSetHitsMap.containsKey(setName)) {
 
  157                             hashSetHitsMap.put(setName, 
new HashSet<Long>());
 
  159                         hashSetHitsMap.get(setName).add(artifactId);
 
  162             } 
catch (TskCoreException | SQLException ex) {
 
  163                 logger.log(Level.WARNING, 
"SQL Exception occurred: ", ex); 
 
  177             super(Children.create(
new HashsetNameFactory(), 
true), Lookups.singleton(DISPLAY_NAME));
 
  178             super.setName(HASHSET_HITS);
 
  179             super.setDisplayName(DISPLAY_NAME);
 
  180             this.setIconBaseWithExtension(
"org/sleuthkit/autopsy/images/hashset_hits.png"); 
 
  190             return visitor.
visit(
this);
 
  195             Sheet sheet = super.createSheet();
 
  196             Sheet.Set sheetSet = sheet.get(Sheet.PROPERTIES);
 
  197             if (sheetSet == null) {
 
  198                 sheetSet = Sheet.createPropertiesSet();
 
  202             sheetSet.put(
new NodeProperty<>(NbBundle.getMessage(
this.getClass(), 
"HashsetHits.createSheet.name.name"),
 
  203                     NbBundle.getMessage(
this.getClass(), 
"HashsetHits.createSheet.name.displayName"),
 
  204                     NbBundle.getMessage(
this.getClass(), 
"HashsetHits.createSheet.name.desc"),
 
  212             return getClass().getName();
 
  226         private final PropertyChangeListener 
pcl = 
new PropertyChangeListener() {
 
  228             public void propertyChange(PropertyChangeEvent evt) {
 
  229                 String eventType = evt.getPropertyName();
 
  245                         if (null != eventData && eventData.
getBlackboardArtifactType().getTypeID() == ARTIFACT_TYPE.TSK_HASHSET_HIT.getTypeID()) {
 
  246                             hashsetResults.update();
 
  263                         hashsetResults.update();
 
  271                     if (evt.getNewValue() == null) {
 
  284             hashsetResults.update();
 
  285             hashsetResults.addObserver(
this);
 
  293             hashsetResults.deleteObserver(
this);
 
  298             list.addAll(hashsetResults.getSetNames());
 
  308         public void update(Observable o, Object arg) {
 
  321             super(Children.create(
new HitFactory(hashSetName), 
true), Lookups.singleton(hashSetName));
 
  322             super.setName(hashSetName);
 
  325             this.setIconBaseWithExtension(
"org/sleuthkit/autopsy/images/hashset_hits.png"); 
 
  326             hashsetResults.addObserver(
this);
 
  333             super.setDisplayName(hashSetName + 
" (" + hashsetResults.getArtifactIds(hashSetName).size() + 
")");
 
  343             Sheet sheet = super.createSheet();
 
  344             Sheet.Set sheetSet = sheet.get(Sheet.PROPERTIES);
 
  345             if (sheetSet == null) {
 
  346                 sheetSet = Sheet.createPropertiesSet();
 
  350             sheetSet.put(
new NodeProperty<>(NbBundle.getMessage(
this.getClass(), 
"HashsetHits.createSheet.name.name"),
 
  351                     NbBundle.getMessage(
this.getClass(), 
"HashsetHits.createSheet.name.displayName"),
 
  352                     NbBundle.getMessage(
this.getClass(), 
"HashsetHits.createSheet.name.desc"),
 
  360             return visitor.
visit(
this);
 
  364         public void update(Observable o, Object arg) {
 
  374             return getClass().getName();
 
  381     private class HitFactory extends ChildFactory.Detachable<Long> implements Observer {
 
  393             hashsetResults.addObserver(
this);
 
  398             hashsetResults.deleteObserver(
this);
 
  404             if (skCase == null) {
 
  408             hashsetResults.getArtifactIds(hashsetName).forEach((
id) -> {
 
  410                     if (!artifactHits.containsKey(
id)) {
 
  411                         BlackboardArtifact art = skCase.getBlackboardArtifact(
id);
 
  412                         artifactHits.put(
id, art);
 
  414                 } 
catch (TskException ex) {
 
  415                     logger.log(Level.SEVERE, 
"TSK Exception occurred", ex); 
 
  422             list.addAll(artifactHits.keySet());
 
  428             BlackboardArtifact art = artifactHits.get(
id);
 
  433         public void update(Observable o, Object arg) {
 
BlackboardArtifact.Type getBlackboardArtifactType()
void removeIngestModuleEventListener(final PropertyChangeListener listener)
Map< Long, BlackboardArtifact > artifactHits
static synchronized IngestManager getInstance()
HashsetNameNode(String hashSetName)
static final String DISPLAY_NAME
HitFactory(String hashsetName)
boolean createKeys(List< String > list)
Node createNodeForKey(String key)
static final String HASHSET_HITS
static final Logger logger
T visit(DataSourcesNode in)
void update(Observable o, Object arg)
HashsetHits(SleuthkitCase skCase)
void removeIngestJobEventListener(final PropertyChangeListener listener)
boolean createKeys(List< Long > list)
final long datasourceObjId
void addIngestJobEventListener(final PropertyChangeListener listener)
final Map< String, Set< Long > > hashSetHitsMap
void update(Observable o, Object arg)
final PropertyChangeListener pcl
void addIngestModuleEventListener(final PropertyChangeListener listener)
synchronized static Logger getLogger(String name)
static Case getCurrentCaseThrows()
static void addEventTypeSubscriber(Set< Events > eventTypes, PropertyChangeListener subscriber)
void update(Observable o, Object arg)
static void removeEventTypeSubscriber(Set< Events > eventTypes, PropertyChangeListener subscriber)
Node createNodeForKey(Long id)
final HashsetResults hashsetResults
HashsetHits(SleuthkitCase skCase, long objId)