19 package org.sleuthkit.autopsy.datamodel;
21 import java.sql.ResultSet;
22 import java.sql.SQLException;
23 import java.util.ArrayList;
24 import java.util.Collections;
25 import java.util.LinkedHashMap;
26 import java.util.List;
28 import java.util.logging.Level;
29 import javax.swing.Action;
30 import org.openide.nodes.Sheet;
31 import org.openide.util.NbBundle;
32 import org.openide.util.NbBundle.Messages;
68 this.setIconBaseWithExtension(
"org/sleuthkit/autopsy/images/folder-icon-deleted.png");
70 this.setIconBaseWithExtension(
"org/sleuthkit/autopsy/images/fileset-icon-16.png");
72 this.setIconBaseWithExtension(
"org/sleuthkit/autopsy/images/Folder-icon.png");
74 this.setIconBaseWithExtension(
"org/sleuthkit/autopsy/images/Folder-icon.png");
87 @NbBundle.Messages({
"VirtualDirectoryNode.action.runIngestMods.text=Run Ingest Modules"})
89 List<Action> actions =
new ArrayList<>();
90 for (Action a : super.getActions(
true)) {
95 NbBundle.getMessage(
this.getClass(),
"VirtualDirectoryNode.getActions.viewInNewWin.text"),
this));
100 Bundle.ImageNode_getActions_openFileSearchByAttr_text()));
103 return actions.toArray(
new Action[0]);
107 @Messages({
"VirtualDirectoryNode.createSheet.size.name=Size (Bytes)",
108 "VirtualDirectoryNode.createSheet.size.displayName=Size (Bytes)",
109 "VirtualDirectoryNode.createSheet.size.desc=Size of the data source in bytes.",
110 "VirtualDirectoryNode.createSheet.type.name=Type",
111 "VirtualDirectoryNode.createSheet.type.displayName=Type",
112 "VirtualDirectoryNode.createSheet.type.desc=Type of the image.",
113 "VirtualDirectoryNode.createSheet.type.text=Logical File Set",
114 "VirtualDirectoryNode.createSheet.timezone.name=Timezone",
115 "VirtualDirectoryNode.createSheet.timezone.displayName=Timezone",
116 "VirtualDirectoryNode.createSheet.timezone.desc=Timezone of the image",
117 "VirtualDirectoryNode.createSheet.deviceId.name=Device ID",
118 "VirtualDirectoryNode.createSheet.deviceId.displayName=Device ID",
119 "VirtualDirectoryNode.createSheet.deviceId.desc=Device ID of the image"})
121 Sheet s = super.createSheet();
122 Sheet.Set ss = s.get(Sheet.PROPERTIES);
124 ss = Sheet.createPropertiesSet();
128 ss.put(
new NodeProperty<>(NbBundle.getMessage(
this.getClass(),
"VirtualDirectoryNode.createSheet.name.name"),
129 NbBundle.getMessage(
this.getClass(),
130 "VirtualDirectoryNode.createSheet.name.displayName"),
131 NbBundle.getMessage(
this.getClass(),
"VirtualDirectoryNode.createSheet.name.desc"),
134 if (!this.content.isDataSource()) {
135 Map<String, Object> map =
new LinkedHashMap<>();
138 final String NO_DESCR = NbBundle.getMessage(this.getClass(),
"VirtualDirectoryNode.createSheet.noDesc");
139 for (Map.Entry<String, Object> entry : map.entrySet()) {
140 ss.put(
new NodeProperty<>(entry.getKey(), entry.getKey(), NO_DESCR, entry.getValue()));
144 ss.put(
new NodeProperty<>(Bundle.VirtualDirectoryNode_createSheet_type_name(),
145 Bundle.VirtualDirectoryNode_createSheet_type_displayName(),
146 Bundle.VirtualDirectoryNode_createSheet_type_desc(),
147 Bundle.VirtualDirectoryNode_createSheet_type_text()));
148 ss.put(
new NodeProperty<>(Bundle.VirtualDirectoryNode_createSheet_size_name(),
149 Bundle.VirtualDirectoryNode_createSheet_size_displayName(),
150 Bundle.VirtualDirectoryNode_createSheet_size_desc(),
151 this.content.getSize()));
153 ResultSet timeZoneSet = query.getResultSet();
154 if (timeZoneSet.next()) {
155 ss.put(
new NodeProperty<>(Bundle.VirtualDirectoryNode_createSheet_timezone_name(),
156 Bundle.VirtualDirectoryNode_createSheet_timezone_displayName(),
157 Bundle.VirtualDirectoryNode_createSheet_timezone_desc(),
158 timeZoneSet.getString(
"time_zone")));
161 logger.log(Level.SEVERE,
"Failed to get time zone for the following image: " +
this.content.getId(), ex);
164 ResultSet deviceIdSet = query.getResultSet();
165 if (deviceIdSet.next()) {
166 ss.put(
new NodeProperty<>(Bundle.VirtualDirectoryNode_createSheet_deviceId_name(),
167 Bundle.VirtualDirectoryNode_createSheet_deviceId_displayName(),
168 Bundle.VirtualDirectoryNode_createSheet_deviceId_desc(),
169 deviceIdSet.getString(
"device_id")));
172 logger.log(Level.SEVERE,
"Failed to get device id for the following image: " +
this.content.getId(), ex);
181 public <T> T accept(ContentNodeVisitor<T> v) {
182 return v.visit(
this);
186 public <T> T accept(DisplayableItemNodeVisitor<T> v) {
187 return v.visit(
this);
209 if ((metaFlag & allocFlag) == allocFlag) {
212 if ((metaFlag & unallocFlag) == unallocFlag) {
static String metaFlagToString(short metaFlag)
Action[] getActions(boolean popup)
void addTagProperty(Sheet.Set ss)
static final String NAME_CARVED
static void fillPropertyMap(Map< String, Object > map, AbstractFile content)
VirtualDirectoryNode(VirtualDirectory ld)
static final Logger logger
SleuthkitCase getSleuthkitCase()
static final String NAME_UNALLOC
static Case getCurrentCase()
synchronized static Logger getLogger(String name)
static final String LOGICAL_FILE_SET_PREFIX
static String nameForLayoutFile(VirtualDirectory ld)
CaseDbQuery executeQuery(String query)