#include "stdafx.h" int CToxProto::MapStatus(int status) { switch (status) { case ID_STATUS_FREECHAT: status = ID_STATUS_ONLINE; break; case ID_STATUS_NA: status = ID_STATUS_AWAY; break; case ID_STATUS_DND: case ID_STATUS_INVISIBLE: status = ID_STATUS_OCCUPIED; break; } return status; } TOX_USER_STATUS CToxProto::MirandaToToxStatus(int status) { TOX_USER_STATUS userstatus = TOX_USER_STATUS_NONE; switch (status) { case ID_STATUS_AWAY: userstatus = TOX_USER_STATUS_AWAY; break; case ID_STATUS_OCCUPIED: userstatus = TOX_USER_STATUS_BUSY; break; } return userstatus; } int CToxProto::ToxToMirandaStatus(TOX_USER_STATUS userstatus) { int status = ID_STATUS_OFFLINE; switch (userstatus) { case TOX_USER_STATUS_NONE: status = ID_STATUS_ONLINE; break; case TOX_USER_STATUS_AWAY: status = ID_STATUS_AWAY; break; case TOX_USER_STATUS_BUSY: status = ID_STATUS_OCCUPIED; break; } return status; } wchar_t* CToxProto::ToxErrorToString(TOX_ERR_NEW error) { switch (error) { case TOX_ERR_NEW_NULL: return TranslateT("One of the arguments is missing"); case TOX_ERR_NEW_MALLOC: return TranslateT("Unable to allocate enough memory"); case TOX_ERR_NEW_PORT_ALLOC: return TranslateT("Unable to bind to a port"); case TOX_ERR_NEW_PROXY_BAD_TYPE: return TranslateT("The proxy type is not valid"); case TOX_ERR_NEW_PROXY_BAD_HOST: return TranslateT("The proxy host is not valid"); case TOX_ERR_NEW_PROXY_BAD_PORT: return TranslateT("The proxy port is not valid"); case TOX_ERR_NEW_PROXY_NOT_FOUND: return TranslateT("The proxy address could not be resolved"); case TOX_ERR_NEW_LOAD_ENCRYPTED: return TranslateT("The profile is encrypted"); case TOX_ERR_NEW_LOAD_BAD_FORMAT: return TranslateT("The data format is not valid"); default: return TranslateT("Unknown error"); } } wchar_t* CToxProto::ToxErrorToString(TOX_ERR_FRIEND_SEND_MESSAGE error) { switch (error) { case TOX_ERR_FRIEND_SEND_MESSAGE_NULL: return TranslateT("One of the arguments is missing"); case TOX_ERR_FRIEND_SEND_MESSAGE_FRIEND_NOT_FOUND: return TranslateT("The friend ID did not designate a valid friend"); case TOX_ERR_FRIEND_SEND_MESSAGE_FRIEND_NOT_CONNECTED: return TranslateT("This client is currently not connected to the friend"); case TOX_ERR_FRIEND_SEND_MESSAGE_SENDQ: return TranslateT("An allocation error occurred while increasing the send queue size"); case TOX_ERR_FRIEND_SEND_MESSAGE_TOO_LONG: return TranslateT("Message length exceeded TOX_MAX_MESSAGE_LENGTH"); case TOX_ERR_FRIEND_SEND_MESSAGE_EMPTY: return TranslateT("Attempted to send a zero-length message"); default: return TranslateT("Unknown error"); } } void CToxProto::ShowNotification(const wchar_t *caption, const wchar_t *message, int flags, MCONTACT hContact) { if (Miranda_IsTerminated()) { return; } if (Popup_Enabled()) { POPUPDATAW ppd; ppd.lchContact = hContact; wcsncpy(ppd.lpwzContactName, caption, MAX_CONTACTNAME); wcsncpy(ppd.lpwzText, message, MAX_SECONDLINE); ppd.lchIcon = IcoLib_GetIcon("Tox_main"); if (!PUAddPopupW(&ppd)) return; } MessageBox(nullptr, message, caption, MB_OK | flags); } void CToxProto::ShowNotification(const wchar_t *message, int flags, MCONTACT hContact) { ShowNotification(_A2W(MODULE), message, flags, hContact); } bool CToxProto::IsFileExists(const wchar_t* path) { return _waccess(path, 0) == 0; } MEVENT CToxProto::AddEventToDb(MCONTACT hContact, uint16_t type, uint32_t timestamp, uint32_t flags, uint8_t *pBlob, size_t cbBlob) { DBEVENTINFO dbei = {}; dbei.szModule = this->m_szModuleName; dbei.timestamp = timestamp; dbei.eventType = type; dbei.cbBlob = (uint32_t)cbBlob; dbei.pBlob = pBlob; dbei.flags = flags; return db_event_add(hContact, &dbei); } INT_PTR CToxProto::ParseToxUri(WPARAM, LPARAM lParam) { wchar_t *uri = (wchar_t*)lParam; if (mir_wstrlen(uri) <= 4) return 1; if (CMPlugin::g_arInstances.getCount() == 0) return 1; CToxProto *proto = nullptr; for (auto &it : CMPlugin::g_arInstances) { if (it->IsOnline()) { proto = it; break; } } if (proto == nullptr) return 1; if (wcschr(uri, '@') != nullptr) return 1; PROTOSEARCHRESULT psr = { sizeof(psr) }; psr.flags = PSR_UTF8; psr.id.a = mir_u2a(&uri[4]); Contact_AddBySearch(proto->m_szModuleName, &psr); return 0; }