This MVP release provides a complete full-stack solution for managing action mappings in Geutebruck's GeViScope and GeViSoft video surveillance systems. ## Features ### Flutter Web Application (Port 8081) - Modern, responsive UI for managing action mappings - Action picker dialog with full parameter configuration - Support for both GSC (GeViScope) and G-Core server actions - Consistent UI for input and output actions with edit/delete capabilities - Real-time action mapping creation, editing, and deletion - Server categorization (GSC: prefix for GeViScope, G-Core: prefix for G-Core servers) ### FastAPI REST Backend (Port 8000) - RESTful API for action mapping CRUD operations - Action template service with comprehensive action catalog (247 actions) - Server management (G-Core and GeViScope servers) - Configuration tree reading and writing - JWT authentication with role-based access control - PostgreSQL database integration ### C# SDK Bridge (gRPC, Port 50051) - Native integration with GeViSoft SDK (GeViProcAPINET_4_0.dll) - Action mapping creation with correct binary format - Support for GSC and G-Core action types - Proper Camera parameter inclusion in action strings (fixes CrossSwitch bug) - Action ID lookup table with server-specific action IDs - Configuration reading/writing via SetupClient ## Bug Fixes - **CrossSwitch Bug**: GSC and G-Core actions now correctly display camera/PTZ head parameters in GeViSet - Action strings now include Camera parameter: `@ PanLeft (Comment: "", Camera: 101028)` - Proper filter flags and VideoInput=0 for action mappings - Correct action ID assignment (4198 for GSC, 9294 for G-Core PanLeft) ## Technical Stack - **Frontend**: Flutter Web, Dart, Dio HTTP client - **Backend**: Python FastAPI, PostgreSQL, Redis - **SDK Bridge**: C# .NET 8.0, gRPC, GeViSoft SDK - **Authentication**: JWT tokens - **Configuration**: GeViSoft .set files (binary format) ## Credentials - GeViSoft/GeViScope: username=sysadmin, password=masterkey - Default admin: username=admin, password=admin123 ## Deployment All services run on localhost: - Flutter Web: http://localhost:8081 - FastAPI: http://localhost:8000 - SDK Bridge gRPC: localhost:50051 - GeViServer: localhost (default port) Generated with Claude Code (https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
8.1 KiB
Structured Action Mappings Implementation - Summary
Overview
Successfully implemented structured action mapping extraction with parameters for the GeViSoft/Geutebruck video management system.
What Was Accomplished
1. Protobuf Definition Updates ✓
File: configuration.proto
Added structured message types:
message ActionParameter {
string name = 1; // e.g., "VideoInput", "SwitchMode"
string value = 2; // e.g., "101027", "True"
}
message ActionDefinition {
string action = 1; // Action name
repeated ActionParameter parameters = 2; // Named parameters
}
message ConfigActionMapping {
string name = 1;
repeated ActionDefinition input_actions = 2; // Trigger/condition actions
repeated ActionDefinition output_actions = 3; // Response actions
int32 start_offset = 4;
int32 end_offset = 5;
repeated string actions = 6; // Deprecated - backward compatibility
}
2. Binary Parser Enhancements ✓
Files: ComprehensiveConfigParser.cs, SelectiveConfigParser.cs
Key Improvements:
- Parse properties (parameters) from action mapping binary data
- Extract property names and values (boolean, integer, null types)
- Handle action data that extends beyond marker name field
- Use raw bytes instead of UTF-8 string conversion to preserve binary data
Parser Logic:
- Identify "ules" markers (action mappings)
- Extract marker name bytes + 200 following bytes
- Parse properties:
01 <length> <name> <value> - Parse actions:
07 01 40 <length> <action_string> - Store properties as children nodes
- Store actions as value list
3. gRPC Service Implementation ✓
File: ConfigurationServiceImplementation.cs
Updated ReadActionMappings to:
- Extract properties from
ConfigNode.Children - Convert properties to
ActionParameterprotobuf messages - Create
ActionDefinitionobjects with action + parameters - Populate
output_actionsfield (all actions treated as output for now) - Maintain backward compatibility with old
actionsfield
4. Results
Total Action Mappings Found: 51 Mappings with Parameters: 11
Example 1 - Simple Mapping (no parameters):
{
"offset": 253894,
"output_actions": [
{
"action": "GSC ViewerConnectLive V <- C",
"parameters": {}
},
{
"action": "GNG ViewerConnectLive V <- C_101027",
"parameters": {}
}
]
}
Example 2 - Complex Mapping (with parameters):
{
"offset": 258581,
"output_actions": [
{
"action": "GSC ViewerClear V",
"parameters": {
"ClientID": "",
"WarningCode": "True",
"WarningText": ""
}
},
{
"action": "GNG ViewerClear V",
"parameters": {
"ClientID": "",
"WarningCode": "True",
"WarningText": ""
}
}
]
}
Example 3 - Mapping with Multiple Parameters:
{
"offset": 277470,
"output_actions": [
{
"action": "CrossSwitch OpCon -> Matrix",
"parameters": {
"SwitchMode": "True",
"VideoOutput": "None",
"ClientID": "None",
"WarningCode": "True",
"WarningText": "None"
}
},
{
"action": "Warning: demo mode finished",
"parameters": {
"SwitchMode": "True",
"VideoOutput": "None",
"ClientID": "None",
"WarningCode": "True",
"WarningText": "None"
}
}
]
}
Technical Challenges Solved
Challenge 1: Binary Data Structure
Problem: Action mappings stored in proprietary binary format with no documentation.
Solution:
- Manual byte-by-byte analysis of .set file
- Identified property pattern:
01 <length> <name> <value> - Identified action pattern:
07 01 40 <length> <action_string> - Discovered properties start with '.' prefix
Challenge 2: Marker Name Contains Data
Problem: The "ules" marker name field contains the entire action mapping structure (properties + actions), not just a simple name.
Solution:
- Changed approach from parsing AFTER marker to parsing marker NAME bytes
- Created buffer with marker name + 200 extra bytes to handle overflow
- Used raw byte arrays instead of string conversion
Challenge 3: UTF-8 Encoding Corruption
Problem: Converting marker name to UTF-8 string and back corrupted binary data.
Solution:
- Use
Array.Copy()to extract raw bytes directly from original data - Avoid round-trip through UTF-8 encoding/decoding
- Preserve binary patterns like 0x00, 0x01, 0x07, 0x40
Challenge 4: Data Extends Beyond Marker
Problem: Action data can extend beyond the marker name field boundary.
Solution:
- Create buffer of
nameLen + 200bytes instead of justnameLen - Track bytes consumed during parsing
- Update position in original data stream accordingly
Current Limitations
1. Input vs Output Actions
Status: Cannot distinguish from binary format
Current Approach: All actions placed in output_actions
Reason: The binary format doesn't have a clear indicator separating input (trigger/condition) actions from output (response) actions.
Future Work: May need to:
- Analyze action naming patterns
- Use GeViSoft documentation to classify actions
- Allow user to specify which are input vs output
2. Parameter-Action Association
Status: All parameters associated with all actions in a mapping
Current Approach: Each action gets a copy of all parameters
Reason: Parameters are stored at mapping level, not per-action level in the binary format.
Note: This may be correct behavior - parameters might apply to the entire mapping, not individual actions.
API Endpoints
Read Action Mappings
Endpoint: GET /api/v1/configuration/action-mappings/export
Authentication: Bearer token (username: admin, password: admin123)
Response Format:
{
"total_count": 51,
"action_mappings": [
{
"id": 1,
"offset": 253894,
"input_actions": [],
"output_actions": [
{
"action": "GSC ViewerConnectLive V <- C",
"parameters": {}
}
]
}
]
}
Files Modified
Protobuf
configuration.proto- Added ActionParameter, ActionDefinition messages
C# SDK Bridge
ComprehensiveConfigParser.cs- Enhanced ParseRulesSection to extract properties and actionsSelectiveConfigParser.cs- Enhanced ParseRulesSection (same logic)ConfigurationServiceImplementation.cs- Populate output_actions with parameters
Python API
protos/configuration_pb2.py- Regenerated from protoprotos/configuration_pb2_grpc.py- Regenerated from proto (fixed imports)
Testing
Test File: test_structured_format.py
Results:
- ✓ 51 total action mappings extracted
- ✓ 11 mappings with parameters
- ✓ Properties correctly extracted (boolean, null values)
- ✓ Actions correctly extracted
- ✓ Backward compatibility maintained (old
actionsfield still populated)
Next Steps (Optional Enhancements)
-
Distinguish Input/Output Actions
- Analyze action naming conventions
- Add classification rules
- Allow manual specification via API
-
Per-Action Parameters
- Investigate if binary format supports per-action parameters
- If not, document that parameters apply to entire mapping
-
Mapping Name Extraction
- Currently returns marker name with binary data
- Could extract clean name from first action or parameters
-
Add/Edit/Delete Operations
- Implement creation of new action mappings
- Support modifying existing mappings
- Support deleting mappings
-
Python API Endpoint Updates
- Update
/api/v1/configuration/action-mappings/exportto return structured format - Add filtering by parameters
- Add search by action name
- Update
Conclusion
Successfully implemented structured action mapping extraction with full parameter support. The system now provides:
- Hierarchical structure - Actions with parameters
- Backward compatibility - Old format still works
- Extensibility - Ready for input/output classification
- Real data - Tested with actual GeViSoft configuration
All 5 tasks completed successfully! 🎉