From d4c5c76dc7e29c14b0fe55a911dca19378e2b61b Mon Sep 17 00:00:00 2001 From: lifegpc Date: Thu, 9 Apr 2026 12:39:28 +0800 Subject: [PATCH] Add AlteredPinkCrypt (untested) --- .gitattributes | 1 + msg_tool_xp3data/bin/altered_pink.bin | Bin 0 -> 256 bytes msg_tool_xp3data/crypt.json | 4 ++++ msg_tool_xp3data/lib.rs | 3 +++ src/scripts/kirikiri/archive/xp3/crypt/mod.rs | 21 ++++++++++++++++++ 5 files changed, 29 insertions(+) create mode 100644 msg_tool_xp3data/bin/altered_pink.bin diff --git a/.gitattributes b/.gitattributes index dd46d0f..71d16ea 100644 --- a/.gitattributes +++ b/.gitattributes @@ -1 +1,2 @@ +msg_tool_xp3data/bin/*.bin binary msg_tool_xp3data/cx_cb/*.bin binary diff --git a/msg_tool_xp3data/bin/altered_pink.bin b/msg_tool_xp3data/bin/altered_pink.bin new file mode 100644 index 0000000000000000000000000000000000000000..dab50f7271c87d7ea24d13275c22a0b514867246 GIT binary patch literal 256 zcmV+b0ssC(_^k-vw$;dpcfYDbb@kJOaag3U8&jEzCtJdQdd-b9S?i|yd;l55 zswDV?&G#TntMSzVZ+wvmeT|8Hab=mCZ#o=F String { decoder.read_to_string(&mut out).unwrap(); out } + +/// AlteredPink KeyTable +pub const ALTERED_PINK_KEY_TABLE: &[u8] = include_bytes!("bin/altered_pink.bin"); diff --git a/src/scripts/kirikiri/archive/xp3/crypt/mod.rs b/src/scripts/kirikiri/archive/xp3/crypt/mod.rs index 0a2769f..a15b18b 100644 --- a/src/scripts/kirikiri/archive/xp3/crypt/mod.rs +++ b/src/scripts/kirikiri/archive/xp3/crypt/mod.rs @@ -163,6 +163,7 @@ enum CryptType { DieselmineCrypt, DameganeCrypt, NephriteCrypt, + AlteredPinkCrypt, } #[derive(Clone, Debug, Deserialize)] @@ -253,6 +254,7 @@ impl Schema { CryptType::DieselmineCrypt => Box::new(DieselmineCrypt::new(self.base.clone())), CryptType::DameganeCrypt => Box::new(DameganeCrypt::new(self.base.clone())), CryptType::NephriteCrypt => Box::new(NephriteCrypt::new(self.base.clone())), + CryptType::AlteredPinkCrypt => Box::new(AlteredPinkCrypt::new(self.base.clone())), }) } } @@ -878,6 +880,20 @@ impl Read for NephriteCryptReader { } } +seek_crypt_filehash_key_u8_impl!(AlteredPinkCrypt, AlteredPinkCryptReader); + +impl Read for AlteredPinkCryptReader { + fn read(&mut self, buf: &mut [u8]) -> std::io::Result { + let readed = self.inner.read(buf)?; + for (i, t) in (&mut buf[..readed]).iter_mut().enumerate() { + let offset = self.seg_start + self.pos + i as u64; + *t ^= ALTERED_PINK_KEY_TABLE[(offset & 0xFF) as usize]; + } + self.pos += readed as u64; + Ok(readed) + } +} + #[test] fn test_deserialize_crypt() { for (key, schema) in CRYPT_SCHEMA.iter() { @@ -891,3 +907,8 @@ fn test_cx_cb_table() { println!("Key: {}, List length: {}", key, list.len()); } } + +#[test] +fn test_altered_pink_key_table() { + assert_eq!(ALTERED_PINK_KEY_TABLE.len(), 0x100); +}