c95824a65d
Full read-only SDK (src/AVEVA.Historian.Client) implementing the CLAUDE.md required
surface against AVEVA Historian's binary WCF protocol — no native AVEVA runtime
dependency. All operations live-verified against a local Historian:
- ProbeAsync, ReadRawAsync, ReadAggregateAsync, ReadAtTimeAsync, ReadEventsAsync
- BrowseTagNamesAsync, GetTagMetadataAsync (17 native data-type codes mapped)
- GetConnectionStatusAsync, GetStoreForwardStatusAsync, GetSystemParameterAsync
- 108/108 unit + integration tests pass
Includes the reverse-engineering toolkit (tools/AVEVA.Historian.ReverseEngineering)
used to decode the protocol: WCF probes, IL inspection via dnlib, and IL-rewrite
instrumentation (instrument-wcf-{write,read}message etc.) plus the .NET Framework
trace harness (tools/AVEVA.Historian.NativeTraceHarness) for parity testing.
Sanitized handoff evidence under docs/reverse-engineering/. Native AVEVA binaries
(current/, aveva-install-x64/, aveva-install-x86/) are gitignored — fetch separately
from the AVEVA installer.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
231 lines
7.2 KiB
JSON
231 lines
7.2 KiB
JSON
[
|
|
{
|
|
"Attempt": "native-empty-filter-version5",
|
|
"OpenAttempt": "legacy-v1-process-integrated-windows-v11-mode1026-hist-integrated",
|
|
"HandleMode": "open-handle",
|
|
"RetrievalOperation": "StartEventQuery",
|
|
"Version": 5,
|
|
"RequestByteCount": 65,
|
|
"RequestSha256": "cb41a8a902dc900eb66972fdda0da7ad963948ef5a587cde75ba2c72bd3fb344",
|
|
"ClientHandle": 1864172287,
|
|
"Success": false,
|
|
"QueryHandle": 0,
|
|
"ResponseSize": 0,
|
|
"ResponseByteCount": null,
|
|
"ErrorSize": 0,
|
|
"NativeErrorCode": null,
|
|
"OpenErrorSize": null,
|
|
"OpenNativeErrorCode": null,
|
|
"Error": null
|
|
},
|
|
{
|
|
"Attempt": "native-empty-filter-version5",
|
|
"OpenAttempt": "legacy-v1-process-integrated-windows-v11-mode1026-hist-integrated",
|
|
"HandleMode": "open-handle",
|
|
"RetrievalOperation": "StartQuery2",
|
|
"Version": 5,
|
|
"RequestByteCount": 65,
|
|
"RequestSha256": "cb41a8a902dc900eb66972fdda0da7ad963948ef5a587cde75ba2c72bd3fb344",
|
|
"ClientHandle": 515844716,
|
|
"Success": false,
|
|
"QueryHandle": 0,
|
|
"ResponseSize": 0,
|
|
"ResponseByteCount": null,
|
|
"ErrorSize": 0,
|
|
"NativeErrorCode": null,
|
|
"OpenErrorSize": null,
|
|
"OpenNativeErrorCode": null,
|
|
"Error": null
|
|
},
|
|
{
|
|
"Attempt": "native-empty-filter-version5",
|
|
"OpenAttempt": "legacy-v1-process-integrated-windows-v11-mode1026-hist-integrated",
|
|
"HandleMode": "client-app-event-slot-handle",
|
|
"RetrievalOperation": "StartEventQuery",
|
|
"Version": 5,
|
|
"RequestByteCount": 65,
|
|
"RequestSha256": "cb41a8a902dc900eb66972fdda0da7ad963948ef5a587cde75ba2c72bd3fb344",
|
|
"ClientHandle": 1,
|
|
"Success": false,
|
|
"QueryHandle": 0,
|
|
"ResponseSize": 0,
|
|
"ResponseByteCount": null,
|
|
"ErrorSize": 0,
|
|
"NativeErrorCode": null,
|
|
"OpenErrorSize": null,
|
|
"OpenNativeErrorCode": null,
|
|
"Error": null
|
|
},
|
|
{
|
|
"Attempt": "native-empty-filter-version5",
|
|
"OpenAttempt": "legacy-v1-process-integrated-windows-v11-mode1026-hist-integrated",
|
|
"HandleMode": "client-app-event-slot-handle",
|
|
"RetrievalOperation": "StartQuery2",
|
|
"Version": 5,
|
|
"RequestByteCount": 65,
|
|
"RequestSha256": "cb41a8a902dc900eb66972fdda0da7ad963948ef5a587cde75ba2c72bd3fb344",
|
|
"ClientHandle": 1,
|
|
"Success": false,
|
|
"QueryHandle": 0,
|
|
"ResponseSize": 0,
|
|
"ResponseByteCount": null,
|
|
"ErrorSize": 0,
|
|
"NativeErrorCode": null,
|
|
"OpenErrorSize": null,
|
|
"OpenNativeErrorCode": null,
|
|
"Error": null
|
|
},
|
|
{
|
|
"Attempt": "native-empty-filter-version5",
|
|
"OpenAttempt": "legacy-v1-process-integrated-windows-v11-mode1026-hist-integrated",
|
|
"HandleMode": "event-tag-handle",
|
|
"RetrievalOperation": "StartEventQuery",
|
|
"Version": 5,
|
|
"RequestByteCount": 65,
|
|
"RequestSha256": "cb41a8a902dc900eb66972fdda0da7ad963948ef5a587cde75ba2c72bd3fb344",
|
|
"ClientHandle": 10000000,
|
|
"Success": false,
|
|
"QueryHandle": 0,
|
|
"ResponseSize": 0,
|
|
"ResponseByteCount": null,
|
|
"ErrorSize": 0,
|
|
"NativeErrorCode": null,
|
|
"OpenErrorSize": null,
|
|
"OpenNativeErrorCode": null,
|
|
"Error": null
|
|
},
|
|
{
|
|
"Attempt": "native-empty-filter-version5",
|
|
"OpenAttempt": "legacy-v1-process-integrated-windows-v11-mode1026-hist-integrated",
|
|
"HandleMode": "event-tag-handle",
|
|
"RetrievalOperation": "StartQuery2",
|
|
"Version": 5,
|
|
"RequestByteCount": 65,
|
|
"RequestSha256": "cb41a8a902dc900eb66972fdda0da7ad963948ef5a587cde75ba2c72bd3fb344",
|
|
"ClientHandle": 10000000,
|
|
"Success": false,
|
|
"QueryHandle": 0,
|
|
"ResponseSize": 0,
|
|
"ResponseByteCount": null,
|
|
"ErrorSize": 0,
|
|
"NativeErrorCode": null,
|
|
"OpenErrorSize": null,
|
|
"OpenNativeErrorCode": null,
|
|
"Error": null
|
|
},
|
|
{
|
|
"Attempt": "native-empty-filter-version5",
|
|
"OpenAttempt": "legacy-v1-event-integrated-windows-v11-mode1281-hist-integrated",
|
|
"HandleMode": "open-handle",
|
|
"RetrievalOperation": "StartEventQuery",
|
|
"Version": 5,
|
|
"RequestByteCount": 65,
|
|
"RequestSha256": "cb41a8a902dc900eb66972fdda0da7ad963948ef5a587cde75ba2c72bd3fb344",
|
|
"ClientHandle": 783821061,
|
|
"Success": false,
|
|
"QueryHandle": 0,
|
|
"ResponseSize": 0,
|
|
"ResponseByteCount": null,
|
|
"ErrorSize": 0,
|
|
"NativeErrorCode": null,
|
|
"OpenErrorSize": null,
|
|
"OpenNativeErrorCode": null,
|
|
"Error": null
|
|
},
|
|
{
|
|
"Attempt": "native-empty-filter-version5",
|
|
"OpenAttempt": "legacy-v1-event-integrated-windows-v11-mode1281-hist-integrated",
|
|
"HandleMode": "open-handle",
|
|
"RetrievalOperation": "StartQuery2",
|
|
"Version": 5,
|
|
"RequestByteCount": 65,
|
|
"RequestSha256": "cb41a8a902dc900eb66972fdda0da7ad963948ef5a587cde75ba2c72bd3fb344",
|
|
"ClientHandle": 2035106190,
|
|
"Success": false,
|
|
"QueryHandle": 0,
|
|
"ResponseSize": 0,
|
|
"ResponseByteCount": null,
|
|
"ErrorSize": 0,
|
|
"NativeErrorCode": null,
|
|
"OpenErrorSize": null,
|
|
"OpenNativeErrorCode": null,
|
|
"Error": null
|
|
},
|
|
{
|
|
"Attempt": "native-empty-filter-version5",
|
|
"OpenAttempt": "legacy-v1-event-integrated-windows-v11-mode1281-hist-integrated",
|
|
"HandleMode": "client-app-event-slot-handle",
|
|
"RetrievalOperation": "StartEventQuery",
|
|
"Version": 5,
|
|
"RequestByteCount": 65,
|
|
"RequestSha256": "cb41a8a902dc900eb66972fdda0da7ad963948ef5a587cde75ba2c72bd3fb344",
|
|
"ClientHandle": 1,
|
|
"Success": false,
|
|
"QueryHandle": 0,
|
|
"ResponseSize": 0,
|
|
"ResponseByteCount": null,
|
|
"ErrorSize": 0,
|
|
"NativeErrorCode": null,
|
|
"OpenErrorSize": null,
|
|
"OpenNativeErrorCode": null,
|
|
"Error": null
|
|
},
|
|
{
|
|
"Attempt": "native-empty-filter-version5",
|
|
"OpenAttempt": "legacy-v1-event-integrated-windows-v11-mode1281-hist-integrated",
|
|
"HandleMode": "client-app-event-slot-handle",
|
|
"RetrievalOperation": "StartQuery2",
|
|
"Version": 5,
|
|
"RequestByteCount": 65,
|
|
"RequestSha256": "cb41a8a902dc900eb66972fdda0da7ad963948ef5a587cde75ba2c72bd3fb344",
|
|
"ClientHandle": 1,
|
|
"Success": false,
|
|
"QueryHandle": 0,
|
|
"ResponseSize": 0,
|
|
"ResponseByteCount": null,
|
|
"ErrorSize": 0,
|
|
"NativeErrorCode": null,
|
|
"OpenErrorSize": null,
|
|
"OpenNativeErrorCode": null,
|
|
"Error": null
|
|
},
|
|
{
|
|
"Attempt": "native-empty-filter-version5",
|
|
"OpenAttempt": "legacy-v1-event-integrated-windows-v11-mode1281-hist-integrated",
|
|
"HandleMode": "event-tag-handle",
|
|
"RetrievalOperation": "StartEventQuery",
|
|
"Version": 5,
|
|
"RequestByteCount": 65,
|
|
"RequestSha256": "cb41a8a902dc900eb66972fdda0da7ad963948ef5a587cde75ba2c72bd3fb344",
|
|
"ClientHandle": 10000000,
|
|
"Success": false,
|
|
"QueryHandle": 0,
|
|
"ResponseSize": 0,
|
|
"ResponseByteCount": null,
|
|
"ErrorSize": 0,
|
|
"NativeErrorCode": null,
|
|
"OpenErrorSize": null,
|
|
"OpenNativeErrorCode": null,
|
|
"Error": null
|
|
},
|
|
{
|
|
"Attempt": "native-empty-filter-version5",
|
|
"OpenAttempt": "legacy-v1-event-integrated-windows-v11-mode1281-hist-integrated",
|
|
"HandleMode": "event-tag-handle",
|
|
"RetrievalOperation": "StartQuery2",
|
|
"Version": 5,
|
|
"RequestByteCount": 65,
|
|
"RequestSha256": "cb41a8a902dc900eb66972fdda0da7ad963948ef5a587cde75ba2c72bd3fb344",
|
|
"ClientHandle": 10000000,
|
|
"Success": false,
|
|
"QueryHandle": 0,
|
|
"ResponseSize": 0,
|
|
"ResponseByteCount": null,
|
|
"ErrorSize": 0,
|
|
"NativeErrorCode": null,
|
|
"OpenErrorSize": null,
|
|
"OpenNativeErrorCode": null,
|
|
"Error": null
|
|
}
|
|
]
|