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>
281 lines
8.1 KiB
Markdown
281 lines
8.1 KiB
Markdown
# 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:
|
|
```protobuf
|
|
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:**
|
|
1. Identify "ules" markers (action mappings)
|
|
2. Extract marker name bytes + 200 following bytes
|
|
3. Parse properties: `01 <length> <name> <value>`
|
|
4. Parse actions: `07 01 40 <length> <action_string>`
|
|
5. Store properties as children nodes
|
|
6. Store actions as value list
|
|
|
|
### 3. gRPC Service Implementation ✓
|
|
**File:** `ConfigurationServiceImplementation.cs`
|
|
|
|
Updated `ReadActionMappings` to:
|
|
- Extract properties from `ConfigNode.Children`
|
|
- Convert properties to `ActionParameter` protobuf messages
|
|
- Create `ActionDefinition` objects with action + parameters
|
|
- Populate `output_actions` field (all actions treated as output for now)
|
|
- Maintain backward compatibility with old `actions` field
|
|
|
|
### 4. Results
|
|
|
|
**Total Action Mappings Found:** 51
|
|
**Mappings with Parameters:** 11
|
|
|
|
**Example 1 - Simple Mapping (no parameters):**
|
|
```json
|
|
{
|
|
"offset": 253894,
|
|
"output_actions": [
|
|
{
|
|
"action": "GSC ViewerConnectLive V <- C",
|
|
"parameters": {}
|
|
},
|
|
{
|
|
"action": "GNG ViewerConnectLive V <- C_101027",
|
|
"parameters": {}
|
|
}
|
|
]
|
|
}
|
|
```
|
|
|
|
**Example 2 - Complex Mapping (with parameters):**
|
|
```json
|
|
{
|
|
"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:**
|
|
```json
|
|
{
|
|
"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 + 200` bytes instead of just `nameLen`
|
|
- 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:**
|
|
```json
|
|
{
|
|
"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 actions
|
|
- `SelectiveConfigParser.cs` - Enhanced ParseRulesSection (same logic)
|
|
- `ConfigurationServiceImplementation.cs` - Populate output_actions with parameters
|
|
|
|
### Python API
|
|
- `protos/configuration_pb2.py` - Regenerated from proto
|
|
- `protos/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 `actions` field still populated)
|
|
|
|
## Next Steps (Optional Enhancements)
|
|
|
|
1. **Distinguish Input/Output Actions**
|
|
- Analyze action naming conventions
|
|
- Add classification rules
|
|
- Allow manual specification via API
|
|
|
|
2. **Per-Action Parameters**
|
|
- Investigate if binary format supports per-action parameters
|
|
- If not, document that parameters apply to entire mapping
|
|
|
|
3. **Mapping Name Extraction**
|
|
- Currently returns marker name with binary data
|
|
- Could extract clean name from first action or parameters
|
|
|
|
4. **Add/Edit/Delete Operations**
|
|
- Implement creation of new action mappings
|
|
- Support modifying existing mappings
|
|
- Support deleting mappings
|
|
|
|
5. **Python API Endpoint Updates**
|
|
- Update `/api/v1/configuration/action-mappings/export` to return structured format
|
|
- Add filtering by parameters
|
|
- Add search by action name
|
|
|
|
## 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! 🎉
|