edmcman / ghidra-scala-loader

An extension to load Ghidra scripts written in Scala
28 stars 7 forks source link
ghidra scala

Build Status Dynamic YAML Badge

Introduction

Love ghidra but hate Java? If so, then this extension is for you! Just load this extension, and Ghidra will see and be able to load any scripts written in Scala. Just make sure their filename ends in .scala and drop them into any ghidra_scripts directory.

Compilation

If you want to build the extension yourself, make sure you have gradle installed, and then run GHIDRA_INSTALL_DIR=/path/to/ghidra gradle buildExtension. If all goes well, you should get a message like:

> Task :buildExtension

Created ghidra_9.2_PUBLIC_20201117_ghidra-scala-loader.zip in /home/ed/Documents/ghidra-scala-loader/dist

BUILD SUCCESSFUL in 11s
4 actionable tasks: 1 executed, 3 up-to-date

In this case, the file dist/ghidra_9.2_PUBLIC_20201117_ghidra-scala-loader.zip is your newly built extension.

Installation

Start Ghidra, and in the initial window (i.e., not the Code Browser), open the File menu, and select Install Extensions. Click the small plus icon in the top right of the window, and select the extension zip file that you built above. This should add an extension into the list, ScalaScriptProvider. Make sure the checkbox is ticked, and click OK to close the window. Ghidra will tell you that you need to restart to load the extension. Do so.

To make sure the extension loaded correctly, open the Code Browser, and under the Window menu, select Script Manager. If all is well, you should see a HelloWorld.scala script. Right click it, and select Run. You should see the hello world message print out to the Console.

Requirements

This extension should work with JDK 17 or 21, but the prebuilt Github extensions will only work with the JDK version required by the Ghidra version they are built for. If you want to use a different JDK version, you will need to build the extension yourself.

Supported Versions

Dynamic YAML Badge