diff options
Diffstat (limited to 'plugins/New_GPG')
-rwxr-xr-x | plugins/New_GPG/src/messages.cpp | 149 | ||||
-rwxr-xr-x | plugins/New_GPG/src/options.cpp | 13 |
2 files changed, 129 insertions, 33 deletions
diff --git a/plugins/New_GPG/src/messages.cpp b/plugins/New_GPG/src/messages.cpp index ccf1ca67bb..e1cf4ba1aa 100755 --- a/plugins/New_GPG/src/messages.cpp +++ b/plugins/New_GPG/src/messages.cpp @@ -75,11 +75,31 @@ void RecvMsgSvc_func(MCONTACT hContact, std::wstring str, char *msg, DWORD, DWOR wstring decfile = toUTF16(get_random(10)); { wstring path = wstring(ptszHomePath) + _T("\\tmp\\") + encfile; - boost::filesystem::remove(path); + if(!bDebugLog) { + boost::system::error_code e; + boost::filesystem::remove(path, e); + } + + {
+ const int timeout = 5000, step = 100; + int count = 0; + fstream f(path.c_str(), std::ios::out); while (!f.is_open()) + { + boost::this_thread::sleep(boost::posix_time::milliseconds(step)); + count += step; + if(count >= timeout) + { + db_set_b(hContact, szGPGModuleName, "GPGEncryption", 0); + setSrmmIcon(hContact); + setClistIcon(hContact); + debuglog<<std::string(time_str() + "info: failed to create temporary file for decryption, disabling gpg for contact to avoid deadlock"); + return; + } f.open(path.c_str(), std::ios::out); + } char *tmp = mir_t2a(str.substr(s1, s2 - s1).c_str()); f << tmp; mir_free(tmp); @@ -124,7 +144,11 @@ void RecvMsgSvc_func(MCONTACT hContact, std::wstring str, char *msg, DWORD, DWOR mir_free(inkeyid); } - boost::filesystem::remove(wstring(ptszHomePath) + _T("\\tmp\\") + decfile); + if(!bDebugLog) + { + boost::system::error_code e; + boost::filesystem::remove(wstring(ptszHomePath) + _T("\\tmp\\") + decfile, e); + } cmd.push_back(L"--output"); cmd.push_back(std::wstring(ptszHomePath) + L"\\tmp\\" + decfile); @@ -138,7 +162,11 @@ void RecvMsgSvc_func(MCONTACT hContact, std::wstring str, char *msg, DWORD, DWOR params.result = &result; if (!gpg_launcher(params)) { - boost::filesystem::remove(path); + if(!bDebugLog) + { + boost::system::error_code e; + boost::filesystem::remove(path, e); + } HistoryLog(hContact, db_event(msg, timestamp, 0, dbflags)); BYTE enc = db_get_b(hContact, szGPGModuleName, "GPGEncryption", 0); db_set_b(hContact, szGPGModuleName, "GPGEncryption", 0); @@ -149,13 +177,23 @@ void RecvMsgSvc_func(MCONTACT hContact, std::wstring str, char *msg, DWORD, DWOR } if (result == pxNotFound) { - boost::filesystem::remove(path); + if(!bDebugLog) + { + boost::system::error_code e; + boost::filesystem::remove(path, e); + } + HistoryLog(hContact, db_event(msg, timestamp, 0, dbflags)); return; } if (result == pxSuccessExitCodeInvalid) { - boost::filesystem::remove(path); + if(!bDebugLog) + { + boost::system::error_code e; + boost::filesystem::remove(path, e); + } + HistoryLog(hContact, db_event(msg, timestamp, 0, dbflags)); HistoryLog(hContact, db_event(Translate("failed to decrypt message, GPG returned error, turn on debug log for more details"), timestamp, 0, 0)); return; @@ -202,7 +240,12 @@ void RecvMsgSvc_func(MCONTACT hContact, std::wstring str, char *msg, DWORD, DWOR params2.code = &code; params2.result = &result2; if (!gpg_launcher(params2)) { - boost::filesystem::remove(path); + if(!bDebugLog) + { + boost::system::error_code e; + boost::filesystem::remove(path, e); + } + HistoryLog(hContact, db_event(msg, timestamp, 0, dbflags)); BYTE enc = db_get_b(hContact, szGPGModuleName, "GPGEncryption", 0); db_set_b(hContact, szGPGModuleName, "GPGEncryption", 0); @@ -213,7 +256,12 @@ void RecvMsgSvc_func(MCONTACT hContact, std::wstring str, char *msg, DWORD, DWOR } if (result2 == pxNotFound) { - boost::filesystem::remove(path); + if(!bDebugLog) + { + boost::system::error_code e; + boost::filesystem::remove(path, e); + } + HistoryLog(hContact, db_event(msg, timestamp, 0, dbflags)); return; } @@ -221,7 +269,12 @@ void RecvMsgSvc_func(MCONTACT hContact, std::wstring str, char *msg, DWORD, DWOR out.clear(); if (!gpg_launcher(params)) { - boost::filesystem::remove(path); + if(!bDebugLog) + { + boost::system::error_code e; + boost::filesystem::remove(path, e); + } + HistoryLog(hContact, db_event(msg, timestamp, 0, dbflags)); BYTE enc = db_get_b(hContact, szGPGModuleName, "GPGEncryption", 0); db_set_b(hContact, szGPGModuleName, "GPGEncryption", 0); @@ -232,10 +285,19 @@ void RecvMsgSvc_func(MCONTACT hContact, std::wstring str, char *msg, DWORD, DWOR } if (result == pxNotFound) { - boost::filesystem::remove(path); + if(!bDebugLog) + { + boost::system::error_code e; + boost::filesystem::remove(path, e); + } + HistoryLog(hContact, db_event(msg, timestamp, 0, dbflags)); } - boost::filesystem::remove(wstring(ptszHomePath) + _T("\\tmp\\") + encfile); + if(!bDebugLog) + { + boost::system::error_code e; + boost::filesystem::remove(wstring(ptszHomePath) + _T("\\tmp\\") + encfile, e); + } if (!boost::filesystem::exists(wstring(ptszHomePath) + _T("\\tmp\\") + decfile)) { @@ -271,11 +333,14 @@ void RecvMsgSvc_func(MCONTACT hContact, std::wstring str, char *msg, DWORD, DWOR str.append(toUTF16(tmp)); delete[] tmp; f.close(); - boost::system::error_code ec; - boost::filesystem::remove(tszDecPath, ec); - if(ec) + if(!bDebugLog) { - //TODO: handle error + boost::system::error_code ec; + boost::filesystem::remove(tszDecPath, ec); + if(ec) + { + //TODO: handle error + } } } } @@ -370,10 +435,30 @@ INT_PTR RecvMsgSvc(WPARAM w, LPARAM l) mir_tstrcat(tmp2, _T(".asc")); mir_free(tmp3); //mir_tstrcat(tmp2, _T("temporary_exported.asc")); - boost::filesystem::remove(tmp2); + if(!bDebugLog) + { + boost::system::error_code e; + boost::filesystem::remove(tmp2, e); + } wfstream f(tmp2, std::ios::out); - while (!f.is_open()) - f.open(tmp2, std::ios::out); + { + const int timeout = 5000, step = 100; + int count = 0; + while (!f.is_open()) + { + boost::this_thread::sleep(boost::posix_time::milliseconds(step)); + count += step; + if(count >= timeout) + { + db_set_b(ccs->hContact, szGPGModuleName, "GPGEncryption", 0); + setSrmmIcon(ccs->hContact); + setClistIcon(ccs->hContact); + debuglog<<std::string(time_str() + "info: failed to create temporary file for decryption, disabling gpg for contact to avoid deadlock"); + return 1; + } + f.open(tmp2, std::ios::out); + } + } ptmp = UniGetContactSettingUtf(ccs->hContact, szGPGModuleName, "GPGPubKey", _T("")); f << (TCHAR*)ptmp; f.close(); @@ -388,7 +473,11 @@ INT_PTR RecvMsgSvc(WPARAM w, LPARAM l) params.result = &result; if (!gpg_launcher(params)) return 1; - boost::filesystem::remove(tmp2); + if(!bDebugLog) + { + boost::system::error_code e; + boost::filesystem::remove(tmp2, e); + } if (result == pxNotFound) return 1; if (result == pxSuccessExitCodeInvalid) @@ -682,17 +771,29 @@ void SendMsgSvc_func(MCONTACT hContact, char *msg, DWORD flags) if (result == pxSuccessExitCodeInvalid) { //mir_free(msg); HistoryLog(hContact, db_event(Translate("failed to encrypt message, GPG returned error, turn on debug log for more details"), 0, 0, DBEF_SENT)); - boost::filesystem::remove(path); + if(!bDebugLog) + { + boost::system::error_code e; + boost::filesystem::remove(path, e); + } return; } if (out.find("usage: ") != string::npos) { MessageBox(0, TranslateT("Something is wrong, GPG does not understand us, aborting encryption."), TranslateT("Warning"), MB_OK); //mir_free(msg); CallContactService(hContact, PSS_MESSAGE, flags, (LPARAM)msg); - boost::filesystem::remove(path); + if(!bDebugLog) + { + boost::system::error_code e; + boost::filesystem::remove(path, e); + } return; } - boost::filesystem::remove(path); + if(!bDebugLog) + { + boost::system::error_code e; + boost::filesystem::remove(path, e); + } path.append(_T(".asc")); wfstream f(path.c_str(), std::ios::in | std::ios::ate | std::ios::binary); count = 0; @@ -719,7 +820,11 @@ void SendMsgSvc_func(MCONTACT hContact, char *msg, DWORD flags) str.append(tmp); delete[] tmp; f.close(); - boost::filesystem::remove(path); + if(!bDebugLog) + { + boost::system::error_code e; + boost::filesystem::remove(path, e); + } } if (str.empty()) { HistoryLog(hContact, db_event("Failed to encrypt message with GPG", 0, 0, DBEF_SENT)); diff --git a/plugins/New_GPG/src/options.cpp b/plugins/New_GPG/src/options.cpp index 8b48874774..1a76b727f0 100755 --- a/plugins/New_GPG/src/options.cpp +++ b/plugins/New_GPG/src/options.cpp @@ -711,17 +711,8 @@ static INT_PTR CALLBACK DlgProcLoadPublicKey(HWND hwndDlg, UINT uMsg, WPARAM wPa params.result = &result;
gpg_launcher(params); //TODO: handle errors
if ((out.find("-----BEGIN PGP PUBLIC KEY BLOCK-----") != string::npos) && (out.find("-----END PGP PUBLIC KEY BLOCK-----") != string::npos)) {
- string::size_type p = 0, stop = 0;
- for (;;) {
- if ((p = out.find("\n", p + 2)) != string::npos) {
- if (p > stop) {
- stop = p;
- out.insert(p, "\r");
- }
- else
- break;
- }
- }
+ boost::algorithm::replace_all(out, "\n", "\r\n");
+
TCHAR *tmp3 = mir_a2t(out.c_str());
str.clear();
str.append(tmp3);
|