You've already forked AstralRinth
forked from xxxOFFxxx/AstralRinth
* typos :help_me: * (part 1/?) massive cleanup to make the code more Rust-ic and cut down heap allocations. * (part 2/?) massive cleanup to make the code more Rust-ic and cut down heap allocations. * (part 3/?) cut down some pretty major heap allocations here - more Bytes and BytesMuts, less Vec<u8>s also I don't really understand why you need to `to_vec` when you don't really use it again afterwards * (part 4/?) deduplicate error handling in backblaze logic * (part 5/?) fixes, cleanups, refactors, and reformatting * (part 6/?) cleanups and refactors * remove loads of `as_str` in types that already are `Display` * Revert "remove loads of `as_str` in types that already are `Display`" This reverts commit 4f974310cfb167ceba03001d81388db4f0fbb509. * reformat and move routes util to the util module * use streams * Run prepare + formatting issues Co-authored-by: Jai A <jaiagr+gpg@pm.me> Co-authored-by: Geometrically <18202329+Geometrically@users.noreply.github.com>
91 lines
2.6 KiB
Rust
91 lines
2.6 KiB
Rust
use crate::validate::{SupportedGameVersions, ValidationError, ValidationResult};
|
|
use chrono::{DateTime, NaiveDateTime, Utc};
|
|
use std::io::Cursor;
|
|
use zip::ZipArchive;
|
|
|
|
pub struct ForgeValidator;
|
|
|
|
impl super::Validator for ForgeValidator {
|
|
fn get_file_extensions(&self) -> &[&str] {
|
|
&["jar", "zip"]
|
|
}
|
|
|
|
fn get_project_types(&self) -> &[&str] {
|
|
&["mod"]
|
|
}
|
|
|
|
fn get_supported_loaders(&self) -> &[&str] {
|
|
&["forge"]
|
|
}
|
|
|
|
fn get_supported_game_versions(&self) -> SupportedGameVersions {
|
|
// Time since release of 1.13, the first forge version which uses the new TOML system
|
|
SupportedGameVersions::PastDate(DateTime::<Utc>::from_utc(
|
|
NaiveDateTime::from_timestamp(1540122067, 0),
|
|
Utc,
|
|
))
|
|
}
|
|
|
|
fn validate(
|
|
&self,
|
|
archive: &mut ZipArchive<Cursor<&[u8]>>,
|
|
) -> Result<ValidationResult, ValidationError> {
|
|
archive.by_name("META-INF/mods.toml").map_err(|_| {
|
|
ValidationError::InvalidInputError("No mods.toml present for Forge file.".into())
|
|
})?;
|
|
|
|
if !archive.file_names().any(|name| name.ends_with(".class")) {
|
|
return Ok(ValidationResult::Warning(
|
|
"Forge mod file is a source file!".into(),
|
|
));
|
|
}
|
|
|
|
//TODO: Check if file is a dev JAR?
|
|
|
|
Ok(ValidationResult::Pass)
|
|
}
|
|
}
|
|
|
|
pub struct LegacyForgeValidator;
|
|
|
|
impl super::Validator for LegacyForgeValidator {
|
|
fn get_file_extensions(&self) -> &[&str] {
|
|
&["jar", "zip"]
|
|
}
|
|
|
|
fn get_project_types(&self) -> &[&str] {
|
|
&["mod"]
|
|
}
|
|
|
|
fn get_supported_loaders(&self) -> &[&str] {
|
|
&["forge"]
|
|
}
|
|
|
|
fn get_supported_game_versions(&self) -> SupportedGameVersions {
|
|
// Times between versions 1.5.2 to 1.12.2, which all use the legacy way of defining mods
|
|
SupportedGameVersions::Range(
|
|
DateTime::from_utc(NaiveDateTime::from_timestamp(1366818300, 0), Utc),
|
|
DateTime::from_utc(NaiveDateTime::from_timestamp(1505810340, 0), Utc),
|
|
)
|
|
}
|
|
|
|
fn validate(
|
|
&self,
|
|
archive: &mut ZipArchive<Cursor<&[u8]>>,
|
|
) -> Result<ValidationResult, ValidationError> {
|
|
archive.by_name("mcmod.info").map_err(|_| {
|
|
ValidationError::InvalidInputError("No mcmod.info present for Forge file.".into())
|
|
})?;
|
|
|
|
if !archive.file_names().any(|name| name.ends_with(".class")) {
|
|
return Ok(ValidationResult::Warning(
|
|
"Forge mod file is a source file!".into(),
|
|
));
|
|
}
|
|
|
|
//TODO: Check if file is a dev JAR?
|
|
|
|
Ok(ValidationResult::Pass)
|
|
}
|
|
}
|