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.List;
29 import java.util.logging.Level;
30 import javax.swing.Action;
31 import org.apache.commons.lang3.tuple.Pair;
32 import org.openide.nodes.Sheet;
33 import org.openide.util.NbBundle;
34 import org.openide.util.NbBundle.Messages;
49 import org.
sleuthkit.datamodel.SleuthkitCase.CaseDbQuery;
71 static String nameForImage(Image i) {
82 String imgName = nameForImage(img);
83 this.setDisplayName(imgName);
84 this.setIconBaseWithExtension(
"org/sleuthkit/autopsy/images/hard-drive-icon.jpg");
105 @Messages({
"ImageNode.action.runIngestMods.text=Run Ingest Modules",
106 "ImageNode.getActions.openFileSearchByAttr.text=Open File Search by Attributes",})
109 List<Action> actionsList =
new ArrayList<>();
110 for (Action a : super.getActions(
true)) {
115 Bundle.ImageNode_getActions_openFileSearchByAttr_text()));
119 NbBundle.getMessage(
this.getClass(),
"ImageNode.getActions.viewInNewWin.text"),
this));
120 return actionsList.toArray(
new Action[0]);
124 @Messages({
"ImageNode.createSheet.size.name=Size (Bytes)",
125 "ImageNode.createSheet.size.displayName=Size (Bytes)",
126 "ImageNode.createSheet.size.desc=Size of the data source in bytes.",
127 "ImageNode.createSheet.type.name=Type",
128 "ImageNode.createSheet.type.displayName=Type",
129 "ImageNode.createSheet.type.desc=Type of the image.",
130 "ImageNode.createSheet.type.text=Image",
131 "ImageNode.createSheet.sectorSize.name=Sector Size (Bytes)",
132 "ImageNode.createSheet.sectorSize.displayName=Sector Size (Bytes)",
133 "ImageNode.createSheet.sectorSize.desc=Sector size of the image in bytes.",
134 "ImageNode.createSheet.timezone.name=Timezone",
135 "ImageNode.createSheet.timezone.displayName=Timezone",
136 "ImageNode.createSheet.timezone.desc=Timezone of the image",
137 "ImageNode.createSheet.deviceId.name=Device ID",
138 "ImageNode.createSheet.deviceId.displayName=Device ID",
139 "ImageNode.createSheet.deviceId.desc=Device ID of the image"})
141 Sheet sheet = super.createSheet();
142 Sheet.Set sheetSet = sheet.get(Sheet.PROPERTIES);
143 if (sheetSet == null) {
144 sheetSet = Sheet.createPropertiesSet();
148 sheetSet.put(
new NodeProperty<>(NbBundle.getMessage(
this.getClass(),
"ImageNode.createSheet.name.name"),
149 NbBundle.getMessage(
this.getClass(),
"ImageNode.createSheet.name.displayName"),
150 NbBundle.getMessage(
this.getClass(),
"ImageNode.createSheet.name.desc"),
153 sheetSet.put(
new NodeProperty<>(Bundle.ImageNode_createSheet_type_name(),
154 Bundle.ImageNode_createSheet_type_displayName(),
155 Bundle.ImageNode_createSheet_type_desc(),
156 Bundle.ImageNode_createSheet_type_text()));
158 sheetSet.put(
new NodeProperty<>(Bundle.ImageNode_createSheet_size_name(),
159 Bundle.ImageNode_createSheet_size_displayName(),
160 Bundle.ImageNode_createSheet_size_desc(),
161 this.content.getSize()));
162 sheetSet.put(
new NodeProperty<>(Bundle.ImageNode_createSheet_sectorSize_name(),
163 Bundle.ImageNode_createSheet_sectorSize_displayName(),
164 Bundle.ImageNode_createSheet_sectorSize_desc(),
165 this.content.getSsize()));
167 sheetSet.put(
new NodeProperty<>(Bundle.ImageNode_createSheet_timezone_name(),
168 Bundle.ImageNode_createSheet_timezone_displayName(),
169 Bundle.ImageNode_createSheet_timezone_desc(),
170 this.content.getTimeZone()));
173 ResultSet deviceIdSet = query.getResultSet();
174 if (deviceIdSet.next()) {
175 sheetSet.put(
new NodeProperty<>(Bundle.ImageNode_createSheet_deviceId_name(),
176 Bundle.ImageNode_createSheet_deviceId_displayName(),
177 Bundle.ImageNode_createSheet_deviceId_desc(),
178 deviceIdSet.getString(
"device_id")));
181 logger.log(Level.SEVERE,
"Failed to get device id for the following image: " +
this.content.getId(), ex);
188 public <T> T accept(ContentNodeVisitor<T> visitor) {
189 return visitor.visit(
this);
199 return visitor.
visit(
this);
204 return getClass().getName();
212 private final PropertyChangeListener
pcl = (PropertyChangeEvent evt) -> {
213 String eventType = evt.getPropertyName();
221 if ((moduleContentEvent.getSource() instanceof Content) ==
false) {
224 Content newContent = (Content) moduleContentEvent.getSource();
227 Content parent = newContent.getParent();
228 if (parent != null) {
230 if (parent.getName().equals(VirtualDirectory.NAME_CARVED)) {
232 if (newContent.getDataSource().getId() ==
getContent().getDataSource().getId()) {
235 while ((parent = parent.getParent()) != null) {
244 }
catch (TskCoreException ex) {
247 logger.log(Level.WARNING,
"Failed to post key refresh event.", ex);
250 if (evt.getNewValue() == null) {
266 return new ArrayList<>();
void removeIngestModuleEventListener(final PropertyChangeListener listener)
static synchronized IngestManager getInstance()
static List< Action > getActions(Content c)
CorrelationAttributeInstance getCorrelationAttributeInstance()
Action[] getActions(boolean context)
T visit(DataSourcesNode in)
Pair< Long, String > getCountPropertyAndDescription(CorrelationAttributeInstance.Type attributeType, String attributeValue, String defaultDescription)
Pair< DataResultViewerTable.Score, String > getScorePropertyAndDescription(List< Tag > tags)
SleuthkitCase getSleuthkitCase()
final PropertyChangeListener pcl
static void post(String nodeName, Object event)
static final Logger logger
DataResultViewerTable.HasCommentStatus getCommentProperty(List< Tag > tags, CorrelationAttributeInstance attribute)
void addIngestModuleEventListener(final PropertyChangeListener listener)
synchronized static Logger getLogger(String name)
static Case getCurrentCaseThrows()
static void addEventTypeSubscriber(Set< Events > eventTypes, PropertyChangeListener subscriber)
List< Tag > getAllTagsFromDatabase()
static void removeEventTypeSubscriber(Set< Events > eventTypes, PropertyChangeListener subscriber)
static final String NO_DESCR