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>
149 lines
4.7 KiB
PowerShell
149 lines
4.7 KiB
PowerShell
#!/usr/bin/env pwsh
|
|
|
|
# Consolidated prerequisite checking script (PowerShell)
|
|
#
|
|
# This script provides unified prerequisite checking for Spec-Driven Development workflow.
|
|
# It replaces the functionality previously spread across multiple scripts.
|
|
#
|
|
# Usage: ./check-prerequisites.ps1 [OPTIONS]
|
|
#
|
|
# OPTIONS:
|
|
# -Json Output in JSON format
|
|
# -RequireTasks Require tasks.md to exist (for implementation phase)
|
|
# -IncludeTasks Include tasks.md in AVAILABLE_DOCS list
|
|
# -PathsOnly Only output path variables (no validation)
|
|
# -Help, -h Show help message
|
|
|
|
[CmdletBinding()]
|
|
param(
|
|
[switch]$Json,
|
|
[switch]$RequireTasks,
|
|
[switch]$IncludeTasks,
|
|
[switch]$PathsOnly,
|
|
[switch]$Help
|
|
)
|
|
|
|
$ErrorActionPreference = 'Stop'
|
|
|
|
# Show help if requested
|
|
if ($Help) {
|
|
Write-Output @"
|
|
Usage: check-prerequisites.ps1 [OPTIONS]
|
|
|
|
Consolidated prerequisite checking for Spec-Driven Development workflow.
|
|
|
|
OPTIONS:
|
|
-Json Output in JSON format
|
|
-RequireTasks Require tasks.md to exist (for implementation phase)
|
|
-IncludeTasks Include tasks.md in AVAILABLE_DOCS list
|
|
-PathsOnly Only output path variables (no prerequisite validation)
|
|
-Help, -h Show this help message
|
|
|
|
EXAMPLES:
|
|
# Check task prerequisites (plan.md required)
|
|
.\check-prerequisites.ps1 -Json
|
|
|
|
# Check implementation prerequisites (plan.md + tasks.md required)
|
|
.\check-prerequisites.ps1 -Json -RequireTasks -IncludeTasks
|
|
|
|
# Get feature paths only (no validation)
|
|
.\check-prerequisites.ps1 -PathsOnly
|
|
|
|
"@
|
|
exit 0
|
|
}
|
|
|
|
# Source common functions
|
|
. "$PSScriptRoot/common.ps1"
|
|
|
|
# Get feature paths and validate branch
|
|
$paths = Get-FeaturePathsEnv
|
|
|
|
if (-not (Test-FeatureBranch -Branch $paths.CURRENT_BRANCH -HasGit:$paths.HAS_GIT)) {
|
|
exit 1
|
|
}
|
|
|
|
# If paths-only mode, output paths and exit (support combined -Json -PathsOnly)
|
|
if ($PathsOnly) {
|
|
if ($Json) {
|
|
[PSCustomObject]@{
|
|
REPO_ROOT = $paths.REPO_ROOT
|
|
BRANCH = $paths.CURRENT_BRANCH
|
|
FEATURE_DIR = $paths.FEATURE_DIR
|
|
FEATURE_SPEC = $paths.FEATURE_SPEC
|
|
IMPL_PLAN = $paths.IMPL_PLAN
|
|
TASKS = $paths.TASKS
|
|
} | ConvertTo-Json -Compress
|
|
} else {
|
|
Write-Output "REPO_ROOT: $($paths.REPO_ROOT)"
|
|
Write-Output "BRANCH: $($paths.CURRENT_BRANCH)"
|
|
Write-Output "FEATURE_DIR: $($paths.FEATURE_DIR)"
|
|
Write-Output "FEATURE_SPEC: $($paths.FEATURE_SPEC)"
|
|
Write-Output "IMPL_PLAN: $($paths.IMPL_PLAN)"
|
|
Write-Output "TASKS: $($paths.TASKS)"
|
|
}
|
|
exit 0
|
|
}
|
|
|
|
# Validate required directories and files
|
|
if (-not (Test-Path $paths.FEATURE_DIR -PathType Container)) {
|
|
Write-Output "ERROR: Feature directory not found: $($paths.FEATURE_DIR)"
|
|
Write-Output "Run /speckit.specify first to create the feature structure."
|
|
exit 1
|
|
}
|
|
|
|
if (-not (Test-Path $paths.IMPL_PLAN -PathType Leaf)) {
|
|
Write-Output "ERROR: plan.md not found in $($paths.FEATURE_DIR)"
|
|
Write-Output "Run /speckit.plan first to create the implementation plan."
|
|
exit 1
|
|
}
|
|
|
|
# Check for tasks.md if required
|
|
if ($RequireTasks -and -not (Test-Path $paths.TASKS -PathType Leaf)) {
|
|
Write-Output "ERROR: tasks.md not found in $($paths.FEATURE_DIR)"
|
|
Write-Output "Run /speckit.tasks first to create the task list."
|
|
exit 1
|
|
}
|
|
|
|
# Build list of available documents
|
|
$docs = @()
|
|
|
|
# Always check these optional docs
|
|
if (Test-Path $paths.RESEARCH) { $docs += 'research.md' }
|
|
if (Test-Path $paths.DATA_MODEL) { $docs += 'data-model.md' }
|
|
|
|
# Check contracts directory (only if it exists and has files)
|
|
if ((Test-Path $paths.CONTRACTS_DIR) -and (Get-ChildItem -Path $paths.CONTRACTS_DIR -ErrorAction SilentlyContinue | Select-Object -First 1)) {
|
|
$docs += 'contracts/'
|
|
}
|
|
|
|
if (Test-Path $paths.QUICKSTART) { $docs += 'quickstart.md' }
|
|
|
|
# Include tasks.md if requested and it exists
|
|
if ($IncludeTasks -and (Test-Path $paths.TASKS)) {
|
|
$docs += 'tasks.md'
|
|
}
|
|
|
|
# Output results
|
|
if ($Json) {
|
|
# JSON output
|
|
[PSCustomObject]@{
|
|
FEATURE_DIR = $paths.FEATURE_DIR
|
|
AVAILABLE_DOCS = $docs
|
|
} | ConvertTo-Json -Compress
|
|
} else {
|
|
# Text output
|
|
Write-Output "FEATURE_DIR:$($paths.FEATURE_DIR)"
|
|
Write-Output "AVAILABLE_DOCS:"
|
|
|
|
# Show status of each potential document
|
|
Test-FileExists -Path $paths.RESEARCH -Description 'research.md' | Out-Null
|
|
Test-FileExists -Path $paths.DATA_MODEL -Description 'data-model.md' | Out-Null
|
|
Test-DirHasFiles -Path $paths.CONTRACTS_DIR -Description 'contracts/' | Out-Null
|
|
Test-FileExists -Path $paths.QUICKSTART -Description 'quickstart.md' | Out-Null
|
|
|
|
if ($IncludeTasks) {
|
|
Test-FileExists -Path $paths.TASKS -Description 'tasks.md' | Out-Null
|
|
}
|
|
}
|