ECImportContentsChangesProxy.cpp 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319
  1. /*
  2. * Copyright 2005 - 2016 Zarafa and its licensors
  3. *
  4. * This program is free software: you can redistribute it and/or modify
  5. * it under the terms of the GNU Affero General Public License, version 3,
  6. * as published by the Free Software Foundation.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU Affero General Public License for more details.
  12. *
  13. * You should have received a copy of the GNU Affero General Public License
  14. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  15. *
  16. */
  17. #include "phpconfig.h"
  18. #include <kopano/platform.h>
  19. #include <kopano/ecversion.h>
  20. #include <cstdio>
  21. #include <ctime>
  22. #include <cmath>
  23. extern "C" {
  24. // Remove these defines to remove warnings
  25. #undef PACKAGE_VERSION
  26. #undef PACKAGE_TARNAME
  27. #undef PACKAGE_NAME
  28. #undef PACKAGE_STRING
  29. #undef PACKAGE_BUGREPORT
  30. #include "php.h"
  31. #include "php_globals.h"
  32. #include "ext/standard/info.h"
  33. #include "ext/standard/php_string.h"
  34. }
  35. // A very, very nice PHP #define that causes link errors in MAPI when you have multiple
  36. // files referencing MAPI....
  37. #undef inline
  38. /***************************************************************
  39. * MAPI Includes
  40. ***************************************************************/
  41. #include <mapi.h>
  42. #include <mapix.h>
  43. #include <mapiutil.h>
  44. #include <mapispi.h>
  45. #include <mapitags.h>
  46. #include <mapicode.h>
  47. #define USES_IID_IMAPIProp
  48. #define USES_IID_IMAPIContainer
  49. #define USES_IID_IMsgStore
  50. #define USES_IID_IMessage
  51. #define USES_IID_IExchangeManageStore
  52. #include <edkguid.h>
  53. #include <edkmdb.h>
  54. #include "ECImportContentsChangesProxy.h"
  55. #include "typeconversion.h"
  56. static char *name_mapi_message;
  57. static int le_mapi_message;
  58. ECImportContentsChangesProxy::ECImportContentsChangesProxy(zval *lpObj TSRMLS_DC) :
  59. m_cRef(1), m_lpObj(lpObj)
  60. {
  61. #if ZEND_MODULE_API_NO >= 20071006
  62. Z_ADDREF_P(m_lpObj);
  63. #else
  64. ZVAL_ADDREF(m_lpObj);
  65. #endif
  66. #ifdef ZTS
  67. this->TSRMLS_C = TSRMLS_C;
  68. #endif
  69. }
  70. ECImportContentsChangesProxy::~ECImportContentsChangesProxy() {
  71. zval_ptr_dtor(&m_lpObj);
  72. }
  73. ULONG ECImportContentsChangesProxy::AddRef() {
  74. return ++m_cRef;
  75. }
  76. ULONG ECImportContentsChangesProxy::Release() {
  77. if (--m_cRef == 0) {
  78. delete this;
  79. return 0;
  80. }
  81. return m_cRef;
  82. }
  83. HRESULT ECImportContentsChangesProxy::QueryInterface(REFIID iid, void **lpvoid) {
  84. if(iid == IID_IExchangeImportContentsChanges) {
  85. AddRef();
  86. *lpvoid = this;
  87. return hrSuccess;
  88. }
  89. return MAPI_E_INTERFACE_NOT_SUPPORTED;
  90. }
  91. HRESULT ECImportContentsChangesProxy::GetLastError(HRESULT hResult, ULONG ulFlags, LPMAPIERROR *lppMAPIError) {
  92. return MAPI_E_NO_SUPPORT;
  93. }
  94. HRESULT ECImportContentsChangesProxy::Config(LPSTREAM lpStream, ULONG ulFlags) {
  95. HRESULT hr = hrSuccess;
  96. zval *pvalFuncName;
  97. zval *pvalReturn;
  98. zval *pvalArgs[2];
  99. MAKE_STD_ZVAL(pvalFuncName);
  100. MAKE_STD_ZVAL(pvalReturn);
  101. MAKE_STD_ZVAL(pvalArgs[0]);
  102. MAKE_STD_ZVAL(pvalArgs[1]);
  103. if (lpStream != nullptr)
  104. ZVAL_RESOURCE(pvalArgs[0], (long)lpStream);
  105. else
  106. ZVAL_NULL(pvalArgs[0]);
  107. ZVAL_LONG(pvalArgs[1], ulFlags);
  108. ZVAL_STRING(pvalFuncName, "Config" , 1);
  109. if(call_user_function(NULL, &m_lpObj, pvalFuncName, pvalReturn, 2, pvalArgs TSRMLS_CC) == FAILURE) {
  110. php_error_docref(NULL TSRMLS_CC, E_WARNING, "Config method not present on ImportContentsChanges object");
  111. hr = MAPI_E_CALL_FAILED;
  112. goto exit;
  113. }
  114. convert_to_long_ex(&pvalReturn);
  115. hr = pvalReturn->value.lval;
  116. exit:
  117. zval_ptr_dtor(&pvalFuncName);
  118. zval_ptr_dtor(&pvalReturn);
  119. zval_ptr_dtor(&pvalArgs[0]);
  120. zval_ptr_dtor(&pvalArgs[1]);
  121. return hr;
  122. }
  123. HRESULT ECImportContentsChangesProxy::UpdateState(LPSTREAM lpStream) {
  124. HRESULT hr = hrSuccess;
  125. zval *pvalFuncName;
  126. zval *pvalReturn;
  127. zval *pvalArgs[1];
  128. MAKE_STD_ZVAL(pvalFuncName);
  129. MAKE_STD_ZVAL(pvalReturn);
  130. MAKE_STD_ZVAL(pvalArgs[0]);
  131. if (lpStream != nullptr)
  132. ZVAL_RESOURCE(pvalArgs[0], (long)lpStream);
  133. else
  134. ZVAL_NULL(pvalArgs[0]);
  135. ZVAL_STRING(pvalFuncName, "UpdateState" , 1);
  136. if(call_user_function(NULL, &m_lpObj, pvalFuncName, pvalReturn, 1, pvalArgs TSRMLS_CC) == FAILURE) {
  137. php_error_docref(NULL TSRMLS_CC, E_WARNING, "UpdateState method not present on ImportContentsChanges object");
  138. hr = MAPI_E_CALL_FAILED;
  139. goto exit;
  140. }
  141. convert_to_long_ex(&pvalReturn);
  142. hr = pvalReturn->value.lval;
  143. exit:
  144. zval_ptr_dtor(&pvalFuncName);
  145. zval_ptr_dtor(&pvalReturn);
  146. zval_ptr_dtor(&pvalArgs[0]);
  147. return hr;
  148. }
  149. HRESULT ECImportContentsChangesProxy::ImportMessageChange(ULONG cValues, LPSPropValue lpPropArray, ULONG ulFlags, LPMESSAGE * lppMessage) {
  150. zval *pvalFuncName;
  151. zval *pvalReturn;
  152. zval *pvalArgs[3];
  153. IMessage *lpMessage = NULL;
  154. HRESULT hr = hrSuccess;
  155. MAKE_STD_ZVAL(pvalFuncName);
  156. MAKE_STD_ZVAL(pvalReturn);
  157. hr = PropValueArraytoPHPArray(cValues, lpPropArray, &pvalArgs[0] TSRMLS_CC);
  158. if(hr != hrSuccess) {
  159. php_error_docref(NULL TSRMLS_CC, E_WARNING, "Unable to convert MAPI propvalue array to PHP");
  160. goto exit;
  161. }
  162. MAKE_STD_ZVAL(pvalArgs[1]);
  163. MAKE_STD_ZVAL(pvalArgs[2]);
  164. ZVAL_LONG(pvalArgs[1], ulFlags);
  165. ZVAL_NULL(pvalArgs[2]);
  166. ZVAL_STRING(pvalFuncName, "ImportMessageChange", 1);
  167. if(call_user_function(NULL, &m_lpObj, pvalFuncName, pvalReturn, 3, pvalArgs TSRMLS_CC) == FAILURE) {
  168. php_error_docref(NULL TSRMLS_CC, E_WARNING, "ImportMessageChange method not present on ImportContentsChanges object");
  169. hr = MAPI_E_CALL_FAILED;
  170. goto exit;
  171. }
  172. convert_to_long_ex(&pvalReturn);
  173. hr = pvalReturn->value.lval;
  174. if(hr != hrSuccess)
  175. goto exit;
  176. lpMessage = (IMessage *) zend_fetch_resource(&pvalReturn TSRMLS_CC, -1, name_mapi_message, NULL, 1, le_mapi_message);
  177. if(!lpMessage) {
  178. php_error_docref(NULL TSRMLS_CC, E_WARNING, "ImportMessageChange() must return a valid MAPI message resource in the last argument when returning OK (0)");
  179. hr = MAPI_E_CALL_FAILED;
  180. goto exit;
  181. }
  182. if(lppMessage)
  183. *lppMessage = lpMessage;
  184. exit:
  185. zval_ptr_dtor(&pvalFuncName);
  186. zval_ptr_dtor(&pvalReturn);
  187. zval_ptr_dtor(&pvalArgs[0]);
  188. zval_ptr_dtor(&pvalArgs[1]);
  189. zval_ptr_dtor(&pvalArgs[2]);
  190. return hr;
  191. }
  192. HRESULT ECImportContentsChangesProxy::ImportMessageDeletion(ULONG ulFlags, LPENTRYLIST lpSourceEntryList) {
  193. HRESULT hr = hrSuccess;
  194. zval *pvalFuncName;
  195. zval *pvalReturn;
  196. zval *pvalArgs[2];
  197. MAKE_STD_ZVAL(pvalFuncName);
  198. MAKE_STD_ZVAL(pvalReturn);
  199. MAKE_STD_ZVAL(pvalArgs[0]);
  200. ZVAL_LONG(pvalArgs[0], ulFlags);
  201. SBinaryArraytoPHPArray(lpSourceEntryList, &pvalArgs[1] TSRMLS_CC);
  202. ZVAL_STRING(pvalFuncName, "ImportMessageDeletion" , 1);
  203. if(call_user_function(NULL, &m_lpObj, pvalFuncName, pvalReturn, 2, pvalArgs TSRMLS_CC) == FAILURE) {
  204. php_error_docref(NULL TSRMLS_CC, E_WARNING, "ImportMessageDeletion method not present on ImportContentsChanges object");
  205. hr = MAPI_E_CALL_FAILED;
  206. goto exit;
  207. }
  208. convert_to_long_ex(&pvalReturn);
  209. hr = pvalReturn->value.lval;
  210. exit:
  211. zval_ptr_dtor(&pvalFuncName);
  212. zval_ptr_dtor(&pvalReturn);
  213. zval_ptr_dtor(&pvalArgs[0]);
  214. zval_ptr_dtor(&pvalArgs[1]);
  215. return hr;
  216. }
  217. HRESULT ECImportContentsChangesProxy::ImportPerUserReadStateChange(ULONG cElements, LPREADSTATE lpReadState) {
  218. HRESULT hr = hrSuccess;
  219. zval *pvalFuncName;
  220. zval *pvalReturn;
  221. zval *pvalArgs[1];
  222. MAKE_STD_ZVAL(pvalFuncName);
  223. MAKE_STD_ZVAL(pvalReturn);
  224. ReadStateArraytoPHPArray(cElements, lpReadState, &pvalArgs[0] TSRMLS_CC);
  225. ZVAL_STRING(pvalFuncName, "ImportPerUserReadStateChange" , 1);
  226. if(call_user_function(NULL, &m_lpObj, pvalFuncName, pvalReturn, 1, pvalArgs TSRMLS_CC) == FAILURE) {
  227. php_error_docref(NULL TSRMLS_CC, E_WARNING, "ImportPerUserReadStateChange method not present on ImportContentsChanges object");
  228. hr = MAPI_E_CALL_FAILED;
  229. goto exit;
  230. }
  231. convert_to_long_ex(&pvalReturn);
  232. hr = pvalReturn->value.lval;
  233. exit:
  234. zval_ptr_dtor(&pvalFuncName);
  235. zval_ptr_dtor(&pvalReturn);
  236. zval_ptr_dtor(&pvalArgs[0]);
  237. return hr;
  238. }
  239. HRESULT ECImportContentsChangesProxy::ImportMessageMove(ULONG cbSourceKeySrcFolder, BYTE *pbSourceKeySrcFolder, ULONG cbSourceKeySrcMessage, BYTE *pbSourceKeySrcMessage, ULONG cbPCLMessage, BYTE *pbPCLMessage, ULONG cbSourceKeyDestMessage, BYTE *pbSourceKeyDestMessage, ULONG cbChangeNumDestMessage, BYTE *pbChangeNumDestMessage) {
  240. return MAPI_E_NO_SUPPORT;
  241. }