use of org.eclipse.milo.opcua.sdk.server.api.AddressSpaceManager in project milo by eclipse.
the class NodeFactory method createNodeTree.
public Tree<UaNode> createNodeTree(NodeId rootNodeId, NodeId typeDefinitionId, InstantiationCallback instantiationCallback) throws UaException {
AddressSpaceManager addressSpaceManager = context.getServer().getAddressSpaceManager();
if (!addressSpaceManager.getManagedNode(typeDefinitionId).isPresent()) {
throw new UaException(StatusCodes.Bad_NodeIdUnknown, "unknown type definition: " + typeDefinitionId);
}
NamespaceTable namespaceTable = context.getServer().getNamespaceTable();
InstanceDeclarationHierarchy idh;
try {
idh = IDH_CACHE.get(typeDefinitionId, () -> {
LoggerFactory.getLogger(NodeFactory.class).debug("InstanceDeclarationHierarchy cache " + "miss for typeDefinitionId={}", typeDefinitionId);
return InstanceDeclarationHierarchy.create(addressSpaceManager, namespaceTable, typeDefinitionId);
});
} catch (ExecutionException e) {
throw new UaException(StatusCodes.Bad_InternalError, e);
}
NodeTable nodeTable = idh.getNodeTable();
ReferenceTable referenceTable = idh.getReferenceTable();
Map<BrowsePath, UaNode> nodes = new HashMap<>();
for (Map.Entry<BrowsePath, NodeId> entry : nodeTable.nodes.entrySet()) {
BrowsePath browsePath = entry.getKey();
NodeId nodeId = entry.getValue();
UaNode node = addressSpaceManager.getManagedNode(nodeId).orElse(null);
if (browsePath.parent == null) {
if (node instanceof UaObjectTypeNode) {
UaNode instance = instanceFromTypeDefinition(rootNodeId, (UaObjectTypeNode) node);
nodes.put(browsePath, instance);
} else if (node instanceof UaVariableTypeNode) {
UaNode instance = instanceFromTypeDefinition(rootNodeId, (UaVariableTypeNode) node);
nodes.put(browsePath, instance);
} else {
throw new UaException(StatusCodes.Bad_InternalError);
}
} else {
// Non-root Nodes are all instance declarations
NodeId instanceNodeId = instanceNodeId(rootNodeId, browsePath);
if (node instanceof UaMethodNode) {
UaMethodNode declaration = (UaMethodNode) node;
UaMethodNode instance = new UaMethodNode(context, instanceNodeId, declaration.getBrowseName(), declaration.getDisplayName(), declaration.getDescription(), declaration.getWriteMask(), declaration.getUserWriteMask(), declaration.isExecutable(), declaration.isUserExecutable());
nodes.put(browsePath, instance);
} else if (node instanceof UaObjectNode) {
UaObjectNode declaration = (UaObjectNode) node;
ExpandedNodeId instanceTypeDefinitionId = getTypeDefinition(referenceTable, browsePath);
UaNode typeDefinitionNode = addressSpaceManager.getManagedNode(instanceTypeDefinitionId).orElse(null);
if (typeDefinitionNode instanceof ObjectTypeNode) {
boolean optional = isOptionalDeclaration(declaration);
if (!optional || instantiationCallback.includeOptionalNode(typeDefinitionNode.getNodeId(), declaration.getBrowseName())) {
UaObjectNode instance = instanceFromTypeDefinition(instanceNodeId, (ObjectTypeNode) typeDefinitionNode);
instance.setBrowseName(declaration.getBrowseName());
instance.setDisplayName(declaration.getDisplayName());
instance.setDescription(declaration.getDescription());
instance.setWriteMask(declaration.getWriteMask());
instance.setUserWriteMask(declaration.getUserWriteMask());
instance.setEventNotifier(declaration.getEventNotifier());
nodes.put(browsePath, instance);
}
} else {
throw new UaException(StatusCodes.Bad_InternalError, "expected type definition for " + instanceTypeDefinitionId);
}
} else if (node instanceof UaVariableNode) {
UaVariableNode declaration = (UaVariableNode) node;
ExpandedNodeId instanceTypeDefinitionId = getTypeDefinition(referenceTable, browsePath);
UaNode typeDefinitionNode = addressSpaceManager.getManagedNode(instanceTypeDefinitionId).orElse(null);
if (typeDefinitionNode instanceof VariableTypeNode) {
boolean optional = isOptionalDeclaration(declaration);
if (!optional || instantiationCallback.includeOptionalNode(typeDefinitionNode.getNodeId(), declaration.getBrowseName())) {
UaVariableNode instance = instanceFromTypeDefinition(instanceNodeId, (VariableTypeNode) typeDefinitionNode);
instance.setBrowseName(declaration.getBrowseName());
instance.setDisplayName(declaration.getDisplayName());
instance.setDescription(declaration.getDescription());
instance.setWriteMask(declaration.getWriteMask());
instance.setUserWriteMask(declaration.getUserWriteMask());
instance.setValue(declaration.getValue());
instance.setDataType(declaration.getDataType());
instance.setValueRank(declaration.getValueRank());
instance.setArrayDimensions(declaration.getArrayDimensions());
instance.setAccessLevel(declaration.getAccessLevel());
instance.setUserAccessLevel(declaration.getUserAccessLevel());
nodes.put(browsePath, instance);
}
} else {
throw new UaException(StatusCodes.Bad_InternalError, "expected type definition for " + instanceTypeDefinitionId);
}
} else {
throw new UaException(StatusCodes.Bad_InternalError, "not an instance declaration: " + node);
}
}
}
nodes.forEach((browsePath, node) -> {
List<ReferenceTable.RefRow> references = referenceTable.getReferences(browsePath);
references.forEach(t -> {
NodeId referenceTypeId = t.nodeId;
ReferenceTable.RefTarget target = t.target;
if (!Identifiers.HasModellingRule.equals(referenceTypeId)) {
if (target.targetNodeId != null) {
node.addReference(new Reference(node.getNodeId(), referenceTypeId, target.targetNodeId, true));
} else {
BrowsePath targetPath = target.targetPath;
UaNode targetNode = nodes.get(targetPath);
if (targetNode != null) {
node.addReference(new Reference(node.getNodeId(), referenceTypeId, targetNode.getNodeId().expanded(), true));
}
}
}
});
context.getNodeManager().addNode(node);
});
Tree<UaNode> nodeTree = nodeTable.getBrowsePathTree().map(nodes::get);
notifyInstantiationCallback(nodeTree, instantiationCallback);
return nodeTree;
}
use of org.eclipse.milo.opcua.sdk.server.api.AddressSpaceManager in project milo by eclipse.
the class EventContentFilter method getParentTypeDefinition.
private static Optional<UaNode> getParentTypeDefinition(UaNode node, OpcUaServer server) {
AddressSpaceManager addressSpaceManager = server.getAddressSpaceManager();
NamespaceTable namespaceTable = server.getNamespaceTable();
return addressSpaceManager.getManagedReferences(node.getNodeId()).stream().filter(Reference.SUBTYPE_OF).flatMap(r -> opt2stream(r.getTargetNodeId().toNodeId(namespaceTable))).findFirst().flatMap(addressSpaceManager::getManagedNode);
}
Aggregations