Files
histsdk/docs/reverse-engineering/wcf-start-event-query-attempts-latest.json
dohertj2 c95824a65d Initial commit: managed .NET 10 AVEVA Historian SDK + reverse-engineering toolkit
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>
2026-05-04 06:31:48 -04:00

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
}
]