Full OPC UA server on .NET Framework 4.8 (x86) exposing AVEVA System Platform Galaxy tags via MXAccess. Mirrors Galaxy object hierarchy as OPC UA address space, translating contained-name browse paths to tag-name runtime references. Components implemented: - Configuration: AppConfiguration with 4 sections, validator - Domain: ConnectionState, Quality, Vtq, MxDataTypeMapper, error codes - MxAccess: StaComThread, MxAccessClient (partial classes), MxProxyAdapter using strongly-typed ArchestrA.MxAccess COM interop - Galaxy Repository: SQL queries (hierarchy, attributes, change detection), ChangeDetectionService with auto-rebuild on deploy - OPC UA Server: LmxNodeManager (CustomNodeManager2), LmxOpcUaServer, OpcUaServerHost with programmatic config, SecurityPolicy None - Status Dashboard: HTTP server with HTML/JSON/health endpoints - Integration: Full 14-step startup, graceful shutdown, component wiring 175 tests (174 unit + 1 integration), all passing. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
9 lines
373 B
SQL
9 lines
373 B
SQL
-- Galaxy Change Detection for OPC UA Server
|
|
-- Poll this query on an interval to detect when the hierarchy needs refreshing.
|
|
-- When time_of_last_deploy changes, a deployment has occurred and the OPC UA
|
|
-- server should re-run hierarchy.sql and attributes.sql to pick up changes
|
|
-- (new/removed objects, undeployed objects, etc.).
|
|
|
|
SELECT time_of_last_deploy
|
|
FROM galaxy;
|