|
|
@ -24,82 +24,80 @@ using namespace std; |
|
|
|
CArcFour SecString::RC4; |
|
|
|
CArcFour SecString::RC4; |
|
|
|
|
|
|
|
|
|
|
|
SecString::operator QString(){ |
|
|
|
SecString::operator QString(){ |
|
|
|
return string(); |
|
|
|
return string(); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
SecString::SecString(){ |
|
|
|
SecString::SecString(){ |
|
|
|
locked=true; |
|
|
|
locked=true; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
int SecString::length(){ |
|
|
|
int SecString::length(){ |
|
|
|
return crypt.size(); |
|
|
|
return crypt.size(); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
SecString::~SecString(){ |
|
|
|
SecString::~SecString(){ |
|
|
|
lock(); |
|
|
|
lock(); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void SecString::lock(){ |
|
|
|
void SecString::lock(){ |
|
|
|
locked=true; |
|
|
|
locked=true; |
|
|
|
overwrite(plain); |
|
|
|
overwrite(plain); |
|
|
|
plain=QString(); |
|
|
|
plain=QString(); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void SecString::unlock(){ |
|
|
|
void SecString::unlock(){ |
|
|
|
locked=false; |
|
|
|
locked = false; |
|
|
|
plain=QString(); |
|
|
|
plain = QString(); |
|
|
|
if(!crypt.length()){return;} |
|
|
|
if(!crypt.length()) |
|
|
|
const unsigned char* buffer=new unsigned char[crypt.length()]; |
|
|
|
return; |
|
|
|
SecString::RC4.decrypt((byte*)crypt.data(),(unsigned char*)buffer,crypt.length()); |
|
|
|
const unsigned char* buffer = new unsigned char[crypt.length()]; |
|
|
|
plain=QString::fromUtf8((const char*)buffer,crypt.size()); |
|
|
|
SecString::RC4.decrypt( (byte*)crypt.data(), (unsigned char*)buffer, crypt.length() ); |
|
|
|
overwrite((unsigned char*)buffer,crypt.size()); |
|
|
|
plain = QString::fromUtf8((const char*)buffer, crypt.size()); |
|
|
|
delete [] buffer; |
|
|
|
overwrite((unsigned char*)buffer, crypt.size()); |
|
|
|
|
|
|
|
delete [] buffer; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const QString& SecString::string(){ |
|
|
|
const QString& SecString::string(){ |
|
|
|
if(locked){ |
|
|
|
Q_ASSERT_X(!locked, "SecString::string()", "string is locked"); |
|
|
|
printf("Error in function SecString::string(): string is locked\n"); |
|
|
|
return plain; |
|
|
|
return QString(">SEC_STRING_ERROR<"); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
return plain; |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void SecString::setString(QString& str, bool DeleteSource){ |
|
|
|
void SecString::setString(QString& str,bool DeleteSource){ |
|
|
|
QByteArray StrData = str.toUtf8(); |
|
|
|
QByteArray StrData=str.toUtf8(); |
|
|
|
int len = StrData.size(); |
|
|
|
int len=StrData.size(); |
|
|
|
unsigned char* buffer = new unsigned char[len]; |
|
|
|
unsigned char* buffer=new unsigned char[len]; |
|
|
|
SecString::RC4.encrypt((const unsigned char*)StrData.data(), buffer, len); |
|
|
|
SecString::RC4.encrypt((const unsigned char*)StrData.data(),buffer,len); |
|
|
|
crypt = QByteArray((const char*)buffer, len); |
|
|
|
crypt=QByteArray((const char*)buffer,len); |
|
|
|
overwrite(buffer, len); |
|
|
|
overwrite(buffer,len); |
|
|
|
overwrite((unsigned char*)StrData.data(), len); |
|
|
|
overwrite((unsigned char*)StrData.data(),len); |
|
|
|
delete [] buffer; |
|
|
|
delete [] buffer; |
|
|
|
if(DeleteSource){ |
|
|
|
if(DeleteSource){ |
|
|
|
|
|
|
|
overwrite(str); |
|
|
|
overwrite(str); |
|
|
|
str=QString();} |
|
|
|
str=QString(); |
|
|
|
lock(); |
|
|
|
} |
|
|
|
|
|
|
|
lock(); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void SecString::overwrite(unsigned char* str,int strlen){ |
|
|
|
void SecString::overwrite(unsigned char* str, int strlen){ |
|
|
|
if(strlen==0 || str==NULL)return; |
|
|
|
if(strlen==0 || str==NULL) |
|
|
|
for(int i=0; i<strlen; i++){ |
|
|
|
return; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for(int i=0; i<strlen; i++) |
|
|
|
str[i]=0; |
|
|
|
str[i]=0; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void SecString::overwrite(QString &str){ |
|
|
|
void SecString::overwrite(QString& str){ |
|
|
|
if(str.length()==0)return; |
|
|
|
if(str.length()==0) |
|
|
|
for(int i=0; i<str.length(); i++){ |
|
|
|
return; |
|
|
|
((char*)str.data())[i]=0; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for(int i=0; i<str.length(); i++) |
|
|
|
|
|
|
|
((char*)str.data())[i] = 0; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void SecString::generateSessionKey(){ |
|
|
|
void SecString::generateSessionKey(){ |
|
|
|
CArcFour arc; |
|
|
|
CArcFour arc; |
|
|
|
unsigned char* sessionkey=new unsigned char[32]; |
|
|
|
unsigned char sessionkey[32]; |
|
|
|
randomize(sessionkey,32); |
|
|
|
randomize(sessionkey,32); |
|
|
|
RC4.setKey(sessionkey,32); |
|
|
|
RC4.setKey(sessionkey,32); |
|
|
|
delete [] sessionkey; |
|
|
|
overwrite(sessionkey,32); |
|
|
|
} |
|
|
|
} |
|
|
|