summaryrefslogtreecommitdiff
path: root/protocols/Skype/keypacker/keypacker.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'protocols/Skype/keypacker/keypacker.cpp')
-rw-r--r--protocols/Skype/keypacker/keypacker.cpp112
1 files changed, 56 insertions, 56 deletions
diff --git a/protocols/Skype/keypacker/keypacker.cpp b/protocols/Skype/keypacker/keypacker.cpp
index 117fa20f93..c9833a41ac 100644
--- a/protocols/Skype/keypacker/keypacker.cpp
+++ b/protocols/Skype/keypacker/keypacker.cpp
@@ -1,5 +1,5 @@
#include "stdafx.h"
-
+
void *buf;
static const char base64Fillchar = '='; // used to mark partial words at the end
@@ -60,7 +60,7 @@ char * encode(unsigned char *inbuf, unsigned int inlen, char formatted)
*(curr++) = 0;
return (char *)buf;
}
-
+
unsigned int decodeSize(char * data)
{
if ( !data) return 0;
@@ -130,7 +130,7 @@ unsigned char decode(char * data, unsigned char *buf, int len)
}
}
#undef BASE64DECODE_READ_NEXT_CHAR
-
+
unsigned char *decode(char * data, int *outlen)
{
if ( !data) { *outlen = 0; return (unsigned char*)""; }
@@ -141,68 +141,68 @@ unsigned char *decode(char * data, int *outlen)
if( !decode(data, (unsigned char*)buf, len)) { return NULL; }
return (unsigned char*)buf;
}
-
-int main()
-{
- aes_context ctx;
- FILE *fin, *fout;
-
- int t = strlen(MY_KEY);
- int basecodedkey = encodeLength(strlen(MY_KEY), false);
- buf = malloc(basecodedkey + 1);
- unsigned char *tmpk = (unsigned char *)malloc(basecodedkey + 1);
- tmpk = (unsigned char *)encode((unsigned char*)MY_KEY, strlen(MY_KEY), false);
+
+int main()
+{
+ aes_context ctx;
+ FILE *fin, *fout;
+
+ int t = strlen(MY_KEY);
+ int basecodedkey = encodeLength(strlen(MY_KEY), false);
+ buf = malloc(basecodedkey + 1);
+ unsigned char *tmpk = (unsigned char *)malloc(basecodedkey + 1);
+ tmpk = (unsigned char *)encode((unsigned char*)MY_KEY, strlen(MY_KEY), false);
tmpk[basecodedkey] = 0;
char *output = (char*)malloc(basecodedkey + 17);
strcpy(output, "#define MY_KEY \"");
strcat(output, (const char*)tmpk);
strcat(output, "\"");
- fout = fopen("..\\..\\..\\..\\SkypeKit\\key.h", "wb");
- fputs((const char*)output, fout);
- fclose(fout);
+ fout = fopen("key.h", "wb");
+ fputs((const char*)output, fout);
+ fclose(fout);
free(buf);
-
- aes_set_key( &ctx, (BYTE*)MY_KEY, 128);
-
- //encrypt
- fin = fopen("..\\..\\..\\..\\SkypeKit\\keypair.crt", "rb");
- fseek(fin, 0, SEEK_END);
- long fileSize = ftell(fin);
- rewind (fin);
- int needbyte = 16 - fileSize%16;
- int corsize = fileSize + needbyte;
+
+ aes_set_key( &ctx, (BYTE*)MY_KEY, 128);
+
+ //encrypt
+ fin = fopen("keypair.crt", "rb");
+ fseek(fin, 0, SEEK_END);
+ long fileSize = ftell(fin);
+ rewind (fin);
+ int needbyte = 16 - fileSize%16;
+ int corsize = fileSize + needbyte;
unsigned char *inBuf = (unsigned char*)malloc(corsize + 1);
unsigned char *locbuf = (unsigned char*)malloc(corsize + 1);
fread(inBuf, fileSize, 1, fin);
- fclose(fin);
- memset(inBuf+fileSize, 0, needbyte);
- inBuf[corsize] = 0;
+ fclose(fin);
+ memset(inBuf+fileSize, 0, needbyte);
+ inBuf[corsize] = 0;
for (int i = 0; i < corsize; i+=16) {
aes_encrypt(&ctx, inBuf+i, locbuf+i);
}
free(inBuf);
- locbuf[corsize] = 0; //cert should be null terminated
- int basecoded = encodeLength(corsize, false);
- buf = malloc(basecoded + 1);
- unsigned char *tmp = (unsigned char *)malloc(basecoded + 1);
- tmp = (unsigned char *)encode(locbuf, corsize, false);
+ locbuf[corsize] = 0; //cert should be null terminated
+ int basecoded = encodeLength(corsize, false);
+ buf = malloc(basecoded + 1);
+ unsigned char *tmp = (unsigned char *)malloc(basecoded + 1);
+ tmp = (unsigned char *)encode(locbuf, corsize, false);
tmp[basecoded] = 0;
free(locbuf);
- fout = fopen("..\\..\\..\\..\\SkypeKit\\keypair.bin", "wb");
- fputs((const char*)tmp, fout);
- fclose(fout);
+ fout = fopen("keypair.bin", "wb");
+ fputs((const char*)tmp, fout);
+ fclose(fout);
free(buf);
- //free(tmp); todo:fix
-
- //decrypt
- fin = fopen("..\\..\\..\\..\\SkypeKit\\keypair.bin", "rb");
- fseek(fin, 0, SEEK_END);
- long fileSizeD = ftell(fin);
- rewind(fin);
+ //free(tmp); todo:fix
+
+ //decrypt
+ fin = fopen("keypair.bin", "rb");
+ fseek(fin, 0, SEEK_END);
+ long fileSizeD = ftell(fin);
+ rewind(fin);
unsigned char *inBufD = (unsigned char*)malloc(fileSizeD);
fread(inBufD, fileSizeD, 1, fin);
- fclose(fin);
- inBufD[fileSizeD] = 0;
+ fclose(fin);
+ inBufD[fileSizeD] = 0;
int basedecoded = decodeSize((char*)inBufD);
unsigned char *bufD = (unsigned char*)malloc(basedecoded + 1);
unsigned char *tmpD = (unsigned char*)malloc(basedecoded + 1);
@@ -210,13 +210,13 @@ int main()
for (int i = 0; i < basedecoded; i += 16) {
aes_decrypt(&ctx, tmpD+i, bufD+i);
}
- bufD[basedecoded] = 0; //cert should be null terminated
- //free(inBufD); todo:fix
- free(tmpD);
- fout = fopen("..\\..\\..\\..\\SkypeKit\\keypair.crt.decrypted", "wb");
- fputs((const char*)bufD, fout);
- fclose(fout);
- free(bufD);
-
- return 0;
+ bufD[basedecoded] = 0; //cert should be null terminated
+ //free(inBufD); todo:fix
+ free(tmpD);
+ fout = fopen("keypair.crt.decrypted", "wb");
+ fputs((const char*)bufD, fout);
+ fclose(fout);
+ free(bufD);
+
+ return 0;
} \ No newline at end of file