Autopsy  4.10.0
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-2019 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 final FileTypeViewer[] KNOWN_VIEWERS = new FileTypeViewer[]{
50  new SQLiteViewer(),
51  new PListViewer(),
52  new MediaFileViewer(),
53  new HtmlViewer()
54  };
55 
56  private FileTypeViewer lastViewer;
57 
61  public FileViewer() {
62 
63  // init the mimetype to viewer map
64  for (FileTypeViewer cv : KNOWN_VIEWERS) {
65  cv.getSupportedMIMETypes().forEach((mimeType) -> {
66  if (mimeTypeToViewerMap.containsKey(mimeType) == false) {
67  mimeTypeToViewerMap.put(mimeType, cv);
68  } else {
69  LOGGER.log(Level.WARNING, "Duplicate viewer for mimtype: {0}", mimeType); //NON-NLS
70  }
71  });
72  }
73 
74  initComponents();
75 
76  LOGGER.log(Level.INFO, "Created ApplicationContentViewer instance: {0}", this); //NON-NLS
77  }
78 
86  private FileTypeViewer getSupportingViewer(String mimeType) {
87  return mimeTypeToViewerMap.get(mimeType);
88  }
89 
95  @SuppressWarnings("unchecked")
96  // <editor-fold defaultstate="collapsed" desc="Generated Code">//GEN-BEGIN:initComponents
97  private void initComponents() {
98 
99  setLayout(new javax.swing.OverlayLayout(this));
100  }// </editor-fold>//GEN-END:initComponents
101 
102 
103  // Variables declaration - do not modify//GEN-BEGIN:variables
104  // End of variables declaration//GEN-END:variables
105 
106  @Override
107  public void setNode(Node selectedNode) {
108 
109  resetComponent();
110 
111  if (selectedNode == null) {
112  return;
113  }
114 
115  AbstractFile file = selectedNode.getLookup().lookup(AbstractFile.class);
116  if (file == null) {
117  return;
118  }
119 
120  String mimeType = file.getMIMEType();
121  if (Strings.isNullOrEmpty(mimeType)) {
122  LOGGER.log(Level.INFO, "Mimetype not known for file: {0}", file.getName()); //NON-NLS
123  try {
124  FileTypeDetector fileTypeDetector = new FileTypeDetector();
125  mimeType = fileTypeDetector.getMIMEType(file);
127  LOGGER.log(Level.SEVERE, "Failed to initialize FileTypeDetector.", ex); //NON-NLS
128  return;
129  }
130  }
131 
132  if (mimeType.equalsIgnoreCase("application/octet-stream")) {
133  return;
134  }
135  else {
136  FileTypeViewer viewer = getSupportingViewer(mimeType);
137  if (viewer != null) {
138  lastViewer = viewer;
139 
140  viewer.setFile(file);
141  this.removeAll();
142  this.add(viewer.getComponent());
143  this.repaint();
144  }
145  }
146 
147  }
148 
149  @Override
150  @NbBundle.Messages("ApplicationContentViewer.title=Application")
151  public String getTitle() {
152  return Bundle.ApplicationContentViewer_title();
153  }
154 
155  @Override
156  @NbBundle.Messages("ApplicationContentViewer.toolTip=Displays file contents.")
157  public String getToolTip() {
158  return Bundle.ApplicationContentViewer_toolTip();
159  }
160 
161  @Override
162  public DataContentViewer createInstance() {
163  return new FileViewer();
164  }
165 
166  @Override
167  public Component getComponent() {
168  return this;
169  }
170 
171  @Override
172  public void resetComponent() {
173 
174  if (lastViewer != null) {
175  lastViewer.resetComponent();
176  }
177  this.removeAll();
178  lastViewer = null;
179  }
180 
181  @Override
182  public boolean isSupported(Node node) {
183 
184  if (node == null) {
185  return false;
186  }
187 
188  AbstractFile aFile = node.getLookup().lookup(AbstractFile.class);
189  if (aFile == null) {
190  return false;
191  }
192 
193  String mimeType = aFile.getMIMEType();
194  if (Strings.isNullOrEmpty(mimeType)) {
195  LOGGER.log(Level.INFO, "Mimetype not known for file: {0}", aFile.getName()); //NON-NLS
196  try {
197  FileTypeDetector fileTypeDetector = new FileTypeDetector();
198  mimeType = fileTypeDetector.getMIMEType(aFile);
200  LOGGER.log(Level.SEVERE, "Failed to initialize FileTypeDetector.", ex); //NON-NLS
201  return false;
202  }
203  }
204 
205  if (mimeType.equalsIgnoreCase("application/octet-stream")) {
206  return false;
207  } else {
208  return (getSupportingViewer(mimeType) != null);
209  }
210 
211  }
212 
213  @Override
214  public int isPreferred(Node node) {
215  AbstractFile file = node.getLookup().lookup(AbstractFile.class);
216  String mimeType = file.getMIMEType();
217 
218  if (Strings.isNullOrEmpty(mimeType)) {
219  LOGGER.log(Level.INFO, "Mimetype not known for file: {0}", file.getName()); //NON-NLS
220  try {
221  FileTypeDetector fileTypeDetector = new FileTypeDetector();
222  mimeType = fileTypeDetector.getMIMEType(file);
224  LOGGER.log(Level.SEVERE, "Failed to initialize FileTypeDetector.", ex); //NON-NLS
225  return 0;
226  }
227  }
228 
229  if (mimeType.equalsIgnoreCase("application/octet-stream")) {
230  return 0;
231  } else {
232  if (null != getSupportingViewer(mimeType)) {
233  return CONFIDENCE_LEVEL;
234  }
235  }
236 
237  return 0;
238  }
239 }
FileTypeViewer getSupportingViewer(String mimeType)
Definition: FileViewer.java:86
synchronized static Logger getLogger(String name)
Definition: Logger.java:124

Copyright © 2012-2018 Basis Technology. Generated on: Fri Mar 22 2019
This work is licensed under a Creative Commons Attribution-Share Alike 3.0 United States License.