FunctionID: Add scripts for creating and attaching FID databases

This commit is contained in:
Andras Gemes 2024-10-06 11:34:26 +02:00
parent 7d5a514f25
commit 16f549aaa5
No known key found for this signature in database
GPG Key ID: F1EF1E4F007ECBAB
2 changed files with 71 additions and 0 deletions

View File

@ -0,0 +1,35 @@
/* ###
* IP: GHIDRA
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
// Attach an existing FID database.
// The functionality is similar to "Tools -> Function ID -> Attach existing FidDb..."
// but this script can be executed in both GUI and headless modes.
// The attached database can later be populated,
// for example by `CreateMultipleLibraries.java` when running in headless mode or
// by "Tools -> Function ID -> Populate FidDb from programs..." when running in GUI mode.
//@category FunctionID
import ghidra.app.script.GhidraScript;
import ghidra.feature.fid.db.FidFileManager;
import java.io.File;
public class AttachFidDatabase extends GhidraScript {
@Override
protected void run() throws Exception {
File dbFile = askFile("Attach existing FidDb", "Attach");
FidFileManager.getInstance().addUserFidFile(dbFile);
}
}

View File

@ -0,0 +1,36 @@
/* ###
* IP: GHIDRA
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
// Create and add (attach) an empty FID database.
// The functionality is similar to "Tools -> Function ID -> Create new empty FidDb..."
// but this script can be executed in both GUI and headless modes.
// The created database can later be populated,
// for example by `CreateMultipleLibraries.java` when running in headless mode or
// by "Tools -> Function ID -> Populate FidDb from programs..." when running in GUI mode.
//@category FunctionID
import ghidra.app.script.GhidraScript;
import ghidra.feature.fid.db.FidFileManager;
import java.io.File;
public class CreateEmptyFidDatabase extends GhidraScript {
@Override
protected void run() throws Exception {
File dbFile = askFile("Create new FidDb file", "Create");
FidFileManager.getInstance().createNewFidDatabase(dbFile);
FidFileManager.getInstance().addUserFidFile(dbFile);
}
}