// ---------------------------------------------------------------------------80 // ICQ plugin for Miranda Instant Messenger // ________________________________________ // // Copyright © 2000,2001 Richard Hughes, Roland Rabien, Tristan Van de Vreede // Copyright © 2001,2002 Jon Keating, Richard Hughes // Copyright © 2002,2003,2004 Martin Öberg, Sam Kothari, Robert Rainwater // Copyright © 2004,2005,2006,2007 Joe Kucera // // 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. // // ----------------------------------------------------------------------------- // // File name : $URL: https://miranda.svn.sourceforge.net/svnroot/miranda/trunk/miranda/include/m_icq.h $ // Revision : $Revision: 6572 $ // Last change on : $Date: 2007-10-12 00:37:38 +0300 (Пт, 12 окт 2007) $ // Last change by : $Author: jokusoftware $ // // DESCRIPTION: // // Describe me here please... // // ----------------------------------------------------------------------------- #ifndef M_ICQ_H__ #define M_ICQ_H__ 1 #define MS_SETINVIS "/SetInvis" #define MS_SETVIS "/SetVis" #define MS_INCOGNITO_REQUEST "/IncognitoRequest" // Add contact to server-list // wParam=(WPARAM)hContact #define MS_ICQ_ADDSERVCONTACT "/AddServerContact" // Note: In v0.3 the part before "/Servicename" is dynamic. It will be the name of the protocol. // Example: If the plugin was loaded from ICQ.dll, the service name is "ICQ/Servicename", and if // the dll was Icq2.dll, the service name will be "Icq2/Servicename". This behaviour is temporary // until proper multiaccounts are implemented. //start a search of all ICQ users by e-mail //wParam=0 //lParam=(LPARAM)(const char*)email //returns a handle to the search on success, NULL on failure //Results are returned using the same scheme documented in PSS_BASICSEARCH //**DEPRECATED** in favour of PS_SEARCHBYEMAIL typedef struct { //extended search result structure, used for all searches PROTOSEARCHRESULT hdr; DWORD uin; BYTE auth; char* uid; } ICQSEARCHRESULT; #define MS_ICQ_SEARCHBYEMAIL "/SearchByEmail" //start a search of all ICQ users by details //wParam=0 //lParam=(LPARAM)(ICQDETAILSSEARCH*)&ids //returns a handle to the search on success, NULL on failure //Results are returned using the same scheme documented in PSS_BASICSEARCH //**DEPRECATED** in favour of PS_SEARCHBYNAME typedef struct { char *nick; char *firstName; char *lastName; } ICQDETAILSSEARCH; #define MS_ICQ_SEARCHBYDETAILS "/SearchByDetails" // Request authorization // wParam=(WPARAM)hContact #define MS_REQ_AUTH "/ReqAuth" // Grant authorization // wParam=(WPARAM)hContact; #define MS_GRANT_AUTH "/GrantAuth" // Revoke authorization // wParam=(WPARAM)hContact #define MS_REVOKE_AUTH "/RevokeAuth" // Add contact to server-list // wParam=(WPARAM)hContact #define MS_ICQ_ADDSERVCONTACT "/AddServerContact" // Display XStatus detail (internal use only) // wParam=(WPARAM)hContact; #define MS_XSTATUS_SHOWDETAILS "/ShowXStatusDetails" #define MS_SEND_TZER "/SendtZer" //Send an SMS via the ICQ network //wParam=(WPARAM)(const char*)szPhoneNumber //lParam=(LPARAM)(const char*)szMessage //Returns a HANDLE to the send on success, or NULL on failure //szPhoneNumber should be the full number with international code and preceeded //by a + //When the server acks the send, an ack will be broadcast: // type=ICQACKTYPE_SMS, result=ACKRESULT_SENTREQUEST, lParam=(LPARAM)(char*)szInfo //At this point the message is queued to be delivered. szInfo contains the raw //XML data of the ack. Here's what I got when I tried: //"airbornww.comYesBT Cellnet, United Kingdom[my uin]-1-1955988055-[destination phone#, without +]0\r\n" //Now the hProcess has been deleted. The only way to track which receipt //corresponds with which response is to parse the field. //At a (possibly much) later time the SMS will have been delivered. An ack will //be broadcast: // type=ICQACKTYPE_SMS, result=ACKRESULT_SUCCESS, hProcess=NULL, lParam=(LPARAM)(char*)szInfo //Note that the result will always be success even if the send failed, just to //save needing to have an attempt at an XML parser in the ICQ module. //Here's the szInfo for a success: //"[my uin]-1--1461632229-[dest phone#, without +][dest phone#, without +]Yes[first 20 bytes of message]Tue, 30 Oct 2001 22:35:16 GMTTue, 30 Oct 2001 22:34:00 GMT" //And here's a failure: //"[my uin]-1-1955988055-[destination phone#, without leading +][destination phone#, without leading +]NoTue, 23 Oct 2001 23:17:02 GMT999999150Multiple message submittion failed" //SMSes received from phones come through this same ack, again to avoid having //an XML parser in the protocol module. Here's one I got: //"MTN[UIN of recipient, ie this account][sending phone number, without +][contains one space, because I sent from ICQ][body of the message]" #define ICQACKTYPE_SMS 1001 #define ICQEVENTTYPE_SMS 2001 //database event type #define MS_ICQ_SENDSMS "/SendSMS" //e-mail express //db event added to NULL contact //blob format is: //ASCIIZ text, usually of the form "Subject: %s\r\n%s" //ASCIIZ from name //ASCIIZ from e-mail #define ICQEVENTTYPE_EMAILEXPRESS 2002 //database event type //www pager //db event added to NULL contact //blob format is: //ASCIIZ text, usually "Sender IP: xxx.xxx.xxx.xxx\r\n%s" //ASCIIZ from name //ASCIIZ from e-mail #define ICQEVENTTYPE_WEBPAGER 2003 //database event type //for server-side lists, used internally only //hProcess=dwSequence //lParam=server's error code, 0 for success #define ICQACKTYPE_SERVERCLIST 1003 //for rate warning distribution (mainly upload dlg) //hProcess=Rate class ID //lParam=server's status code #define ICQACKTYPE_RATEWARNING 1004 //received Xtraz Notify response //hProcess=dwSequence //lParam=contents of RES node #define ICQACKTYPE_XTRAZNOTIFY_RESPONSE 1005 //received Custom Status details response //hProcess=dwSequence //lParam=0 #define ICQACKTYPE_XSTATUS_RESPONSE 1006 //Update user details on server //Permited operation types: #define CIXT_BASIC 0x0001 #define CIXT_MORE 0x0002 #define CIXT_WORK 0x0004 #define CIXT_CONTACT 0x0008 #define CIXT_LOCATION 0x0010 #define CIXT_BACKGROUND 0x0020 #define CIXT_FULL 0x003F //wParam=operationType #define PS_CHANGEINFOEX "/ChangeInfoEx" //Change nickname in White pages //lParam=(LPARAM)(const char*)szNewNickName #define PS_SET_NICKNAME "/SetNickname" //Set password for current session //lParam=(LPARAM)(const char*)szPassword #define PS_ICQ_SETPASSWORD "/SetPassword" //miranda/icqoscar/statusmsgreq event //called when our status message is requested //wParam=(BYTE)msgType //lParam=(DWORD)uin //msgType is one of the ICQ_MSGTYPE_GET###MSG constants in icq_constants.h //uin is the UIN of the contact requesting our status message #define ME_ICQ_STATUSMSGREQ "/StatusMsgReq" /* Custom Status helper API * - to set custom status message & title use PS_ICQ_GETCUSTOMSTATUS to obtain DB settings and write values to them (UTF-8 strings best). (obsolete) - use PS_ICQ_GETCUSTOMSTATUSEX and PS_ICQ_SETCUSTOMSTATUSEX for controling Custom Status - custom messages for each user supported - ME_ICQ_STATUSMSGREQ with type MTYPE_SCRIPT_NOTIFY */ #define CSSF_MASK_STATUS 0x0001 // status member valid for set/get #define CSSF_MASK_NAME 0x0002 // pszName member valid for set/get #define CSSF_MASK_MESSAGE 0x0004 // pszMessage member valid for set/get #define CSSF_DISABLE_UI 0x0040 // disable default custom status UI, wParam = bEnable #define CSSF_DEFAULT_NAME 0x0080 // only with CSSF_MASK_NAME and get API to get default custom status name (wParam = status) #define CSSF_STATUSES_COUNT 0x0100 // returns number of custom statuses in wParam, only get API #define CSSF_STR_SIZES 0x0200 // returns sizes of custom status name & message (wParam & lParam members) in chars #define CSSF_UNICODE 0x1000 // strings are in UCS-2 #if defined(_UNICODE) #define CSSF_TCHAR CSSF_UNICODE #else #define CSSF_TCHAR 0 #endif typedef struct { int cbSize; // size of the structure int flags; // combination of CSSF_* int *status; // custom status id union { char *pszName; // buffer for custom status name TCHAR *ptszName; WCHAR *pwszName; }; union { char *pszMessage; // buffer for custom status message TCHAR *ptszMessage; WCHAR *pwszMessage; }; WPARAM *wParam; // extra params, see flags LPARAM *lParam; } ICQ_CUSTOM_STATUS; // Sets owner current custom status (obsolete) //wParam = (int)N // custom status id (1-37) //lParam = 0 //return = N (id of status set) or 0 (failed - probably bad params) #define PS_ICQ_SETCUSTOMSTATUS "/SetXStatus" // Sets owner current custom status //wParam = 0 // reserved //lParam = (ICQ_CUSTOM_STATUS*)pData // contains what to set and new values //return = 0 (for success) #define PS_ICQ_SETCUSTOMSTATUSEX "/SetXStatusEx" // Retrieves custom status details for specified hContact //wParam = (HANDLE)hContact //lParam = (ICQ_CUSTOM_STATUS*)pData // receives details (members must be prepared) //return = 0 (for success) #define PS_ICQ_GETCUSTOMSTATUSEX "/GetXStatusEx" // Retrieves specified custom status icon //wParam = (int)N // custom status id (1-37), 0 = my current custom status //lParam = flags // use LR_SHARED for shared HICON //return = HICON // custom status icon (use DestroyIcon to release resources if not LR_SHARED) #define PS_ICQ_GETCUSTOMSTATUSICON "/GetXStatusIcon" // Get Custom status DB field names & current owner custom status (obsolete) //wParam = (char**)szDBTitle // will receive title DB setting name (do not free) //lParam = (char**)szDBMsg // will receive message DB setting name //return = N // current custom status id if successful, 0 otherwise #define PS_ICQ_GETCUSTOMSTATUS "/GetXStatus" // Request Custom status details (messages) for specified contact //wParam = hContact // request custom status details for this contact //lParam = 0 //return = (int)dwSequence // if successful it is sequence for ICQACKTYPE_XSTATUS_RESPONSE // 0 failed to request (e.g. auto-request enabled) // -1 delayed (rate control) - sequence unknown #define PS_ICQ_REQUESTCUSTOMSTATUS "/RequestXStatusDetails" // Called when contact changes custom status and extra icon is set to clist_mw //wParam = hContact // contact changing status //lParam = hIcon // HANDLE to clist extra icon set as custom status #define ME_ICQ_CUSTOMSTATUS_EXTRAICON_CHANGED "/XStatusExtraIconChanged" // Called when a contact changes its custom status // wParam = hContact // lParam = 0 #define ME_ICQ_CUSTOMSTATUS_CHANGED "/XStatusChanged" // Called from contact list in order to get index of custom status icon in list // wParam = hContact // lParam = 0 // rerurn = (int) index of extra contact icon shifted <<16 (the low word will be normal status icon, the high will be xStatus Icon #define PS_ICQ_GETADVANCEDSTATUSICON "/GetAdvancedStatusIcon" #define MAX_CAPNAME 64 typedef struct { int cbSize; char caps[0x10]; HANDLE hIcon; char name[MAX_CAPNAME]; } ICQ_CUSTOMCAP; // Add a custom icq capability. // wParam = 0; // lParam = (LPARAM)(ICQ_CUSTOMCAP *)&icqCustomCap; #define PS_ICQ_ADDCAPABILITY "/IcqAddCapability" // Check if capability is supportes. Only icqCustomCap.caps does matter. // wParam = (WPARAM)(HANDLE)hContact; // lParam = (LPARAM)(ICQ_CUSTOMCAP *)&icqCustomCap; // returns non-zero if capability is supported #define PS_ICQ_CHECKCAPABILITY "/IcqCheckCapability" #ifndef ICQ_NOHELPERS static __inline void IcqBuildMirandaCap(ICQ_CUSTOMCAP *icqCustomCap, const char *name, HICON hIcon, const char *id) { if (!icqCustomCap) return; icqCustomCap->cbSize = sizeof(*icqCustomCap); icqCustomCap->hIcon = hIcon; strncpy(icqCustomCap->name, name, sizeof(icqCustomCap->name))[sizeof(icqCustomCap->name)-1]=0; memset(icqCustomCap->caps, 0, 0x10); strncpy(icqCustomCap->caps+0, "Miranda/", 8); strncpy(icqCustomCap->caps+8, id, 8); } #endif /* usage: char icqCustomCapStr[0x10] = {...}; ICQ_CUSTOMCAP icqCustomCap; icqCustomCap.cbSize = sizeof(icqCustomCap); memcpy(icqCustomCap.caps, icqCustomCapStr, 0x10); lstrcpy(icqCustomCap.name, "Custom Name"); CallProtoService("ICQ", PS_ICQ_ADDCAPABILITY, 0, (LPARAM)&icqCustomCap); */ #endif // M_ICQ_H__