summaryrefslogtreecommitdiff
path: root/messages.cpp
blob: c4a890d24ebc7aaa7787115e677c3656a45ea762 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
// Copyright © 2010 sss
// 
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; either version 2
// of the License, or (at your option) any later version.
// 
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
// 
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.

#include "commonheaders.h"

int RecvMsgSvc(WPARAM w, LPARAM l)
{
	CCSDATA *ccs = (CCSDATA*)l;
	if (!ccs)
		return CallService(MS_PROTO_CHAINRECV, w, l);
	PROTORECVEVENT *pre = (PROTORECVEVENT*)(ccs->lParam);
	if (!pre)
		return CallService(MS_PROTO_CHAINRECV, w, l);
	char *msg = pre->szMessage;
	if (!msg)
		return CallService(MS_PROTO_CHAINRECV, w, l);
	bool unicode = (bool)(pre->flags&PREF_UNICODE);

	{ //check for gpg related data
		wchar_t *tmp = mir_utf8decodeW(msg);
		wstring str = tmp;
		mir_free(tmp);
		wstring::size_type s1, s2;

		if(((s2 = str.find(_T("-----END PGP PUBLIC KEY BLOCK-----"))) != wstring::npos) && ((s1 = str.find(_T("-----BEGIN PGP PUBLIC KEY BLOCK-----"))) != wstring::npos))
		{  //this is public key
		}
		else if(((s2 = str.find(_T("-/ENCRYPTED-"))) != wstring::npos) && ((s1 = str.find(_T("-ENCRYPTED-"))) != wstring::npos))
		{ //this is generic encrypted data block
		}
		else if(((s1 = str.find(_T("<body>This message is encrypted.</body>"))) != wstring::npos))
		{ //this is jabber encrypted data
		}

		char *utf = mir_utf8encodeW(str.c_str()); //for later usage
		mir_free(utf);

	}

	return CallService(MS_PROTO_CHAINRECV, w, l);
}

int SendMsgSvc(WPARAM w, LPARAM l)
{
	CCSDATA *ccs = (CCSDATA*)l;
	if (!ccs)
		return CallService(MS_PROTO_CHAINSEND, w, l);
	if(!DBGetContactSettingByte(ccs->hContact, szModuleName, "GPGEncryption", 0))
		return CallService(MS_PROTO_CHAINSEND, w, l);

	char *msg = (char*)(ccs->lParam);
	if (!msg)
		return CallService(MS_PROTO_CHAINSEND, w, l);
	bool unicode = (bool)(ccs->wParam&PREF_UNICODE);

	{ //encrypt data here
		wchar_t *tmp = mir_utf8decodeW(msg);
		wstring str = tmp;
		mir_free(tmp);
		wstring::size_type s1, s2;

		char *utf = mir_utf8encodeW(str.c_str()); //for later usage
		mir_free(utf);
	}

	return CallService(MS_PROTO_CHAINSEND, w, l);
}