2010-12-08 07:26:18 +00:00
|
|
|
#ifndef WAD_H
|
|
|
|
#define WAD_H
|
|
|
|
|
|
|
|
#include "includes.h"
|
|
|
|
class Wad
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
//create a wad instance from a bytearray containing a wad
|
2010-12-23 16:17:46 +00:00
|
|
|
Wad( const QByteArray &stuff = QByteArray() );
|
2010-12-08 07:26:18 +00:00
|
|
|
|
|
|
|
//create a wad object from a list of byteArrays.
|
|
|
|
//the first one should be the tmd, the second one the ticket, and the rest are the contents, in order
|
|
|
|
//it will use the global cert unless one is given with SetCert
|
2010-12-23 16:17:46 +00:00
|
|
|
Wad( const QList< QByteArray > &stuff, bool isEncrypted = true );
|
2010-12-08 07:26:18 +00:00
|
|
|
|
|
|
|
//check if this wad is valid
|
|
|
|
bool IsOk(){ return ok; }
|
|
|
|
|
|
|
|
//set the cert for this wad
|
2010-12-23 16:17:46 +00:00
|
|
|
void SetCert( const QByteArray &stuff );
|
2010-12-08 07:26:18 +00:00
|
|
|
|
|
|
|
//returns the tid of the tmd of this wad( which may be different than the one in the ticket if somebody did something stupid )
|
|
|
|
quint64 Tid();
|
|
|
|
|
|
|
|
//set the tid in the ticket&tmd and fakesign the wad
|
2010-12-09 11:30:25 +00:00
|
|
|
bool SetTid( quint64 tid );
|
|
|
|
|
2010-12-23 07:32:10 +00:00
|
|
|
//set the ios in the ticket&tmd and fakesign the wad
|
|
|
|
bool SetIOS( quint32 ios );
|
|
|
|
|
|
|
|
//set the tmd to allow AHBPROT removal
|
|
|
|
bool SetAhb( bool remove = true );
|
|
|
|
|
|
|
|
//set the tmd to allow direct disc access
|
|
|
|
bool SetDiskAccess( bool allow = true );
|
|
|
|
|
2010-12-09 11:30:25 +00:00
|
|
|
//replace a content of this wad, update the size & hash in the tmd and sign it
|
|
|
|
//ba should be decrypted
|
2010-12-23 16:17:46 +00:00
|
|
|
bool ReplaceContent( quint16 idx, const QByteArray &ba );
|
2010-12-08 07:26:18 +00:00
|
|
|
|
|
|
|
//add a new content to this wad and fakesign
|
|
|
|
//if the data is encrypted, set that arguement to true
|
|
|
|
//index is the index used for the new entry, default is after all the others
|
2010-12-09 11:30:25 +00:00
|
|
|
//void AddContent( const QByteArray &stuff, quint16 type, bool isEncrypted = false, quint16 index = 0xffff );
|
2010-12-08 07:26:18 +00:00
|
|
|
|
|
|
|
//remove a content from this wad
|
2010-12-09 11:30:25 +00:00
|
|
|
//void RemoveContent( quint16 index );
|
2010-12-08 07:26:18 +00:00
|
|
|
|
|
|
|
//set the global cert that will be used for all created
|
|
|
|
static void SetGlobalCert( const QByteArray &stuff );
|
|
|
|
|
|
|
|
//pack a wad from the given directory
|
2010-12-23 16:17:46 +00:00
|
|
|
//returns a bytearray containing a wad reading for writing to a file
|
|
|
|
//or an empty bytearray on error
|
|
|
|
//! dir should be a directory containing a tmd ( "*.tmd" or "tmd.*" ), a ticket ( "*.tik" or "cetk" ),
|
|
|
|
//! all the contents ( <cid>.app :where cid is the correct cid from the tmd, not the "0, 1, 2, 3..." bullshit some broken wad-unpackers create )
|
|
|
|
//! if any of the .apps do not match in size or hash what is in the TMD, then the TMD will be updated and fakesigned
|
|
|
|
//! a cert ( "*.cert" ) is also supported, but not required
|
2010-12-08 18:07:57 +00:00
|
|
|
static QByteArray FromDirectory( QDir dir );
|
2010-12-08 07:26:18 +00:00
|
|
|
|
|
|
|
//get a assembled wad from the list of parts
|
|
|
|
//the first one should be the tmd, the second one the ticket, and the rest are the contents, in order
|
|
|
|
//it will use the global cert
|
2010-12-23 16:17:46 +00:00
|
|
|
static QByteArray FromPartList( const QList< QByteArray > &stuff, bool isEncrypted = true );
|
2010-12-08 07:26:18 +00:00
|
|
|
|
|
|
|
//get all the parts of this wad put together in a wad ready for writing to disc or whatever
|
2010-12-23 16:17:46 +00:00
|
|
|
const QByteArray Data( quint32 magicWord = 0x49730000, const QByteArray &footer = QByteArray() );
|
2010-12-16 20:07:38 +00:00
|
|
|
|
2010-12-21 20:01:39 +00:00
|
|
|
//get the tmd for the wad
|
|
|
|
const QByteArray getTmd();
|
2010-12-16 20:07:38 +00:00
|
|
|
|
2010-12-21 20:01:39 +00:00
|
|
|
//get the tik for the wad
|
|
|
|
const QByteArray getTik();
|
2010-12-08 07:26:18 +00:00
|
|
|
|
|
|
|
//get the decrypted data from a content
|
|
|
|
const QByteArray Content( quint16 i );
|
|
|
|
|
2010-12-21 20:01:39 +00:00
|
|
|
//get the number of contents
|
|
|
|
quint32 content_count();
|
2010-12-16 20:07:38 +00:00
|
|
|
|
2010-12-08 07:26:18 +00:00
|
|
|
//get the last error encountered while trying to do something
|
|
|
|
const QString LastError(){ return errStr; }
|
|
|
|
|
2010-12-08 18:07:57 +00:00
|
|
|
//get a name for a wad as it would be seen in a wii disc update partition
|
|
|
|
//if a path is given, it will check that path for existing wads with the name and append a number to the end "(1)" to avoid duplicate files
|
|
|
|
//returns an empty string if it cant guess the title based on TID
|
2010-12-23 16:17:46 +00:00
|
|
|
static QString WadName( quint64 tid, quint16 version, const QString &path = QString() );
|
2010-12-08 18:07:57 +00:00
|
|
|
|
2010-12-09 11:30:25 +00:00
|
|
|
//get this Wad's name as it would appear on a disc update partition
|
2010-12-23 16:17:46 +00:00
|
|
|
QString WadName( const QString &path = QString() );
|
2010-12-08 18:07:57 +00:00
|
|
|
|
2010-12-08 07:26:18 +00:00
|
|
|
private:
|
|
|
|
bool ok;
|
|
|
|
QString errStr;
|
|
|
|
|
|
|
|
//keep encrypted parts here
|
|
|
|
QList< QByteArray > partsEnc;
|
|
|
|
QByteArray tmdData;
|
|
|
|
QByteArray tikData;
|
|
|
|
QByteArray certData;
|
|
|
|
|
2010-12-23 16:17:46 +00:00
|
|
|
void Err( const QString &str );
|
2010-12-08 07:26:18 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // WAD_H
|