Autopsy  4.9.1
Graphical digital forensics platform for The Sleuth Kit and other tools.
FileViewer.java
Go to the documentation of this file.
1 /*
2  * Autopsy Forensic Browser
3  *
4  * Copyright 2018 Basis Technology Corp.
5  * Contact: carrier <at> sleuthkit <dot> org
6  *
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  * http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  */
19 package org.sleuthkit.autopsy.contentviewers;
20 
21 
22 import com.google.common.base.Strings;
23 import java.awt.Component;
24 import java.util.HashMap;
25 import java.util.Map;
26 import java.util.logging.Level;
27 import org.openide.nodes.Node;
28 import org.openide.util.NbBundle;
29 import org.openide.util.lookup.ServiceProvider;
33 import org.sleuthkit.datamodel.AbstractFile;
34 
38 @ServiceProvider(service = DataContentViewer.class, position = 3)
39 @SuppressWarnings("PMD.SingularField") // UI widgets cause lots of false positives
40 public class FileViewer extends javax.swing.JPanel implements DataContentViewer {
41 
42  private static final int CONFIDENCE_LEVEL = 5;
43  private static final long serialVersionUID = 1L;
44  private static final Logger LOGGER = Logger.getLogger(FileViewer.class.getName());
45 
46  private final Map<String, FileTypeViewer> mimeTypeToViewerMap = new HashMap<>();
47 
48  // TBD: This hardcoded list of viewers should be replaced with a dynamic lookup
49  private static final FileTypeViewer[] KNOWN_VIEWERS = new FileTypeViewer[]{
50  new SQLiteViewer(),
51  new PListViewer(),
52  new MediaFileViewer()
53  };
54 
55  private FileTypeViewer lastViewer;
56 
60  public FileViewer() {
61 
62  // init the mimetype to viewer map
63  for (FileTypeViewer cv : KNOWN_VIEWERS) {
64  cv.getSupportedMIMETypes().forEach((mimeType) -> {
65  if (mimeTypeToViewerMap.containsKey(mimeType) == false) {
66  mimeTypeToViewerMap.put(mimeType, cv);
67  } else {
68  LOGGER.log(Level.WARNING, "Duplicate viewer for mimtype: {0}", mimeType); //NON-NLS
69  }
70  });
71  }
72 
73  initComponents();
74 
75  LOGGER.log(Level.INFO, "Created ApplicationContentViewer instance: {0}", this); //NON-NLS
76  }
77 
85  private FileTypeViewer getSupportingViewer(String mimeType) {
86  return mimeTypeToViewerMap.get(mimeType);
87  }
88 
94  @SuppressWarnings("unchecked")
95  // <editor-fold defaultstate="collapsed" desc="Generated Code">//GEN-BEGIN:initComponents
96  private void initComponents() {
97 
98  setLayout(new javax.swing.OverlayLayout(this));
99  }// </editor-fold>//GEN-END:initComponents
100 
101 
102  // Variables declaration - do not modify//GEN-BEGIN:variables
103  // End of variables declaration//GEN-END:variables
104 
105  @Override
106  public void setNode(Node selectedNode) {
107 
108  resetComponent();
109 
110  if (selectedNode == null) {
111  return;
112  }
113 
114  AbstractFile file = selectedNode.getLookup().lookup(AbstractFile.class);
115  if (file == null) {
116  return;
117  }
118 
119  String mimeType = file.getMIMEType();
120  if (Strings.isNullOrEmpty(mimeType)) {
121  LOGGER.log(Level.INFO, "Mimetype not known for file: {0}", file.getName()); //NON-NLS
122  try {
123  FileTypeDetector fileTypeDetector = new FileTypeDetector();
124  mimeType = fileTypeDetector.getMIMEType(file);
126  LOGGER.log(Level.SEVERE, "Failed to initialize FileTypeDetector.", ex); //NON-NLS
127  return;
128  }
129  }
130 
131  if (mimeType.equalsIgnoreCase("application/octet-stream")) {
132  return;
133  }
134  else {
135  FileTypeViewer viewer = getSupportingViewer(mimeType);
136  if (viewer != null) {
137  lastViewer = viewer;
138 
139  viewer.setFile(file);
140  this.removeAll();
141  this.add(viewer.getComponent());
142  this.repaint();
143  }
144  }
145 
146  }
147 
148  @Override
149  @NbBundle.Messages("ApplicationContentViewer.title=Application")
150  public String getTitle() {
151  return Bundle.ApplicationContentViewer_title();
152  }
153 
154  @Override
155  @NbBundle.Messages("ApplicationContentViewer.toolTip=Displays file contents.")
156  public String getToolTip() {
157  return Bundle.ApplicationContentViewer_toolTip();
158  }
159 
160  @Override
161  public DataContentViewer createInstance() {
162  return new FileViewer();
163  }
164 
165  @Override
166  public Component getComponent() {
167  return this;
168  }
169 
170  @Override
171  public void resetComponent() {
172 
173  if (lastViewer != null) {
174  lastViewer.resetComponent();
175  }
176  this.removeAll();
177  lastViewer = null;
178  }
179 
180  @Override
181  public boolean isSupported(Node node) {
182 
183  if (node == null) {
184  return false;
185  }
186 
187  AbstractFile aFile = node.getLookup().lookup(AbstractFile.class);
188  if (aFile == null) {
189  return false;
190  }
191 
192  String mimeType = aFile.getMIMEType();
193  if (Strings.isNullOrEmpty(mimeType)) {
194  LOGGER.log(Level.INFO, "Mimetype not known for file: {0}", aFile.getName()); //NON-NLS
195  try {
196  FileTypeDetector fileTypeDetector = new FileTypeDetector();
197  mimeType = fileTypeDetector.getMIMEType(aFile);
199  LOGGER.log(Level.SEVERE, "Failed to initialize FileTypeDetector.", ex); //NON-NLS
200  return false;
201  }
202  }
203 
204  if (mimeType.equalsIgnoreCase("application/octet-stream")) {
205  return false;
206  } else {
207  return (getSupportingViewer(mimeType) != null);
208  }
209 
210  }
211 
212  @Override
213  public int isPreferred(Node node) {
214  AbstractFile file = node.getLookup().lookup(AbstractFile.class);
215  String mimeType = file.getMIMEType();
216 
217  if (Strings.isNullOrEmpty(mimeType)) {
218  LOGGER.log(Level.INFO, "Mimetype not known for file: {0}", file.getName()); //NON-NLS
219  try {
220  FileTypeDetector fileTypeDetector = new FileTypeDetector();
221  mimeType = fileTypeDetector.getMIMEType(file);
223  LOGGER.log(Level.SEVERE, "Failed to initialize FileTypeDetector.", ex); //NON-NLS
224  return 0;
225  }
226  }
227 
228  if (mimeType.equalsIgnoreCase("application/octet-stream")) {
229  return 0;
230  } else {
231  if (null != getSupportingViewer(mimeType)) {
232  return CONFIDENCE_LEVEL;
233  }
234  }
235 
236  return 0;
237  }
238 }
FileTypeViewer getSupportingViewer(String mimeType)
Definition: FileViewer.java:85
synchronized static Logger getLogger(String name)
Definition: Logger.java:124

Copyright © 2012-2018 Basis Technology. Generated on: Tue Dec 18 2018
This work is licensed under a Creative Commons Attribution-Share Alike 3.0 United States License.