opcua_secureChannelLayer.c 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. /*
  2. * opcua_secureChannelLayer.c
  3. *
  4. * Created on: Jan 13, 2014
  5. * Author: opcua
  6. */
  7. #include "opcua_secureChannelLayer.h"
  8. SL_getRequestHeader()
  9. {
  10. }
  11. /*
  12. * opens a secureChannel (server side)
  13. */
  14. void SL_secureChannel_open(const UA_connection *connection,
  15. const AD_RawMessage *secureChannelMessage,
  16. SL_SecureConversationMessageHeader *SCM_Header,
  17. SL_AsymmetricAlgorithmSecurityHeader *AAS_Header)
  18. {
  19. TL_send();
  20. //connection->secureLayer.
  21. }
  22. /*
  23. void SL_secureChannel_Request_get(AD_RawMessage *secureChannelMessage,
  24. secureChannelRequest *SC_request)
  25. {
  26. }
  27. */
  28. /*
  29. * closes a secureChannel (server side)
  30. */
  31. void SL_secureChannel_close(UA_connection *connection)
  32. {
  33. }
  34. /*
  35. * receive and process data from underlying layer
  36. */
  37. void SL_receive(UA_connection *connection,
  38. AD_RawMessage *serviceMessage)
  39. {
  40. AD_RawMessage* secureChannelMessage;
  41. SL_SecureConversationMessageHeader SCM_Header;
  42. SL_AsymmetricAlgorithmSecurityHeader AAS_Header;
  43. //get data from transport layer
  44. TL_receive(UA_connection, secureChannelMessage);
  45. //get the Secure Channel Message Header
  46. UInt32 readPosition = SL_secureChannel_SCMHeader_get(connection,secureChannelMessage,&SCM_Header);
  47. //get the Secure Channel Asymmetric Algorithm Security Header
  48. readPosition = SL_secureChannel_AASHeader_get(connection,secureChannelMessage,readPosition,&AAS_Header);
  49. //get Secure Channel Message
  50. SL_secureChannel_Message_get(connection,secureChannelMessage,readPosition,serviceMessage);
  51. if (secureChannelMessage.length > 0)
  52. {
  53. switch (SCM_Header.MessageType)
  54. {
  55. case packetType_MSG:
  56. if (connection->secureLayer.connectionState
  57. == connectionState_ESTABLISHED)
  58. {
  59. }
  60. else //receiving message, without secure channel
  61. {
  62. //TODO send back Error Message
  63. }
  64. break;
  65. case packetType_OPN:
  66. //Server Handling
  67. if (openSecureChannelHeader_check(connection, secureChannelMessage))
  68. {
  69. SL_secureChannel_open(connection, serviceMessage);
  70. }
  71. else
  72. {
  73. //TODO send back Error Message
  74. }
  75. //Client Handling
  76. //TODO free memory for secureChannelMessage
  77. break;
  78. case packetType_CLO:
  79. SL_secureChannel_close(connection, secureChannelMessage);
  80. //TODO free memory for secureChannelMessage
  81. break;
  82. }
  83. }
  84. UInt32 SL_secureChannel_SCMHeader_get(UA_connection *connection, AD_RawMessage *rawMessage, SL_SecureConversationMessageHeader* SC_Header)
  85. {
  86. Int32 pos = 0;
  87. SC_Header->MessageType = TL_getPacketType(rawMessage);
  88. pos += TL_MESSAGE_TYPE_LEN;
  89. SC_Header->IsFinal = rawMessage[pos];
  90. pos += sizeof(Byte);
  91. SC_Header->MessageSize = convertToUInt32(rawMessage,pos);
  92. pos += sizeof(UInt32);
  93. SC_Header->SecureChannelId = convertToUInt32(rawMessage,pos);
  94. pos += sizeof(UInt32);
  95. return pos;
  96. }
  97. UInt32 SL_secureChannel_AASHeader_get(UA_connection *connection, AD_RawMessage *rawMessage,UInt32 pos, SL_AsymmetricAlgorithmSecurityHeader* AAS_Header)
  98. {
  99. AAS_Header->SecurityPolicyUri.Length = convertToInt32(rawMessage,pos);
  100. pos += sizeof(Int32);
  101. AAS_Header->SecurityPolicyUri.Data = rawMessage[pos];
  102. if(AAS_Header->SecurityPolicyUri.Length < 0)
  103. {
  104. AAS_Header->SecurityPolicyUri.Length = 0;
  105. }
  106. pos += AAS_Header->SecurityPolicyUri.Length;
  107. AAS_Header->SenderCertificate.Length = convertToInt32(rawMessage,pos);
  108. pos += sizeof(Int32);
  109. if(AAS_Header->SenderCertificate.Length < 0)
  110. {
  111. AAS_Header->SenderCertificate.Length = 0;
  112. }
  113. AAS_Header->SenderCertificate.Data = rawMessage[pos];
  114. pos += AAS_Header->SenderCertificate.Length;
  115. AAS_Header->ReceiverThumbprint.Length = convertToInt32(rawMessage,pos);
  116. pos += sizeof(Int32);
  117. if(AAS_Header->ReceiverThumbprint.Length < 0)
  118. {
  119. AAS_Header->ReceiverThumbprint.Length = 0;
  120. }
  121. AAS_Header->ReceiverThumbprint.Data = rawMessage[pos];
  122. pos += AAS_Header->ReceiverThumbprint.Length;
  123. return pos;
  124. }
  125. void SL_secureChannel_Footer_get()
  126. {
  127. }
  128. void SL_secureChannel_Message_get(UA_connection *connection, AD_RawMessage *rawMessage,UInt32 pos, AD_RawMessage *message)
  129. {
  130. }