A parser and serializer for Adobe Local Shared Object (LSO) file format (.sol), AMF0 and AFM3 in 100% safe rust
The primary goal of this crate is to be as safe as possible against malformed and invalid input and to fail cleanly when this is identified.
rust
use std::fs::File;
use std::io::Read;
use flash_lso::read::Reader;
fn main() {
let mut x = File::open(path).expect("Couldn't open file");
let mut data = Vec::new();
let _ = x.read_to_end(&mut data).expect("Unable to read file");
let d = Reader::default().parse_full(&data).expect("Failed to parse lso file");
println!("{:#?}", d);
}
The web
directory contains an example web viewer for LSO files using yew. To run, first build into WASM like so
shell script
cd web
wasm-pack build --out-name wasm --out-dir ./static --target web --release
Then serve the static directory like so
```shell script
cargo install miniserve
miniserve ./static --index index.html ```
This project has a collection of integration tests to verify that it is able to serialize and then deserialize LSO files to produce output that is identical to it's input Also available is a lso-to-json project which allows dumping an LSO file to json for debugging and testing.
To enable serde support
toml
flash-lso = { version = "0.2.0", features = ["serde"] }
To enable (alpha) support for flex
toml
flash-lso = { version = "0.2.0", features = ["flex"] }
This project makes use of cargo-fuzz to ensure correct handling of invalid data
cargo fuzz run --release fuzz_amf3_body
This project is licensed under MIT