updated dependencies

This commit is contained in:
tihmstar 2017-04-25 16:05:28 +02:00
parent e2d0d263e5
commit 42b37c5c71
4 changed files with 7 additions and 60 deletions

2
external/img4tool vendored

@ -1 +1 @@
Subproject commit eb552125956b08425cd3f85b4de1ff49756ca794 Subproject commit 7f4ac073d934bb669c7da7d1d39fae8db3a0929a

2
external/tsschecker vendored

@ -1 +1 @@
Subproject commit 7d267698cb16ab4699fa9cba20783ee041ac999e Subproject commit 84c7c8e54232af9f4d875055cfc89cac8e046fb8

View file

@ -167,7 +167,7 @@ plist_t futurerestore::nonceMatchesApTickets(){
if (_client->image4supported){ if (_client->image4supported){
for (int i=0; i< _im4ms.size(); i++){ for (int i=0; i< _im4ms.size(); i++){
if (memcmp(realnonce, (unsigned const char*)getNonceFromIM4M(_im4ms[i],NULL), realNonceSize) == 0) return _aptickets[i]; if (memcmp(realnonce, (unsigned const char*)getBNCHFromIM4M(_im4ms[i],NULL), realNonceSize) == 0) return _aptickets[i];
} }
}else{ }else{
for (int i=0; i< _im4ms.size(); i++){ for (int i=0; i< _im4ms.size(); i++){
@ -196,7 +196,7 @@ const char *futurerestore::nonceMatchesIM4Ms(){
if (_client->image4supported) { if (_client->image4supported) {
for (int i=0; i< _im4ms.size(); i++){ for (int i=0; i< _im4ms.size(); i++){
if (memcmp(realnonce, (unsigned const char*)getNonceFromIM4M(_im4ms[i],NULL), realNonceSize) == 0) return _im4ms[i]; if (memcmp(realnonce, (unsigned const char*)getBNCHFromIM4M(_im4ms[i],NULL), realNonceSize) == 0) return _im4ms[i];
} }
}else{ }else{
for (int i=0; i< _im4ms.size(); i++){ for (int i=0; i< _im4ms.size(); i++){
@ -259,7 +259,7 @@ void futurerestore::waitForNonce(){
reterror(-77, "Error: waitForNonce is not supported on 32bit devices\n"); reterror(-77, "Error: waitForNonce is not supported on 32bit devices\n");
for (auto im4m : _im4ms){ for (auto im4m : _im4ms){
nonces.push_back(getNonceFromIM4M(im4m,&nonceSize)); nonces.push_back(getBNCHFromIM4M(im4m,&nonceSize));
} }
waitForNonce(nonces,nonceSize); waitForNonce(nonces,nonceSize);
@ -988,58 +988,6 @@ error:
return ret; return ret;
} }
char *futurerestore::getNonceFromIM4M(const char* im4m, size_t *nonceSize){
char *ret = NULL;
char *mainSet = NULL;
char *manbSet = NULL;
char *manpSet = NULL;
char *nonceOctet = NULL;
char *bnch = NULL;
char *manb = NULL;
char *manp = NULL;
if (!im4m) reterror(-15, "Got empty IM4M\n");
if (asn1ElementsInObject(im4m)< 3){
error("unexpected number of Elements in IM4M sequence\n");
goto error;
}
mainSet = asn1ElementAtIndex(im4m, 2);
manb = getValueForTagInSet((char*)mainSet, 0x4d414e42); //MANB priv Tag
if (asn1ElementsInObject(manb)< 2){
error("unexpected number of Elements in MANB sequence\n");
goto error;
}
manbSet = asn1ElementAtIndex(manb, 1);
manp = getValueForTagInSet((char*)manbSet, 0x4d414e50); //MANP priv Tag
if (asn1ElementsInObject(manp)< 2){
error("unexpected number of Elements in MANP sequence\n");
goto error;
}
manpSet = asn1ElementAtIndex(manp, 1);
bnch = getValueForTagInSet((char*)manpSet, 0x424e4348); //BNCH priv Tag
if (asn1ElementsInObject(bnch)< 2){
error("unexpected number of Elements in BNCH sequence\n");
goto error;
}
nonceOctet = (char*)asn1ElementAtIndex(bnch, 1);
nonceOctet++;
ret = (char*)malloc(asn1Len(nonceOctet).dataLen);
if (ret){
memcpy(ret, nonceOctet + asn1Len(nonceOctet).sizeBytes, asn1Len(nonceOctet).dataLen);
if (nonceSize) *nonceSize = asn1Len(nonceOctet).dataLen;
}
error:
return ret;
}
uint64_t futurerestore::getEcidFromIM4M(const char* im4m){ uint64_t futurerestore::getEcidFromIM4M(const char* im4m){
uint64_t ret = 0; uint64_t ret = 0;
char *mainSet = NULL; char *mainSet = NULL;
@ -1096,8 +1044,8 @@ error:
char *futurerestore::getNonceFromAPTicket(const char* apticketPath){ char *futurerestore::getNonceFromAPTicket(const char* apticketPath){
char *ret = NULL; char *ret = NULL;
if (char *im4m = im4mFormShshFile(apticketPath)){ if (char *im4m = im4mFormShshFile(apticketPath,NULL)){
ret = getNonceFromIM4M(im4m,NULL); ret = getBNCHFromIM4M(im4m,NULL);
free(im4m); free(im4m);
} }
return ret; return ret;

View file

@ -101,7 +101,6 @@ public:
static const char *getRamdiskHashFromSCAB(const char* scab, size_t *hashSize); static const char *getRamdiskHashFromSCAB(const char* scab, size_t *hashSize);
static char *getNonceFromSCAB(const char* scab, size_t *nonceSize); static char *getNonceFromSCAB(const char* scab, size_t *nonceSize);
static uint64_t getEcidFromSCAB(const char* scab); static uint64_t getEcidFromSCAB(const char* scab);
static char *getNonceFromIM4M(const char* im4m, size_t *nonceSize);
static uint64_t getEcidFromIM4M(const char* im4m); static uint64_t getEcidFromIM4M(const char* im4m);
static char *getNonceFromAPTicket(const char* apticketPath); static char *getNonceFromAPTicket(const char* apticketPath);
static plist_t loadPlistFromFile(const char *path); static plist_t loadPlistFromFile(const char *path);