Files
lmxopcua/gr/ddl/tables/package.sql
Joseph Doherty a7576ffb38 Implement LmxOpcUa server — all 6 phases complete
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>
2026-03-25 05:55:27 -04:00

22 lines
860 B
Transact-SQL

-- Table: package
CREATE TABLE [package] (
[gobject_id] int NOT NULL,
[package_id] int NOT NULL,
[status_id] int NOT NULL DEFAULT ((0)),
[reference_status_id] int NOT NULL DEFAULT ((0)),
[instance_attributes] image(2147483647) NULL,
[operation_status] int NOT NULL DEFAULT ((0)),
[security_group] nvarchar(32) NOT NULL DEFAULT ('Default'),
[derived_from_package_id] int NOT NULL DEFAULT ((0)),
[deployable_configuration_version] int NOT NULL DEFAULT ((0)),
[package_type] nvarchar(5) NOT NULL DEFAULT ('I'),
[package_version] smallint NOT NULL DEFAULT ((0)),
[object_status] smallint NOT NULL DEFAULT ((0)),
CONSTRAINT [PK_package] PRIMARY KEY ([gobject_id], [package_id], [gobject_id], [status_id])
);
GO
ALTER TABLE [package] ADD FOREIGN KEY ([status_id]) REFERENCES [lookup_status] ([status_id]);
GO