ua_session.c 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. /* This Source Code Form is subject to the terms of the Mozilla Public
  2. * License, v. 2.0. If a copy of the MPL was not distributed with this
  3. * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
  4. #include "ua_session.h"
  5. #include "ua_types_generated_handling.h"
  6. #include "ua_util.h"
  7. #ifdef UA_ENABLE_SUBSCRIPTIONS
  8. #include "server/ua_subscription.h"
  9. #endif
  10. UA_Session adminSession = {
  11. {{0, NULL},{0, NULL},
  12. {{0, NULL},{0, NULL}},
  13. UA_APPLICATIONTYPE_CLIENT,
  14. {0, NULL},{0, NULL},
  15. 0, NULL}, /* .clientDescription */
  16. {sizeof("Administrator Session")-1, (UA_Byte*)"Administrator Session"}, /* .sessionName */
  17. false, /* .activated */
  18. NULL, /* .sessionHandle */
  19. {0,UA_NODEIDTYPE_NUMERIC,{1}}, /* .authenticationToken */
  20. {0,UA_NODEIDTYPE_NUMERIC,{1}}, /* .sessionId */
  21. UA_UINT32_MAX, /* .maxRequestMessageSize */
  22. UA_UINT32_MAX, /* .maxResponseMessageSize */
  23. (UA_Double)UA_INT64_MAX, /* .timeout */
  24. UA_INT64_MAX, /* .validTill */
  25. {0, NULL},
  26. NULL, /* .channel */
  27. UA_MAXCONTINUATIONPOINTS, /* .availableContinuationPoints */
  28. {NULL}, /* .continuationPoints */
  29. #ifdef UA_ENABLE_SUBSCRIPTIONS
  30. 0, /* .lastSubscriptionID */
  31. 0, /* .lastSeenSubscriptionID */
  32. {NULL}, /* .serverSubscriptions */
  33. {NULL, NULL}, /* .responseQueue */
  34. #endif
  35. };
  36. void UA_Session_init(UA_Session *session) {
  37. UA_ApplicationDescription_init(&session->clientDescription);
  38. session->activated = false;
  39. UA_NodeId_init(&session->authenticationToken);
  40. UA_NodeId_init(&session->sessionId);
  41. UA_String_init(&session->sessionName);
  42. UA_ByteString_init(&session->serverNonce);
  43. session->maxRequestMessageSize = 0;
  44. session->maxResponseMessageSize = 0;
  45. session->timeout = 0;
  46. UA_DateTime_init(&session->validTill);
  47. session->channel = NULL;
  48. session->availableContinuationPoints = UA_MAXCONTINUATIONPOINTS;
  49. LIST_INIT(&session->continuationPoints);
  50. #ifdef UA_ENABLE_SUBSCRIPTIONS
  51. LIST_INIT(&session->serverSubscriptions);
  52. session->lastSubscriptionID = 0;
  53. session->lastSeenSubscriptionID = 0;
  54. SIMPLEQ_INIT(&session->responseQueue);
  55. #endif
  56. }
  57. void UA_Session_deleteMembersCleanup(UA_Session *session, UA_Server* server) {
  58. UA_ApplicationDescription_deleteMembers(&session->clientDescription);
  59. UA_NodeId_deleteMembers(&session->authenticationToken);
  60. UA_NodeId_deleteMembers(&session->sessionId);
  61. UA_String_deleteMembers(&session->sessionName);
  62. UA_ByteString_deleteMembers(&session->serverNonce);
  63. struct ContinuationPointEntry *cp, *temp;
  64. LIST_FOREACH_SAFE(cp, &session->continuationPoints, pointers, temp) {
  65. LIST_REMOVE(cp, pointers);
  66. UA_ByteString_deleteMembers(&cp->identifier);
  67. UA_BrowseDescription_deleteMembers(&cp->browseDescription);
  68. UA_free(cp);
  69. }
  70. if(session->channel)
  71. UA_SecureChannel_detachSession(session->channel, session);
  72. #ifdef UA_ENABLE_SUBSCRIPTIONS
  73. UA_Subscription *currents, *temps;
  74. LIST_FOREACH_SAFE(currents, &session->serverSubscriptions, listEntry, temps) {
  75. LIST_REMOVE(currents, listEntry);
  76. UA_Subscription_deleteMembers(currents, server);
  77. UA_free(currents);
  78. }
  79. UA_PublishResponseEntry *entry;
  80. while((entry = SIMPLEQ_FIRST(&session->responseQueue))) {
  81. SIMPLEQ_REMOVE_HEAD(&session->responseQueue, listEntry);
  82. UA_PublishResponse_deleteMembers(&entry->response);
  83. UA_free(entry);
  84. }
  85. #endif
  86. }
  87. void UA_Session_updateLifetime(UA_Session *session) {
  88. session->validTill = UA_DateTime_nowMonotonic() +
  89. (UA_DateTime)(session->timeout * UA_MSEC_TO_DATETIME);
  90. }
  91. #ifdef UA_ENABLE_SUBSCRIPTIONS
  92. void UA_Session_addSubscription(UA_Session *session, UA_Subscription *newSubscription) {
  93. LIST_INSERT_HEAD(&session->serverSubscriptions, newSubscription, listEntry);
  94. }
  95. UA_StatusCode
  96. UA_Session_deleteSubscription(UA_Server *server, UA_Session *session,
  97. UA_UInt32 subscriptionID) {
  98. UA_Subscription *sub = UA_Session_getSubscriptionByID(session, subscriptionID);
  99. if(!sub)
  100. return UA_STATUSCODE_BADSUBSCRIPTIONIDINVALID;
  101. LIST_REMOVE(sub, listEntry);
  102. UA_Subscription_deleteMembers(sub, server);
  103. UA_free(sub);
  104. return UA_STATUSCODE_GOOD;
  105. }
  106. UA_Subscription *
  107. UA_Session_getSubscriptionByID(UA_Session *session, UA_UInt32 subscriptionID) {
  108. UA_Subscription *sub;
  109. LIST_FOREACH(sub, &session->serverSubscriptions, listEntry) {
  110. if(sub->subscriptionID == subscriptionID)
  111. break;
  112. }
  113. return sub;
  114. }
  115. UA_UInt32 UA_Session_getUniqueSubscriptionID(UA_Session *session) {
  116. return ++(session->lastSubscriptionID);
  117. }
  118. #endif