opcua_secureChannelLayer.c 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  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(UA_connection *connection,
  15. 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. if (openSecureChannelHeader_check(connection, secureChannelMessage))
  67. {
  68. SL_secureChannel_open(connection, serviceMessage);
  69. }
  70. else
  71. {
  72. //TODO send back Error Message
  73. }
  74. //TODO free memory for secureChannelMessage
  75. break;
  76. case packetType_CLO:
  77. SL_secureChannel_close(connection, secureChannelMessage);
  78. //TODO free memory for secureChannelMessage
  79. break;
  80. }
  81. }
  82. UInt32 SL_secureChannel_SCMHeader_get(UA_connection *connection, AD_RawMessage *rawMessage, SL_SecureConversationMessageHeader* SC_Header)
  83. {
  84. Int32 pos = 0;
  85. SC_Header->MessageType = TL_getPacketType(rawMessage);
  86. pos += TL_MESSAGE_TYPE_LEN;
  87. SC_Header->IsFinal = rawMessage[pos];
  88. pos += sizeof(Byte);
  89. SC_Header->MessageSize = convertToUInt32(rawMessage,pos);
  90. pos += sizeof(UInt32);
  91. SC_Header->SecureChannelId = convertToUInt32(rawMessage,pos);
  92. pos += sizeof(UInt32);
  93. return pos;
  94. }
  95. UInt32 SL_secureChannel_AASHeader_get(UA_connection *connection, AD_RawMessage *rawMessage,UInt32 pos, SL_AsymmetricAlgorithmSecurityHeader* AAS_Header)
  96. {
  97. AAS_Header->SecurityPolicyUri.Length = convertToInt32(rawMessage,pos);
  98. pos += sizeof(Int32);
  99. AAS_Header->SecurityPolicyUri.Data = rawMessage[pos];
  100. if(AAS_Header->SecurityPolicyUri.Length < 0)
  101. {
  102. AAS_Header->SecurityPolicyUri.Length = 0;
  103. }
  104. pos += AAS_Header->SecurityPolicyUri.Length;
  105. AAS_Header->SenderCertificate.Length = convertToInt32(rawMessage,pos);
  106. pos += sizeof(Int32);
  107. if(AAS_Header->SenderCertificate.Length < 0)
  108. {
  109. AAS_Header->SenderCertificate.Length = 0;
  110. }
  111. AAS_Header->SenderCertificate.Data = rawMessage[pos];
  112. pos += AAS_Header->SenderCertificate.Length;
  113. AAS_Header->ReceiverThumbprint.Length = convertToInt32(rawMessage,pos);
  114. pos += sizeof(Int32);
  115. if(AAS_Header->ReceiverThumbprint.Length < 0)
  116. {
  117. AAS_Header->ReceiverThumbprint.Length = 0;
  118. }
  119. AAS_Header->ReceiverThumbprint.Data = rawMessage[pos];
  120. pos += AAS_Header->ReceiverThumbprint.Length;
  121. return pos;
  122. }
  123. void SL_secureChannel_Footer_get()
  124. {
  125. }
  126. void SL_secureChannel_Message_get(UA_connection *connection, AD_RawMessage *rawMessage,UInt32 pos, AD_RawMessage *message)
  127. {
  128. }