IDCertificate_server_g.h 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. #ifndef __IDCERTIFICATE_SERVER_G_H
  2. #define __IDCERTIFICATE_SERVER_G_H
  3. #pragma once
  4. // This code is generated by spgen tool!
  5. #include "IDCertificate_def_g.h"
  6. namespace IDCertificate {
  7. class IDCertService_ServerSessionBase : public CServerSessionBase
  8. {
  9. public:
  10. IDCertService_ServerSessionBase()
  11. {
  12. /// override by user
  13. }
  14. virtual ~IDCertService_ServerSessionBase()
  15. {
  16. /// override by user
  17. }
  18. virtual bool IsExclusive() { return false; }
  19. virtual bool IsSessionOverlap() { return true; }
  20. virtual ErrorCodeEnum GetMessageAttr(DWORD dwMessageID, DWORD dwSignature, bool &bOverlap)
  21. {
  22. ErrorCodeEnum Error = Error_Succeed;
  23. switch (dwMessageID) {
  24. case IDCertService_Method_CancelRead:
  25. if (dwSignature == IDCertService_MethodSignature_CancelRead) {
  26. bOverlap = true;
  27. } else {
  28. Error = Error_MethodSignatureFailed;
  29. }
  30. break;
  31. case IDCertService_Method_GetDevInfo:
  32. if (dwSignature == IDCertService_MethodSignature_GetDevInfo) {
  33. bOverlap = true;
  34. } else {
  35. Error = Error_MethodSignatureFailed;
  36. }
  37. break;
  38. case IDCertService_Method_ReadAndScanUTF8:
  39. if (dwSignature == IDCertService_MethodSignature_ReadAndScanUTF8) {
  40. bOverlap = true;
  41. } else {
  42. Error = Error_MethodSignatureFailed;
  43. }
  44. break;
  45. case IDCertService_Method_ReadAndScanUTF8JS:
  46. if (dwSignature == IDCertService_MethodSignature_ReadAndScanUTF8JS) {
  47. bOverlap = true;
  48. } else {
  49. Error = Error_MethodSignatureFailed;
  50. }
  51. break;
  52. case IDCertService_Method_CancelReadJS:
  53. if (dwSignature == IDCertService_MethodSignature_CancelReadJS) {
  54. bOverlap = true;
  55. } else {
  56. Error = Error_MethodSignatureFailed;
  57. }
  58. break;
  59. default:
  60. Error = Error_MethodNotFound;
  61. break;
  62. }
  63. return Error;
  64. }
  65. int CheckMessageSignature(DWORD dwMessageID, DWORD dwSignature)
  66. {
  67. ErrorCodeEnum Error = Error_Succeed;
  68. switch (dwMessageID) {
  69. case IDCertService_Method_CancelRead:
  70. if (dwSignature != IDCertService_MethodSignature_CancelRead) {
  71. Error = Error_MethodSignatureFailed;
  72. }
  73. break;
  74. case IDCertService_Method_GetDevInfo:
  75. if (dwSignature != IDCertService_MethodSignature_GetDevInfo) {
  76. Error = Error_MethodSignatureFailed;
  77. }
  78. break;
  79. case IDCertService_Method_ReadAndScanUTF8:
  80. if (dwSignature != IDCertService_MethodSignature_ReadAndScanUTF8) {
  81. Error = Error_MethodSignatureFailed;
  82. }
  83. break;
  84. case IDCertService_Method_ReadAndScanUTF8JS:
  85. if (dwSignature != IDCertService_MethodSignature_ReadAndScanUTF8JS) {
  86. Error = Error_MethodSignatureFailed;
  87. }
  88. break;
  89. case IDCertService_Method_CancelReadJS:
  90. if (dwSignature != IDCertService_MethodSignature_CancelReadJS) {
  91. Error = Error_MethodSignatureFailed;
  92. }
  93. break;
  94. default:
  95. Error = Error_MethodNotFound;
  96. break;
  97. }
  98. return Error;
  99. }
  100. virtual void Handle_CancelRead(SpOnewayCallContext<IDCertService_CancelRead_Info>::Pointer ctx)
  101. {
  102. /// override by user
  103. }
  104. virtual void Handle_GetDevInfo(SpReqAnsContext<IDCertService_GetDevInfo_Req, IDCertService_GetDevInfo_Ans>::Pointer ctx)
  105. {
  106. /// override by user
  107. }
  108. virtual void Handle_ReadAndScanUTF8(SpReqAnsContext<IDCertService_ReadAndScanUTF8_Req, IDCertService_ReadAndScanUTF8_Ans>::Pointer ctx)
  109. {
  110. /// override by user
  111. }
  112. virtual void Handle_ReadAndScanUTF8JS(SpReqAnsContext<IDCertService_ReadAndScanUTF8JS_Req, IDCertService_ReadAndScanUTF8JS_Ans>::Pointer ctx)
  113. {
  114. /// override by user
  115. }
  116. virtual void Handle_CancelReadJS(SpReqAnsContext<IDCertService_CancelReadJS_Req, IDCertService_CancelReadJS_Ans>::Pointer ctx)
  117. {
  118. /// override by user
  119. }
  120. virtual void OnRequest(CSmartPointer<ITransactionContext> pTransactionContext)
  121. {
  122. CAutoBuffer Buf;
  123. DWORD dwMessageID;
  124. DWORD dwMessageSignature;
  125. ErrorCodeEnum Error = pTransactionContext->GetReceiveBuffer(dwMessageID, dwMessageSignature, Buf);
  126. if (Error == Error_Succeed) {
  127. #ifdef DEBUG
  128. assert(CheckMessageSignature(dwMessageID, dwMessageSignature) == Error_Succeed);
  129. #else
  130. if (CheckMessageSignature(dwMessageID, dwMessageSignature) != Error_Succeed) {
  131. pTransactionContext->SendAnswer(Error_MethodSignatureFailed);
  132. return;
  133. }
  134. #endif
  135. switch (dwMessageID) {
  136. case IDCertService_Method_CancelRead:
  137. {
  138. SpOnewayCallContext<IDCertService_CancelRead_Info>::Pointer ctx;
  139. ctx.Attach(new SpOnewayCallContext<IDCertService_CancelRead_Info>());
  140. SpBuffer2Object(Buf, ctx->Info);
  141. pTransactionContext->GetLinkContext(ctx->link);
  142. EntityResource::setLink(ctx->link);
  143. Handle_CancelRead(ctx);
  144. }
  145. break;
  146. case IDCertService_Method_GetDevInfo:
  147. {
  148. SpReqAnsContext<IDCertService_GetDevInfo_Req,IDCertService_GetDevInfo_Ans>::Pointer ctx;
  149. ctx.Attach(new SpReqAnsContext<IDCertService_GetDevInfo_Req,IDCertService_GetDevInfo_Ans>(pTransactionContext));
  150. SpBuffer2Object(Buf, ctx->Req);
  151. pTransactionContext->GetLinkContext(ctx->link);
  152. EntityResource::setLink(ctx->link);
  153. Handle_GetDevInfo(ctx);
  154. }
  155. break;
  156. case IDCertService_Method_ReadAndScanUTF8:
  157. {
  158. SpReqAnsContext<IDCertService_ReadAndScanUTF8_Req,IDCertService_ReadAndScanUTF8_Ans>::Pointer ctx;
  159. ctx.Attach(new SpReqAnsContext<IDCertService_ReadAndScanUTF8_Req,IDCertService_ReadAndScanUTF8_Ans>(pTransactionContext));
  160. SpBuffer2Object(Buf, ctx->Req);
  161. pTransactionContext->GetLinkContext(ctx->link);
  162. EntityResource::setLink(ctx->link);
  163. Handle_ReadAndScanUTF8(ctx);
  164. }
  165. break;
  166. case IDCertService_Method_ReadAndScanUTF8JS:
  167. {
  168. SpReqAnsContext<IDCertService_ReadAndScanUTF8JS_Req,IDCertService_ReadAndScanUTF8JS_Ans>::Pointer ctx;
  169. ctx.Attach(new SpReqAnsContext<IDCertService_ReadAndScanUTF8JS_Req,IDCertService_ReadAndScanUTF8JS_Ans>(pTransactionContext));
  170. SpBuffer2Object(Buf, ctx->Req);
  171. pTransactionContext->GetLinkContext(ctx->link);
  172. EntityResource::setLink(ctx->link);
  173. Handle_ReadAndScanUTF8JS(ctx);
  174. }
  175. break;
  176. case IDCertService_Method_CancelReadJS:
  177. {
  178. SpReqAnsContext<IDCertService_CancelReadJS_Req,IDCertService_CancelReadJS_Ans>::Pointer ctx;
  179. ctx.Attach(new SpReqAnsContext<IDCertService_CancelReadJS_Req,IDCertService_CancelReadJS_Ans>(pTransactionContext));
  180. SpBuffer2Object(Buf, ctx->Req);
  181. pTransactionContext->GetLinkContext(ctx->link);
  182. EntityResource::setLink(ctx->link);
  183. Handle_CancelReadJS(ctx);
  184. }
  185. break;
  186. default:
  187. assert(0);
  188. break;
  189. }
  190. } else {
  191. pTransactionContext->SendAnswer(Error);
  192. }
  193. }
  194. };
  195. ///////////////////////////
  196. } // namespace IDCertificate
  197. #endif // __IDCERTIFICATE_SERVER_G_H