mirror of
https://github.com/NationalSecurityAgency/ghidra.git
synced 2025-10-03 01:39:21 +02:00

Remove unnecessary boilerplate impls that returned null. Build info string better, handle the GTree node where a sub-file system is mounted so that both are included in the info display. Fix missing img3 icon.
182 lines
5.4 KiB
Java
182 lines
5.4 KiB
Java
/* ###
|
|
* 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.
|
|
*/
|
|
package skeleton;
|
|
|
|
import java.io.*;
|
|
import java.util.*;
|
|
|
|
import ghidra.app.util.bin.ByteProvider;
|
|
import ghidra.app.util.bin.ByteProviderInputStream;
|
|
import ghidra.formats.gfilesystem.*;
|
|
import ghidra.formats.gfilesystem.annotations.FileSystemInfo;
|
|
import ghidra.formats.gfilesystem.factory.GFileSystemFactoryFull;
|
|
import ghidra.formats.gfilesystem.factory.GFileSystemProbeFull;
|
|
import ghidra.util.exception.CancelledException;
|
|
import ghidra.util.task.TaskMonitor;
|
|
|
|
/**
|
|
* TODO: Provide class-level documentation that describes what this file system does.
|
|
*/
|
|
@FileSystemInfo(type = "fstypegoeshere", // ([a-z0-9]+ only)
|
|
description = "File system description goes here", factory = SkeletonFileSystem.MyFileSystemFactory.class)
|
|
public class SkeletonFileSystem implements GFileSystem {
|
|
|
|
private final FSRLRoot fsFSRL;
|
|
private FileSystemIndexHelper<MyMetadata> fsih;
|
|
private FileSystemRefManager refManager = new FileSystemRefManager(this);
|
|
|
|
private ByteProvider provider;
|
|
|
|
/**
|
|
* File system constructor.
|
|
*
|
|
* @param fsFSRL The root {@link FSRL} of the file system.
|
|
* @param provider The file system provider.
|
|
*/
|
|
public SkeletonFileSystem(FSRLRoot fsFSRL, ByteProvider provider) {
|
|
this.fsFSRL = fsFSRL;
|
|
this.provider = provider;
|
|
this.fsih = new FileSystemIndexHelper<>(this, fsFSRL);
|
|
}
|
|
|
|
/**
|
|
* Mounts (opens) the file system.
|
|
*
|
|
* @param monitor A cancellable task monitor.
|
|
*/
|
|
public void mount(TaskMonitor monitor) {
|
|
monitor.setMessage("Opening " + SkeletonFileSystem.class.getSimpleName() + "...");
|
|
|
|
// TODO: Customize how things in the file system are stored. The following should be
|
|
// treated as pseudo-code.
|
|
for (MyMetadata metadata : new MyMetadata[10]) {
|
|
if (monitor.isCancelled()) {
|
|
break;
|
|
}
|
|
fsih.storeFile(metadata.path, fsih.getFileCount(), false, metadata.size, metadata);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void close() throws IOException {
|
|
refManager.onClose();
|
|
if (provider != null) {
|
|
provider.close();
|
|
provider = null;
|
|
}
|
|
fsih.clear();
|
|
}
|
|
|
|
@Override
|
|
public String getName() {
|
|
return fsFSRL.getContainer().getName();
|
|
}
|
|
|
|
@Override
|
|
public FSRLRoot getFSRL() {
|
|
return fsFSRL;
|
|
}
|
|
|
|
@Override
|
|
public boolean isClosed() {
|
|
return provider == null;
|
|
}
|
|
|
|
@Override
|
|
public int getFileCount() {
|
|
return fsih.getFileCount();
|
|
}
|
|
|
|
@Override
|
|
public FileSystemRefManager getRefManager() {
|
|
return refManager;
|
|
}
|
|
|
|
@Override
|
|
public GFile lookup(String path) throws IOException {
|
|
return fsih.lookup(path);
|
|
}
|
|
|
|
@Override
|
|
public InputStream getInputStream(GFile file, TaskMonitor monitor)
|
|
throws IOException, CancelledException {
|
|
|
|
// TODO: Get an input stream for a file. The following is an example of how the metadata
|
|
// might be used to get an input stream from a stored provider offset.
|
|
MyMetadata metadata = fsih.getMetadata(file);
|
|
return (metadata != null)
|
|
? new ByteProviderInputStream(provider, metadata.offset, metadata.size)
|
|
: null;
|
|
}
|
|
|
|
@Override
|
|
public List<GFile> getListing(GFile directory) throws IOException {
|
|
return fsih.getListing(directory);
|
|
}
|
|
|
|
@Override
|
|
public String getInfo(GFile file, TaskMonitor monitor) {
|
|
MyMetadata metadata = fsih.getMetadata(file);
|
|
return (metadata == null) ? null : FSUtilities.infoMapToString(getInfoMap(metadata));
|
|
}
|
|
|
|
public Map<String, String> getInfoMap(MyMetadata metadata) {
|
|
Map<String, String> info = new LinkedHashMap<>();
|
|
|
|
// TODO: Customize information about a file system entry. The following is sample
|
|
// information that might be useful.
|
|
info.put("Name", metadata.name);
|
|
info.put("Size",
|
|
"" + Long.toString(metadata.size) + ", 0x" + Long.toHexString(metadata.size));
|
|
return info;
|
|
}
|
|
|
|
// TODO: Customize for the real file system.
|
|
public static class MyFileSystemFactory
|
|
implements GFileSystemFactoryFull<SkeletonFileSystem>, GFileSystemProbeFull {
|
|
|
|
@Override
|
|
public SkeletonFileSystem create(FSRL containerFSRL, FSRLRoot targetFSRL,
|
|
ByteProvider byteProvider, File containerFile, FileSystemService fsService,
|
|
TaskMonitor monitor) throws IOException, CancelledException {
|
|
|
|
SkeletonFileSystem fs = new SkeletonFileSystem(targetFSRL, byteProvider);
|
|
fs.mount(monitor);
|
|
return fs;
|
|
}
|
|
|
|
@Override
|
|
public boolean probe(FSRL containerFSRL, ByteProvider byteProvider, File containerFile,
|
|
FileSystemService fsService, TaskMonitor monitor)
|
|
throws IOException, CancelledException {
|
|
|
|
// TODO: Quickly and efficiently examine the bytes in 'byteProvider' to determine if
|
|
// it's a valid file system. If it is, return true.
|
|
|
|
return false;
|
|
}
|
|
}
|
|
|
|
// TODO: Customize with metadata from files in the real file system. This is just a stub.
|
|
// The elements of the file system will most likely be modeled by Java classes external to this
|
|
// file.
|
|
private static class MyMetadata {
|
|
private String name;
|
|
private String path;
|
|
private long offset;
|
|
private long size;
|
|
}
|
|
}
|