123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144 |
- /*
- * Copyright (C) 2014 the contributors as stated in the AUTHORS file
- *
- * This file is part of open62541. open62541 is free software: you can
- * redistribute it and/or modify it under the terms of the GNU Lesser General
- * Public License, version 3 (as published by the Free Software Foundation) with
- * a static linking exception as stated in the LICENSE file provided with
- * open62541.
- *
- * open62541 is distributed in the hope that it will be useful, but WITHOUT ANY
- * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
- * A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
- * details.
- */
- #ifndef UA_SERVER_H_
- #define UA_SERVER_H_
- #ifdef __cplusplus
- extern "C" {
- #endif
- #include "ua_types.h"
- #include "ua_types_generated.h"
- #include "ua_connection.h"
- #include "ua_log.h"
- /**
- * @defgroup server Server
- *
- * @brief This module describes the server object and functions to interact with * it.
- *
- * @{
- */
- struct UA_Server;
- typedef struct UA_Server UA_Server;
- UA_Server UA_EXPORT * UA_Server_new(UA_String *endpointUrl, UA_ByteString *serverCertificate);
- void UA_EXPORT UA_Server_delete(UA_Server *server);
- void UA_EXPORT UA_Server_processBinaryMessage(UA_Server *server, UA_Connection *connection,
- const UA_ByteString *msg);
- /**
- * @brief Adds a node to the server's address space
- *
- * If adding the node succeeds, the pointer to the node is set to null. If the
- * original nodeid is null (ns=0,i=0), a unique new nodeid is created for the
- * node and returned in the AddNodesResult struct. */
- UA_AddNodesResult UA_EXPORT
- UA_Server_addNode(UA_Server *server, const UA_Node **node, const UA_ExpandedNodeId *parentNodeId,
- const UA_NodeId *referenceTypeId);
- /** @brief Adds a reference to the server's address space */
- UA_StatusCode UA_EXPORT
- UA_Server_addReference(UA_Server *server, const UA_AddReferencesItem *item);
- /**
- * @brief Adds a VariableNode to the server's address space that points to a
- * scalar value. The value must lie on the heap and cannot be reused afterwards
- * as it becomes attached to the lifecycle of the VariableNode */
- void UA_EXPORT
- UA_Server_addScalarVariableNode(UA_Server *server, UA_QualifiedName *browseName, void *value,
- const UA_TypeVTable *vt, const UA_ExpandedNodeId *parentNodeId,
- const UA_NodeId *referenceTypeId );
- /** @} */
- /**
- * @ingroup server
- *
- * @defgroup external_nodestore External Nodestore
- *
- * @brief This modules describes the VTable and function signatures to add an
- * external nodestore to the server.
- *
- * To plug in outside data sources, one can use
- *
- * - VariableNodes with a data source (functions that are called for read and write access)
- * - An external nodestore that is mapped to specific namespaces
- *
- * If no external nodestore is defined for a nodeid, it is always looked up in
- * the "local" nodestore of open62541. Namespace Zero is always in the local
- * nodestore.
- *
- * @{
- */
- typedef UA_Int32 (*UA_ExternalNodeStore_addNodes)
- (void *ensHandle, const UA_RequestHeader *requestHeader, UA_AddNodesItem *nodesToAdd, UA_UInt32 *indices,
- UA_UInt32 indicesSize, UA_AddNodesResult* addNodesResults, UA_DiagnosticInfo *diagnosticInfos);
- typedef UA_Int32 (*UA_ExternalNodeStore_addReferences)
- (void *ensHandle, const UA_RequestHeader *requestHeader, UA_AddReferencesItem* referencesToAdd,
- UA_UInt32 *indices,UA_UInt32 indicesSize, UA_StatusCode *addReferencesResults,
- UA_DiagnosticInfo *diagnosticInfos);
- typedef UA_Int32 (*UA_ExternalNodeStore_deleteNodes)
- (void *ensHandle, const UA_RequestHeader *requestHeader, UA_DeleteNodesItem *nodesToDelete, UA_UInt32 *indices,
- UA_UInt32 indicesSize, UA_StatusCode *deleteNodesResults, UA_DiagnosticInfo *diagnosticInfos);
- typedef UA_Int32 (*UA_ExternalNodeStore_deleteReferences)
- (void *ensHandle, const UA_RequestHeader *requestHeader, UA_DeleteReferencesItem *referenceToDelete,
- UA_UInt32 *indices, UA_UInt32 indicesSize, UA_StatusCode deleteReferencesresults,
- UA_DiagnosticInfo *diagnosticInfos);
- typedef UA_Int32 (*UA_ExternalNodeStore_readNodes)
- (void *ensHandle, const UA_RequestHeader *requestHeader, UA_ReadValueId *readValueIds, UA_UInt32 *indices,
- UA_UInt32 indicesSize,UA_DataValue *readNodesResults, UA_Boolean timeStampToReturn,
- UA_DiagnosticInfo *diagnosticInfos);
- typedef UA_Int32 (*UA_ExternalNodeStore_writeNodes)
- (void *ensHandle, const UA_RequestHeader *requestHeader, UA_WriteValue *writeValues, UA_UInt32 *indices,
- UA_UInt32 indicesSize, UA_StatusCode *writeNodesResults, UA_DiagnosticInfo *diagnosticInfo);
- typedef UA_Int32 (*UA_ExternalNodeStore_browseNodes)
- (void *ensHandle, const UA_RequestHeader *requestHeader, UA_BrowseDescription *browseDescriptions,
- UA_UInt32 *indices, UA_UInt32 indicesSize, UA_UInt32 requestedMaxReferencesPerNode,
- UA_BrowseResult *browseResults, UA_DiagnosticInfo *diagnosticInfos);
- typedef UA_Int32 (*UA_ExternalNodeStore_delete)(void *ensHandle);
- typedef struct UA_ExternalNodeStore {
- void *ensHandle;
- UA_ExternalNodeStore_addNodes addNodes;
- UA_ExternalNodeStore_deleteNodes deleteNodes;
- UA_ExternalNodeStore_writeNodes writeNodes;
- UA_ExternalNodeStore_readNodes readNodes;
- UA_ExternalNodeStore_browseNodes browseNodes;
- UA_ExternalNodeStore_addReferences addReferences;
- UA_ExternalNodeStore_deleteReferences deleteReferences;
- UA_ExternalNodeStore_delete delete;
- } UA_ExternalNodeStore;
- UA_StatusCode UA_EXPORT
- UA_Server_addExternalNamespace(UA_Server *server, UA_UInt16 namespaceIndex, UA_ExternalNodeStore *nodeStore);
- /** @} */
- #ifdef __cplusplus
- } // extern "C"
- #endif
- #endif /* UA_SERVER_H_ */
|