libload_reflective

Crates.iolibload_reflective
lib.rslibload_reflective
version0.1.14
created_at2024-11-04 15:19:27.792141+00
updated_at2025-02-14 13:36:38.949624+00
descriptionA package to reflectively load libraries from memory
homepage
repositoryhttps://github.com/mrLochness350/Libload-Reflective
max_upload_size
id1435121
size44,666
(mrLochness350)

documentation

README

Libload Reflective

maintenance-status Crates.io Version

This crate allows loading dynamic libraries into memory from bytes, rather than from disk. A lot of this code was taken from the libloading crate, because I thought their implementation of Symbol<T> was already done and it didn't need a lot of modifications for it to work with in-memory libraries. For Windows it uses Reflective DLL loading, and for Linux it uses anonymous file-descriptors to load the library into memory. I am by no means expecting people to use this, since it's still messy, and I want to clean and reformat the code to be prettier. Feel free to open issues or PRs to make it better.

I only tested this on Windows 11 and Ubuntu 22.04, so be advised.

Why?

I wanted to implement a custom "plugin" system for the C2 framework (payload and server) that I'm working on, and I couldn't find something that fit my needs, so I decided to implement my own system for this.

Example usage

type AddFn = fn(usize, usize) -> usize;

fn main() -> Result<(), ReflectError> {
    let data = vec![/*Library bytes*/]
    let lib = ReflectedLibrary::new(data)?;
    let add: Symbol<AddFn> = lib.get(b"add")?;
    let result = add(1,2);
    println!("Result: {res}");
    lib.close()?;
}

References

Commit count: 14

cargo fmt