#include "ua_session.h" #include "ua_types_generated_handling.h" #include "ua_util.h" #ifdef UA_ENABLE_SUBSCRIPTIONS #include "server/ua_subscription.h" #endif UA_Session adminSession = { .clientDescription = {.applicationUri = {0, NULL}, .productUri = {0, NULL}, .applicationName = {.locale = {0, NULL}, .text = {0, NULL}}, .applicationType = UA_APPLICATIONTYPE_CLIENT, .gatewayServerUri = {0, NULL}, .discoveryProfileUri = {0, NULL}, .discoveryUrlsSize = 0, .discoveryUrls = NULL}, .sessionName = {sizeof("Administrator Session")-1, (UA_Byte*)"Administrator Session"}, .authenticationToken = {.namespaceIndex = 0, .identifierType = UA_NODEIDTYPE_NUMERIC, .identifier.numeric = 1}, .sessionId = {.namespaceIndex = 0, .identifierType = UA_NODEIDTYPE_NUMERIC, .identifier.numeric = 1}, .maxRequestMessageSize = UA_UINT32_MAX, .maxResponseMessageSize = UA_UINT32_MAX, .timeout = (UA_Double)UA_INT64_MAX, .validTill = UA_INT64_MAX, .channel = NULL, .continuationPoints = {NULL}}; void UA_Session_init(UA_Session *session) { UA_ApplicationDescription_init(&session->clientDescription); session->activated = false; UA_NodeId_init(&session->authenticationToken); UA_NodeId_init(&session->sessionId); UA_String_init(&session->sessionName); session->maxRequestMessageSize = 0; session->maxResponseMessageSize = 0; session->timeout = 0; UA_DateTime_init(&session->validTill); session->channel = NULL; session->availableContinuationPoints = UA_MAXCONTINUATIONPOINTS; LIST_INIT(&session->continuationPoints); #ifdef UA_ENABLE_SUBSCRIPTIONS LIST_INIT(&session->serverSubscriptions); session->lastSubscriptionID = 0; SIMPLEQ_INIT(&session->responseQueue); #endif } void UA_Session_deleteMembersCleanup(UA_Session *session, UA_Server* server) { UA_ApplicationDescription_deleteMembers(&session->clientDescription); UA_NodeId_deleteMembers(&session->authenticationToken); UA_NodeId_deleteMembers(&session->sessionId); UA_String_deleteMembers(&session->sessionName); struct ContinuationPointEntry *cp, *temp; LIST_FOREACH_SAFE(cp, &session->continuationPoints, pointers, temp) { LIST_REMOVE(cp, pointers); UA_ByteString_deleteMembers(&cp->identifier); UA_BrowseDescription_deleteMembers(&cp->browseDescription); UA_free(cp); } if(session->channel) UA_SecureChannel_detachSession(session->channel, session); #ifdef UA_ENABLE_SUBSCRIPTIONS UA_Subscription *currents, *temps; LIST_FOREACH_SAFE(currents, &session->serverSubscriptions, listEntry, temps) { LIST_REMOVE(currents, listEntry); UA_Subscription_deleteMembers(currents, server); UA_free(currents); } UA_PublishResponseEntry *entry; while((entry = SIMPLEQ_FIRST(&session->responseQueue))) { SIMPLEQ_REMOVE_HEAD(&session->responseQueue, listEntry); UA_PublishResponse_deleteMembers(&entry->response); UA_free(entry); } #endif } void UA_Session_updateLifetime(UA_Session *session) { session->validTill = UA_DateTime_nowMonotonic() + (UA_DateTime)(session->timeout * UA_MSEC_TO_DATETIME); } #ifdef UA_ENABLE_SUBSCRIPTIONS void UA_Session_addSubscription(UA_Session *session, UA_Subscription *newSubscription) { LIST_INSERT_HEAD(&session->serverSubscriptions, newSubscription, listEntry); } UA_StatusCode UA_Session_deleteSubscription(UA_Server *server, UA_Session *session, UA_UInt32 subscriptionID) { UA_Subscription *sub = UA_Session_getSubscriptionByID(session, subscriptionID); if(!sub) return UA_STATUSCODE_BADSUBSCRIPTIONIDINVALID; LIST_REMOVE(sub, listEntry); UA_Subscription_deleteMembers(sub, server); UA_free(sub); return UA_STATUSCODE_GOOD; } UA_Subscription * UA_Session_getSubscriptionByID(UA_Session *session, UA_UInt32 subscriptionID) { UA_Subscription *sub; LIST_FOREACH(sub, &session->serverSubscriptions, listEntry) { if(sub->subscriptionID == subscriptionID) break; } return sub; } UA_UInt32 UA_Session_getUniqueSubscriptionID(UA_Session *session) { return ++(session->lastSubscriptionID); } #endif