Audit and support tools for Pristy ECM installations
Project description
Pristy Support
Audit and support tools for Pristy ECM installations.
Overview
Pristy Support is a command-line tool designed to help support teams diagnose and audit Pristy installations. It performs comprehensive checks on system resources, services, logs, database statistics, and configuration files, generating detailed reports in multiple formats.
Features
System Checks
- ✅ Systemd services status (enabled/active)
- ✅ Docker containers health
- ✅ Memory configuration and limits validation
- ✅ Swap presence and size
- ✅ Firewall status detection
- ✅ Disk space monitoring
- ✅ System load analysis
Logs Analysis
- 🔍 Journalctl log analysis for all Pristy services
- 🔍 Error and warning detection
- 🔍 Log severity aggregation
- 🔍 Common error pattern extraction
Database Statistics
- 📊 Node, property, and aspect counts
- 📊 User and group statistics
- 📊 Content statistics
- 📊 Database and table sizes
- 📊 Useful ratios (properties/node, aspects/node)
Configuration Review
- 📄 Alfresco global.properties analysis
- 📄 Pristy Vue.js application configurations
- 📄 Key parameter extraction
- 📄 Configuration issue detection
Export Formats
- 📝 Markdown: Clean text reports
- 🌐 HTML: Styled, navigable reports
- 📦 ZIP: Complete archives with all data and reports
Installation
From Source
- with uv
cd pristy-support
uv venv
uv pip install .
- without uv
cd pristy-support
python3 -m venv .venv
source .venv/bin/activate
pip install .
For Development
cd pristy-support
pip install -e .
For Client Deployment
Once published to a package index:
pip install pristy-support
Configuration
Pristy Support can be customized via YAML configuration files. The tool looks for configuration in these locations (in order of priority):
- Custom path specified with
--configoption ./pristy-support.yml(current directory)./.pristy-support.yml(current directory, hidden)~/.pristy-support.yml(user home directory)~/.config/pristy-support/config.yml(XDG config directory)/etc/pristy/pristy-support.yml(system-wide configuration)
Generate Default Configuration
Create a configuration file with all default values:
pristy-support init-config
This creates pristy-support.yml in the current directory. You can specify a custom output path:
pristy-support init-config --output /path/to/config.yml
Configuration Options
The configuration file allows you to customize:
- System: Services to check, memory thresholds, disk space thresholds
- Docker: Container name patterns to monitor
- Logs: Services to analyze, time periods, severity keywords, max samples per severity
- Database: PostgreSQL connection parameters
- Config Paths: Paths for Alfresco and Pristy application configurations
- Audit: Default export formats and output directory
Example configuration snippet:
system:
services:
- postgres
- kafka
- alfresco
memory:
min_ram_gb: 8
recommended_ram_gb: 12
min_swap_gb: 2
disk_thresholds:
/: 10
/var/lib/docker: 30
logs:
services:
- alfresco
- solr6
default_since: 7d
max_samples_per_severity: 10
severity_keywords:
critical: [CRITICAL, FATAL]
error: [ERROR]
warning: [WARN, WARNING]
Using Custom Configuration
pristy-support --config /path/to/config.yml audit
Usage
Full Audit
Run a complete audit of your Pristy installation:
pristy-support audit
This will generate reports in the current directory in all formats (Markdown, HTML, and ZIP).
Options
pristy-support audit --output-dir /path/to/output --formats md,html,zip --since 30d
--output-dir,-o: Output directory for reports (default: current directory)--formats,-f: Export formats, comma-separated (default:md,html,zip)--since,-s: Time period for log analysis (default:7d)
Examples:
--since 24h: Last 24 hours--since 7d: Last 7 days (default)--since 30d: Last 30 days
Individual Checks
Run specific checks independently:
System Checks Only
pristy-support system-check
Logs Analysis Only
pristy-support logs-check --since 7d
Database Statistics Only
pristy-support database-check
Configuration Review Only
pristy-support config-check
Version
pristy-support --version
Help
pristy-support --help
pristy-support audit --help
Debug Mode
Enable debug mode to see all commands executed by the tool:
pristy-support --debug audit
Debug mode displays:
- All system commands before execution (systemctl, journalctl, docker, etc.)
- Command results (success/failure with exit codes)
- Docker exec operations with container names
- File read/write operations
Example output:
DEBUG [pristy_support] 🔧 Checking systemctl availability
DEBUG [pristy_support] $ systemctl --version
DEBUG [pristy_support] ✓ Command succeeded (exit code: 0)
DEBUG [pristy_support] 🔧 Listing Docker containers
DEBUG [pristy_support] $ docker ps --format {{.ID}}|{{.Names}}|{{.Status}}|{{.Image}} -a
DEBUG [pristy_support] ✓ Command succeeded (exit code: 0)
DEBUG [pristy_support] 🐳 Executing in container 'postgres':
DEBUG [pristy_support] $ psql -U alfresco -d alfresco -t -A -c SELECT COUNT(*) FROM alf_node;
This is useful for:
- Troubleshooting issues
- Understanding what the tool is doing
- Debugging permission problems
- Support and diagnostics
Requirements
System Requirements
- Python 3.9 or higher
- Linux operating system (systemd-based)
- Docker (for container checks and PostgreSQL access)
Permissions
The tool automatically detects available permissions and adapts its checks accordingly:
- Root/sudo: Full access to all checks
- Docker group: Access to Docker commands
- Standard user: Limited checks (may miss some system information)
For best results, run with sudo or as root:
sudo pristy-support audit
Pristy Installation
The tool expects a standard Pristy installation with:
- Systemd services for Pristy components
- Docker containers running Pristy services
- PostgreSQL database in a Docker container named
postgres - Configuration files in standard locations:
/opt/alfresco/tomcat/shared/classes/alfresco-global.properties/opt/pristy-*/public/env-config.json
Architecture
Project Structure
pristy-support/
├── pristy_support/
│ ├── __init__.py
│ ├── __main__.py # Entry point for python -m pristy_support
│ ├── cli.py # CLI interface (Click)
│ ├── modules/ # Audit modules
│ │ ├── system.py # System checks
│ │ ├── logs.py # Log analysis
│ │ ├── database.py # Database statistics
│ │ └── config.py # Configuration review
│ ├── exporters/ # Report exporters
│ │ ├── markdown.py # Markdown exporter
│ │ ├── html.py # HTML exporter
│ │ └── zip_exporter.py # ZIP archive exporter
│ ├── utils/ # Utilities
│ │ ├── permissions.py # Permission detection
│ │ ├── docker_utils.py # Docker utilities
│ │ └── logger.py # Debug logging
│ └── templates/ # HTML templates
│ └── report.html.j2
├── tests/ # Unit tests
├── setup.py # Package setup
├── pyproject.toml # Modern packaging metadata
├── requirements.txt # Dependencies
├── README.md # This file
└── LICENSE # AGPL-3.0 license
Modules
System Module (system.py)
Checks system resources and services:
- Systemd service status
- Docker container health
- Memory and swap configuration
- Disk space availability
- System load
Logs Module (logs.py)
Analyzes system logs via journalctl:
- Searches for ERROR, WARN, FATAL keywords
- Aggregates by service and severity
- Extracts common error patterns
Database Module (database.py)
Collects PostgreSQL statistics:
- Executes queries via
docker execon postgres container - Counts nodes, properties, aspects, users, groups
- Calculates useful ratios
- Reports database and table sizes
Config Module (config.py)
Reviews configuration files:
- Parses alfresco-global.properties
- Reads Vue.js env-config.json files
- Validates key parameters
- Detects configuration issues
Exporters
Markdown Exporter
Generates clean, readable text reports with tables.
HTML Exporter
Creates styled HTML reports with:
- Responsive layout
- Color-coded status badges
- Sortable tables
- Metrics cards
ZIP Exporter
Bundles all reports and raw data:
- Markdown report
- HTML report
- Raw JSON data
- Individual module data files
Development
Setup Development Environment
git clone https://gitlab.com/pristy-oss/pristy-support.git
cd pristy-support
pip install -e ".[dev]"
Run Tests
pytest
Code Formatting
black pristy_support/
Type Checking
mypy pristy_support/
Contributing
Contributions are welcome! Please follow these guidelines:
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature) - Commit your changes using conventional commits
- Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
Code Style
- Follow PEP 8 guidelines
- Use Black for code formatting (line length: 100)
- Add type hints where possible
- Write docstrings for all functions and classes
- All code comments in English
Commit Messages
Use conventional commits format:
feat(module): add new featurefix(logs): correct error detectiondocs(readme): update installation instructionsrefactor(system): improve memory check logic
License
This project is licensed under the GNU Affero General Public License v3.0 or later (AGPL-3.0-or-later).
See LICENSE file for details.
Authors
- JECI SARL - https://www.jeci.fr
- PRISTY - https://www.pristy.fr
Support
For issues, questions, or contributions:
- GitHub Issues: [https://gitlab.com/pristy-oss/pristy-support/-/issues)
Changelog
Version 1.0.0 (2025-01-XX)
Initial release:
- System checks (services, containers, memory, disk, load)
- Logs analysis with error detection
- Database statistics collection
- Configuration review
- Multiple export formats (Markdown, HTML, ZIP)
- Automatic permission detection
- CLI interface with Click
- Debug mode with command tracing
- YAML configuration system with customizable parameters
init-configcommand to generate default configuration
Roadmap
Future enhancements:
- Interactive mode for detailed investigation
- Automated issue remediation suggestions
- Integration with monitoring systems (Prometheus, Grafana)
- Performance benchmarking
- Historical trend analysis
- Multi-server support for clustered installations
- Email report delivery
- Scheduled audit execution
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pristy_support-1.0.0.tar.gz.
File metadata
- Download URL: pristy_support-1.0.0.tar.gz
- Upload date:
- Size: 42.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.1 CPython/3.13.7 Linux/6.16.12-200.fc42.x86_64
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
555b0434fa891dfac1e9bfce54b36d5794e8d9206ffd79a8a7ca580289f39448
|
|
| MD5 |
7a83a901bc6e1b992f5515aca56cc9ae
|
|
| BLAKE2b-256 |
802fcacde134e592449af4772d8f165da5a86148ab29fdc6c79c37d0b6113477
|
File details
Details for the file pristy_support-1.0.0-py3-none-any.whl.
File metadata
- Download URL: pristy_support-1.0.0-py3-none-any.whl
- Upload date:
- Size: 52.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.1 CPython/3.13.7 Linux/6.16.12-200.fc42.x86_64
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ccbedd3a65259f38fd22035d3181d61e82d407b4cfc215948f68fe5982621253
|
|
| MD5 |
fd30d6230e99bf271a007aeab4aebbe1
|
|
| BLAKE2b-256 |
4ac6d95441a6854cca6233c1e27f8dac55c12a109cfb8da354dd00d9876b4a0d
|