constants.h 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  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. *
  5. * Copyright 2016-2017 (c) Fraunhofer IOSB (Author: Julius Pfrommer)
  6. * Copyright 2016 (c) Sten Grüner
  7. * Copyright 2016-2017 (c) Stefan Profanter, fortiss GmbH
  8. * Copyright 2017 (c) Florian Palm
  9. */
  10. #ifndef UA_CONSTANTS_H_
  11. #define UA_CONSTANTS_H_
  12. #include <open62541/config.h>
  13. _UA_BEGIN_DECLS
  14. /**
  15. * Standard-Defined Constants
  16. * ==========================
  17. * This section contains numerical and string constants that are defined in the
  18. * OPC UA standard.
  19. *
  20. * .. _attribute-id:
  21. *
  22. * Attribute Id
  23. * ------------
  24. * Every node in an OPC UA information model contains attributes depending on
  25. * the node type. Possible attributes are as follows: */
  26. typedef enum {
  27. UA_ATTRIBUTEID_NODEID = 1,
  28. UA_ATTRIBUTEID_NODECLASS = 2,
  29. UA_ATTRIBUTEID_BROWSENAME = 3,
  30. UA_ATTRIBUTEID_DISPLAYNAME = 4,
  31. UA_ATTRIBUTEID_DESCRIPTION = 5,
  32. UA_ATTRIBUTEID_WRITEMASK = 6,
  33. UA_ATTRIBUTEID_USERWRITEMASK = 7,
  34. UA_ATTRIBUTEID_ISABSTRACT = 8,
  35. UA_ATTRIBUTEID_SYMMETRIC = 9,
  36. UA_ATTRIBUTEID_INVERSENAME = 10,
  37. UA_ATTRIBUTEID_CONTAINSNOLOOPS = 11,
  38. UA_ATTRIBUTEID_EVENTNOTIFIER = 12,
  39. UA_ATTRIBUTEID_VALUE = 13,
  40. UA_ATTRIBUTEID_DATATYPE = 14,
  41. UA_ATTRIBUTEID_VALUERANK = 15,
  42. UA_ATTRIBUTEID_ARRAYDIMENSIONS = 16,
  43. UA_ATTRIBUTEID_ACCESSLEVEL = 17,
  44. UA_ATTRIBUTEID_USERACCESSLEVEL = 18,
  45. UA_ATTRIBUTEID_MINIMUMSAMPLINGINTERVAL = 19,
  46. UA_ATTRIBUTEID_HISTORIZING = 20,
  47. UA_ATTRIBUTEID_EXECUTABLE = 21,
  48. UA_ATTRIBUTEID_USEREXECUTABLE = 22
  49. } UA_AttributeId;
  50. /**
  51. * Access Level Masks
  52. * ------------------
  53. * The access level to a node is given by the following constants that are ANDed
  54. * with the overall access level. */
  55. #define UA_ACCESSLEVELMASK_READ (0x01u << 0u)
  56. #define UA_ACCESSLEVELMASK_WRITE (0x01u << 1u)
  57. #define UA_ACCESSLEVELMASK_HISTORYREAD (0x01u << 2u)
  58. #define UA_ACCESSLEVELMASK_HISTORYWRITE (0x01u << 3u)
  59. #define UA_ACCESSLEVELMASK_SEMANTICCHANGE (0x01u << 4u)
  60. #define UA_ACCESSLEVELMASK_STATUSWRITE (0x01u << 5u)
  61. #define UA_ACCESSLEVELMASK_TIMESTAMPWRITE (0x01u << 6u)
  62. /**
  63. * Write Masks
  64. * -----------
  65. * The write mask and user write mask is given by the following constants that
  66. * are ANDed for the overall write mask. Part 3: 5.2.7 Table 2 */
  67. #define UA_WRITEMASK_ACCESSLEVEL (0x01u << 0u)
  68. #define UA_WRITEMASK_ARRRAYDIMENSIONS (0x01u << 1u)
  69. #define UA_WRITEMASK_BROWSENAME (0x01u << 2u)
  70. #define UA_WRITEMASK_CONTAINSNOLOOPS (0x01u << 3u)
  71. #define UA_WRITEMASK_DATATYPE (0x01u << 4u)
  72. #define UA_WRITEMASK_DESCRIPTION (0x01u << 5u)
  73. #define UA_WRITEMASK_DISPLAYNAME (0x01u << 6u)
  74. #define UA_WRITEMASK_EVENTNOTIFIER (0x01u << 7u)
  75. #define UA_WRITEMASK_EXECUTABLE (0x01u << 8u)
  76. #define UA_WRITEMASK_HISTORIZING (0x01u << 9u)
  77. #define UA_WRITEMASK_INVERSENAME (0x01u << 10u)
  78. #define UA_WRITEMASK_ISABSTRACT (0x01u << 11u)
  79. #define UA_WRITEMASK_MINIMUMSAMPLINGINTERVAL (0x01u << 12u)
  80. #define UA_WRITEMASK_NODECLASS (0x01u << 13u)
  81. #define UA_WRITEMASK_NODEID (0x01u << 14u)
  82. #define UA_WRITEMASK_SYMMETRIC (0x01u << 15u)
  83. #define UA_WRITEMASK_USERACCESSLEVEL (0x01u << 16u)
  84. #define UA_WRITEMASK_USEREXECUTABLE (0x01u << 17u)
  85. #define UA_WRITEMASK_USERWRITEMASK (0x01u << 18u)
  86. #define UA_WRITEMASK_VALUERANK (0x01u << 19u)
  87. #define UA_WRITEMASK_WRITEMASK (0x01u << 20u)
  88. #define UA_WRITEMASK_VALUEFORVARIABLETYPE (0x01u << 21u)
  89. /**
  90. * ValueRanks
  91. * ----------
  92. * The following are the most common ValueRanks used for Variables,
  93. * VariableTypes and method arguments. ValueRanks higher than 3 are valid as
  94. * well (but less common). */
  95. #define UA_VALUERANK_SCALAR_OR_ONE_DIMENSION -3
  96. #define UA_VALUERANK_ANY -2
  97. #define UA_VALUERANK_SCALAR -1
  98. #define UA_VALUERANK_ONE_OR_MORE_DIMENSIONS 0
  99. #define UA_VALUERANK_ONE_DIMENSION 1
  100. #define UA_VALUERANK_TWO_DIMENSIONS 2
  101. #define UA_VALUERANK_THREE_DIMENSIONS 3
  102. /**
  103. * Internal Constants
  104. * ==================
  105. *
  106. * Rule Handling
  107. * -------------
  108. *
  109. * The RuleHanding settings define how error cases that result from rules in the
  110. * OPC UA specification shall be handled. The rule handling can be softened,
  111. * e.g. to workaround misbehaving implementations or to mitigate the impact of
  112. * additional rules that are introduced in later versions of the OPC UA
  113. * specification. */
  114. typedef enum {
  115. UA_RULEHANDLING_DEFAULT = 0,
  116. UA_RULEHANDLING_ABORT, /* Abort the operation and return an error code */
  117. UA_RULEHANDLING_WARN, /* Print a message in the logs and continue */
  118. UA_RULEHANDLING_ACCEPT, /* Continue and disregard the broken rule */
  119. } UA_RuleHandling;
  120. /**
  121. * Order
  122. * -----
  123. *
  124. * The Order enum is used to establish an absolute ordering between elements.
  125. */
  126. typedef enum {
  127. UA_ORDER_LESS = -1,
  128. UA_ORDER_EQ = 0,
  129. UA_ORDER_MORE = 1
  130. } UA_Order;
  131. _UA_END_DECLS
  132. #endif /* UA_CONSTANTS_H_ */