Autopsy  4.21.0
Graphical digital forensics platform for The Sleuth Kit and other tools.
Python Development Setup

This page describes the basic concepts and setup that are needed for all types of Python modules. It is not needed if you are doing only Java module development.

Autopsy uses Jython (http://www.jython.org) to enable Python scripting. Jython looks like Python and gets converted into Java byte code and runs on the JVM. Its biggest limitations are:

Using it is very easy though in Autopsy and it allows you to access all of the Java services and classes that you need.

To develop a module, you should follow this section to get your environment setup and then read the later sections on the different types of modules.

There are also a set of tutorials that provide an easy introduction to the general ideas.

Basic Setup

-You don't really need anything to develop a python Autopsy module except for the standard Autopsy and your favorite text editor. We recommend IntelliJ IDEA or the Jython plug-in to NetBeans.

To install NetBeans' plug-in:

  1. Download and install the Jython 2.7 installer to desired location (http://www.jython.org/downloads.html).
  2. Download NetBeans Python plug-in zip file (http://plugins.netbeans.org/plugin/56795/python4netbeans802).
  3. Unpack the content (.nbm files) of the zip file to the desired location.
  4. In NetBeans go to Tools->Plugins. In Downloaded tab, click on Add Plugins, then choose extracted .nbm files.
  5. Setup Jython path from Tools->Python Platforms, click on new, then choose Jython.exe (usually in C:\Program files\Jython2.7\bin)

To install IntelliJ IDEA + Python plug-in:

  1. Download java JDK depending on platform. Install to desired location (https://bell-sw.com/pages/downloads/).
  2. Download and install IDEA Community Edition to desired location (https://www.jetbrains.com/idea/download/).
  3. Open IDEA and choose desired UI theme. Continue with default settings.
  4. Choose to either create a new empty project or open an existing one.
  5. It will ask you to modify Project Structure. Leave that for now and click OK.
  6. In File->Settings. Go to Plugins tab and click on Install JetBrains Plugin.
  7. Look for and install Python Community Edition. After the installation, it will ask you restart. Restart IDEA.
  8. In File->Project Structure. In Project tab, Project SDK, click on New and choose IntelliJ Platform Plugin SKD.
  9. It will ask you to configure the JKD first, click OK and navigate to the JDK folder location and click OK.
  10. After that it will ask you to choose the IntelliJ Platform Plugin SKD. It will most likely take you to it's location automatically. (Usually in C:\Program Files (x86)\JetBrains\IntelliJ IDEA Community Edition 14.1.5)
  11. In the drop down menu next to New button, choose IntelliJ IDEA Community Edition.
  12. Still in Project STructure, In Libraries tab, click on '+' to add new libraries. Choose desired autopsy modules (usually in C:\Program Files\Autopsy-3.1.3\autopsy\modules if you have executable version).

Creating a Basic Python Module

Packaging Structure

Autopsy requires that you put all of your Python modules into a single folder. This prevents naming collisions with other modules. You can name the folder what ever you want. You'll need to put all of the libraries that you depend on in there too.

You will need to copy this folder into Autopsy's Python script folder. Autopsy will scan this folder each time it looks for modules. You can find the location of this folder from the "Tools -> Python Scripts" menu item.

Module Creation

We have a growing number of sample Python scripts and therefore the easiest starting point for any Python script is probably to start with one of the public domain examples. This approach is a bit different than what you'd find with Java because the Java environment auto-creates the modules more.

This is the basic approach:

  1. Create a folder referenced in Packaging Structure.
  2. Copy one of the sample modules from the github repository (https://github.com/sleuthkit/autopsy/tree/develop/pythonExamples)
  3. Edit the sample module by looking for "TODO" references.

That's it. Autopsy will find the module each time it needs it and you can make updates without having to restart Autopsy each time.

Using External Libraries

If you need to bring in a library that is not part of the standard Jython distribution, then do the following:

  1. Copy the library file or folder into the folder that you made in Packaging Structure. For example, you may copy in folder called 'neededLib' that has a file named mylib.py in it. The end result be a folder structure such as myModuleFolder/neededLib/mylib.py.
  2. In your Python code, if you needed a class from mylib, then you'd have a line such as:
    1 from neededLib.mylib import neededClass

Jython will look in the module's folder to resolve these libraries.

If you bring in a library that uses native code, then you will get a runtime error when you try to load it.

Minor Gotchas

This section lists some helpful tips that we have found. These are all now in the sample modules, so refer to those for examples and a place to copy and paste from.

Distribution

To distribute and share your Python module, ZIP up the folder and send it around. Other users of the module should expand the ZIP file and drop the folder into their Autopsy Python folder.


Copyright © 2012-2022 Basis Technology. Generated on: Tue Feb 6 2024
This work is licensed under a Creative Commons Attribution-Share Alike 3.0 United States License.