Files
LEDMatrix/docs
Chuck 441b3c56e9 fix(starlark): code review fixes - security, robustness, and schema parsing
## Security Fixes
- manager.py: Check _update_manifest_safe return values to prevent silent failures
- manager.py: Improve temp file cleanup in _save_manifest to prevent leaks
- manager.py: Fix uninstall order (manifest → memory → disk) for consistency
- api_v3.py: Add path traversal validation in uninstall endpoint
- api_v3.py: Implement atomic writes for manifest files with temp + rename
- pixlet_renderer.py: Relax config validation to only block dangerous shell metacharacters

## Frontend Robustness
- plugins_manager.js: Add safeLocalStorage wrapper for restricted contexts (private browsing)
- starlark_config.html: Scope querySelector to container to prevent modal conflicts

## Schema Parsing Improvements
- pixlet_renderer.py: Indentation-aware get_schema() extraction (handles nested functions)
- pixlet_renderer.py: Handle quoted defaults with commas (e.g., "New York, NY")
- tronbyte_repository.py: Validate file_name is string before path traversal checks

## Dependencies
- requirements.txt: Update Pillow (10.4.0), PyYAML (6.0.2), requests (2.32.0)

## Documentation
- docs/STARLARK_APPS_GUIDE.md: Comprehensive guide explaining:
  - How Starlark apps work
  - That apps come from Tronbyte (not LEDMatrix)
  - Installation, configuration, troubleshooting
  - Links to upstream projects

All changes improve security, reliability, and user experience.

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-19 16:58:22 -05:00
..
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00
2025-12-27 14:15:49 -05:00

LEDMatrix Documentation

Welcome to the LEDMatrix documentation! This directory contains comprehensive guides, specifications, and reference materials for the LEDMatrix project.

📚 Documentation Overview

This documentation has been recently consolidated (January 2026) to reduce redundancy while maintaining comprehensive coverage. We've reduced from 51 main documents to 16-17 well-organized files (~68% reduction) by merging duplicates, archiving ephemeral content, and unifying writing styles.

📖 Quick Start

For New Users

  1. Installation: Follow the main README.md in the project root
  2. First Setup: See GETTING_STARTED.md for first-time setup guide
  3. Web Interface: Use WEB_INTERFACE_GUIDE.md to learn the control panel
  4. Troubleshooting: Check TROUBLESHOOTING.md for common issues

For Developers

  1. Plugin Development: See PLUGIN_DEVELOPMENT_GUIDE.md for complete guide
  2. Advanced Patterns: Read ADVANCED_PLUGIN_DEVELOPMENT.md for advanced techniques
  3. API Reference: Check PLUGIN_API_REFERENCE.md for available methods
  4. Configuration: See PLUGIN_CONFIGURATION_GUIDE.md for config schemas

For API Integration

  1. REST API: See REST_API_REFERENCE.md for all web interface endpoints
  2. Plugin API: See PLUGIN_API_REFERENCE.md for plugin developer APIs
  3. Developer Reference: See DEVELOPER_QUICK_REFERENCE.md for common tasks

📋 Documentation Categories

🚀 Getting Started & User Guides

Advanced Features

  • ADVANCED_FEATURES.md - Vegas scroll mode, on-demand display, cache management, background services, permissions

🔌 Plugin Development

🏗️ Plugin Features & Extensions

📡 API Reference

🏛️ Architecture & Design

🛠️ Development & Tools

🔄 Migration & Updates

📚 Miscellaneous

🎯 Key Resources by Use Case

I'm new to LEDMatrix

  1. GETTING_STARTED.md - Start here for first-time setup
  2. WEB_INTERFACE_GUIDE.md - Learn the control panel
  3. PLUGIN_STORE_GUIDE.md - Install plugins

I want to create a plugin

  1. PLUGIN_DEVELOPMENT_GUIDE.md - Complete development guide
  2. PLUGIN_API_REFERENCE.md - Available methods and APIs
  3. ADVANCED_PLUGIN_DEVELOPMENT.md - Advanced patterns
  4. PLUGIN_CONFIGURATION_GUIDE.md - Configuration setup
  5. PLUGIN_ARCHITECTURE_SPEC.md - Complete specification

I need to troubleshoot an issue

  1. TROUBLESHOOTING.md - Comprehensive troubleshooting guide
  2. WIFI_NETWORK_SETUP.md - WiFi/network issues
  3. PLUGIN_DEPENDENCY_TROUBLESHOOTING.md - Dependency issues

I want to use advanced features

  1. ADVANCED_FEATURES.md - Vegas scroll, on-demand display, background services
  2. FONT_MANAGER.md - Font management
  3. REST_API_REFERENCE.md - API integration

I want to understand the architecture

  1. PLUGIN_ARCHITECTURE_SPEC.md - System architecture
  2. PLUGIN_CONFIG_ARCHITECTURE.md - Configuration architecture
  3. PLUGIN_IMPLEMENTATION_SUMMARY.md - Implementation details

🔄 Recent Consolidations (January 2026)

Major Consolidation Effort

  • Before: 51 main documentation files
  • After: 16-17 well-organized files
  • Reduction: ~68% fewer files
  • Archived: 33 files (consolidated sources + ephemeral docs)

New Consolidated Guides

  • GETTING_STARTED.md - New first-time user guide
  • WEB_INTERFACE_GUIDE.md - Consolidated web interface documentation
  • WIFI_NETWORK_SETUP.md - Consolidated WiFi setup (5 files → 1)
  • PLUGIN_STORE_GUIDE.md - Consolidated plugin store guides (2 files → 1)
  • TROUBLESHOOTING.md - Consolidated troubleshooting (4 files → 1)
  • ADVANCED_FEATURES.md - Consolidated advanced features (6 files → 1)

What Was Archived

  • Ephemeral debug documents (DEBUG_WEB_ISSUE.md, BROWSER_ERRORS_EXPLANATION.md, etc.)
  • Implementation summaries (PLUGIN_CONFIG_TABS_SUMMARY.md, STARTUP_OPTIMIZATION_SUMMARY.md, etc.)
  • Consolidated source files (WIFI_SETUP.md, V3_INTERFACE_README.md, etc.)
  • Testing documentation (CAPTIVE_PORTAL_TESTING.md, etc.)

All archived files are preserved in docs/archive/ with full git history.

Benefits

  • Easier to find information (fewer files to search)
  • No duplicate content
  • Consistent writing style (professional technical)
  • Updated outdated references
  • Fixed broken internal links
  • Better organization for users vs developers

📝 Contributing to Documentation

Documentation Standards

  • Use Markdown format with consistent headers
  • Professional technical writing style
  • Minimal emojis (1-2 per major section for navigation)
  • Include code examples where helpful
  • Provide both quick start and detailed reference sections
  • Cross-reference related documentation

Adding New Documentation

  1. Consider if content should be added to existing docs first
  2. Place in appropriate category (see sections above)
  3. Update this README.md with the new document
  4. Follow naming conventions (FEATURE_NAME.md)
  5. Use consistent formatting and voice

Consolidation Guidelines

  • User Guides: Consolidate by topic (WiFi, troubleshooting, etc.)
  • Developer Guides: Keep development vs reference vs architecture separate
  • Debug Documents: Archive after issues are resolved
  • Implementation Summaries: Archive completed implementation details
  • Ephemeral Content: Archive, don't keep in main docs

📊 Documentation Statistics

  • Main Documents: 16-17 files (after consolidation)
  • Archived Documents: 33 files (in docs/archive/)
  • Categories: 9 major sections
  • Primary Language: English
  • Format: Markdown (.md)
  • Last Major Update: January 2026
  • Coverage: Installation, user guides, development, troubleshooting, architecture, API references

Documentation Highlights

  • Comprehensive user guides for first-time setup
  • Complete REST API documentation (71+ endpoints)
  • Complete Plugin API reference (Display Manager, Cache Manager, Plugin Manager)
  • Advanced plugin development guide with examples
  • Consolidated configuration documentation
  • Professional technical writing throughout
  • ~68% reduction in file count while maintaining coverage

This documentation index was last updated: January 2026

For questions or suggestions about the documentation, please open an issue or start a discussion on GitHub.