mirror of
https://github.com/jakcron/nstool
synced 2024-11-22 21:49:30 +00:00
[nstool] Where not guarenteed to control file position, IFile wrappers assert their position.
This commit is contained in:
parent
e1ccf81e54
commit
33313f208d
3 changed files with 24 additions and 11 deletions
|
@ -1,19 +1,16 @@
|
||||||
#include "AesCtrWrappedIFile.h"
|
#include "AesCtrWrappedIFile.h"
|
||||||
|
|
||||||
AesCtrWrappedIFile::AesCtrWrappedIFile(fnd::IFile* file, const crypto::aes::sAes128Key& key, const crypto::aes::sAesIvCtr& ctr) :
|
AesCtrWrappedIFile::AesCtrWrappedIFile(fnd::IFile* file, const crypto::aes::sAes128Key& key, const crypto::aes::sAesIvCtr& ctr) :
|
||||||
mOwnIFile(false),
|
AesCtrWrappedIFile(file, false, key, ctr)
|
||||||
mFile(file),
|
|
||||||
mKey(key),
|
|
||||||
mBaseCtr(ctr)
|
|
||||||
{
|
{
|
||||||
mScratch.alloc(kAesCtrScratchAllocSize);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
AesCtrWrappedIFile::AesCtrWrappedIFile(fnd::IFile* file, bool ownIfile, const crypto::aes::sAes128Key& key, const crypto::aes::sAesIvCtr& ctr) :
|
AesCtrWrappedIFile::AesCtrWrappedIFile(fnd::IFile* file, bool ownIfile, const crypto::aes::sAes128Key& key, const crypto::aes::sAesIvCtr& ctr) :
|
||||||
mOwnIFile(ownIfile),
|
mOwnIFile(ownIfile),
|
||||||
mFile(file),
|
mFile(file),
|
||||||
mKey(key),
|
mKey(key),
|
||||||
mBaseCtr(ctr)
|
mBaseCtr(ctr),
|
||||||
|
mFileOffset(0)
|
||||||
{
|
{
|
||||||
mScratch.alloc(kAesCtrScratchAllocSize);
|
mScratch.alloc(kAesCtrScratchAllocSize);
|
||||||
}
|
}
|
||||||
|
@ -33,13 +30,13 @@ size_t AesCtrWrappedIFile::size()
|
||||||
|
|
||||||
void AesCtrWrappedIFile::seek(size_t offset)
|
void AesCtrWrappedIFile::seek(size_t offset)
|
||||||
{
|
{
|
||||||
mFile->seek(offset);
|
mFileOffset = offset;
|
||||||
crypto::aes::AesIncrementCounter(mBaseCtr.iv, offset>>4, mCurrentCtr.iv);
|
|
||||||
mBlockOffset = offset & 0xf;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AesCtrWrappedIFile::read(byte_t* out, size_t len)
|
void AesCtrWrappedIFile::read(byte_t* out, size_t len)
|
||||||
{
|
{
|
||||||
|
internalSeek();
|
||||||
|
|
||||||
for (size_t i = 0; i < (len / kAesCtrScratchSize); i++)
|
for (size_t i = 0; i < (len / kAesCtrScratchSize); i++)
|
||||||
{
|
{
|
||||||
mFile->read(mScratch.getBytes() + mBlockOffset, kAesCtrScratchSize);
|
mFile->read(mScratch.getBytes() + mBlockOffset, kAesCtrScratchSize);
|
||||||
|
@ -55,6 +52,8 @@ void AesCtrWrappedIFile::read(byte_t* out, size_t len)
|
||||||
crypto::aes::AesCtr(mScratch.getBytes(), kAesCtrScratchAllocSize, mKey.key, mCurrentCtr.iv, mScratch.getBytes());
|
crypto::aes::AesCtr(mScratch.getBytes(), kAesCtrScratchAllocSize, mKey.key, mCurrentCtr.iv, mScratch.getBytes());
|
||||||
memcpy(out + read_pos, mScratch.getBytes() + mBlockOffset, read_len);
|
memcpy(out + read_pos, mScratch.getBytes() + mBlockOffset, read_len);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
seek(mFileOffset + len);
|
||||||
}
|
}
|
||||||
|
|
||||||
void AesCtrWrappedIFile::read(byte_t* out, size_t offset, size_t len)
|
void AesCtrWrappedIFile::read(byte_t* out, size_t offset, size_t len)
|
||||||
|
@ -65,6 +64,8 @@ void AesCtrWrappedIFile::read(byte_t* out, size_t offset, size_t len)
|
||||||
|
|
||||||
void AesCtrWrappedIFile::write(const byte_t* out, size_t len)
|
void AesCtrWrappedIFile::write(const byte_t* out, size_t len)
|
||||||
{
|
{
|
||||||
|
internalSeek();
|
||||||
|
|
||||||
for (size_t i = 0; i < (len / kAesCtrScratchSize); i++)
|
for (size_t i = 0; i < (len / kAesCtrScratchSize); i++)
|
||||||
{
|
{
|
||||||
memcpy(mScratch.getBytes() + mBlockOffset, out + (i * kAesCtrScratchSize), kAesCtrScratchSize);
|
memcpy(mScratch.getBytes() + mBlockOffset, out + (i * kAesCtrScratchSize), kAesCtrScratchSize);
|
||||||
|
@ -80,6 +81,8 @@ void AesCtrWrappedIFile::write(const byte_t* out, size_t len)
|
||||||
crypto::aes::AesCtr(mScratch.getBytes(), kAesCtrScratchAllocSize, mKey.key, mCurrentCtr.iv, mScratch.getBytes());
|
crypto::aes::AesCtr(mScratch.getBytes(), kAesCtrScratchAllocSize, mKey.key, mCurrentCtr.iv, mScratch.getBytes());
|
||||||
mFile->write(mScratch.getBytes() + mBlockOffset, write_len);
|
mFile->write(mScratch.getBytes() + mBlockOffset, write_len);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
seek(mFileOffset + len);
|
||||||
}
|
}
|
||||||
|
|
||||||
void AesCtrWrappedIFile::write(const byte_t* out, size_t offset, size_t len)
|
void AesCtrWrappedIFile::write(const byte_t* out, size_t offset, size_t len)
|
||||||
|
@ -87,3 +90,10 @@ void AesCtrWrappedIFile::write(const byte_t* out, size_t offset, size_t len)
|
||||||
seek(offset);
|
seek(offset);
|
||||||
write(out, len);
|
write(out, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AesCtrWrappedIFile::internalSeek()
|
||||||
|
{
|
||||||
|
mFile->seek(mFileOffset);
|
||||||
|
crypto::aes::AesIncrementCounter(mBaseCtr.iv, mFileOffset>>4, mCurrentCtr.iv);
|
||||||
|
mBlockOffset = mFileOffset & 0xf;
|
||||||
|
}
|
|
@ -25,6 +25,9 @@ private:
|
||||||
crypto::aes::sAes128Key mKey;
|
crypto::aes::sAes128Key mKey;
|
||||||
crypto::aes::sAesIvCtr mBaseCtr, mCurrentCtr;
|
crypto::aes::sAesIvCtr mBaseCtr, mCurrentCtr;
|
||||||
size_t mBlockOffset;
|
size_t mBlockOffset;
|
||||||
|
size_t mFileOffset;
|
||||||
|
|
||||||
fnd::MemoryBlob mScratch;
|
fnd::MemoryBlob mScratch;
|
||||||
|
|
||||||
|
void internalSeek();
|
||||||
};
|
};
|
|
@ -43,7 +43,7 @@ void OffsetAdjustedIFile::read(byte_t* out, size_t len)
|
||||||
// assert proper position in file
|
// assert proper position in file
|
||||||
mFile->seek(mCurrentOffset + mBaseOffset);
|
mFile->seek(mCurrentOffset + mBaseOffset);
|
||||||
mFile->read(out, len);
|
mFile->read(out, len);
|
||||||
mCurrentOffset += len;
|
seek(mCurrentOffset + len);
|
||||||
}
|
}
|
||||||
|
|
||||||
void OffsetAdjustedIFile::read(byte_t* out, size_t offset, size_t len)
|
void OffsetAdjustedIFile::read(byte_t* out, size_t offset, size_t len)
|
||||||
|
@ -57,7 +57,7 @@ void OffsetAdjustedIFile::write(const byte_t* out, size_t len)
|
||||||
// assert proper position in file
|
// assert proper position in file
|
||||||
mFile->seek(mCurrentOffset + mBaseOffset);
|
mFile->seek(mCurrentOffset + mBaseOffset);
|
||||||
mFile->write(out, len);
|
mFile->write(out, len);
|
||||||
mCurrentOffset += len;
|
seek(mCurrentOffset + len);
|
||||||
}
|
}
|
||||||
|
|
||||||
void OffsetAdjustedIFile::write(const byte_t* out, size_t offset, size_t len)
|
void OffsetAdjustedIFile::write(const byte_t* out, size_t offset, size_t len)
|
||||||
|
|
Loading…
Reference in a new issue