Metadata-Version: 2.4
Name: smart-repository-manager-core
Version: 0.3.7
Summary: Smart Repository Manager Core - A Python library for managing Git repositories with intelligent synchronization, SSH configuration validation, and GitHub integration.
Author-email: Alexander Suvorov <smartlegiondev@gmail.com>
License-Expression: BSD-3-Clause
Project-URL: Homepage, https://github.com/smartlegionlab/smart-repository-manager-core
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Operating System :: OS Independent
Requires-Python: >=3.6
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: requests==2.32.5
Dynamic: license-file


# Smart Repository Manager Core <sup>v0.3.7</sup>

---

A Python library for managing Git repositories with intelligent synchronization and GitHub integration.

---

[![PyPI - Downloads](https://img.shields.io/pypi/dm/smart-repository-manager-core?label=pypi%20downloads)](https://pypi.org/project/smart-repository-manager-core/)
[![GitHub release (latest by date)](https://img.shields.io/github/v/release/smartlegionlab/smart-repository-manager-core)](https://github.com/smartlegionlab/smart-repository-manager-core/)
![GitHub top language](https://img.shields.io/github/languages/top/smartlegionlab/smart-repository-manager-core)
[![PyPI](https://img.shields.io/pypi/v/smart-repository-manager-core)](https://pypi.org/project/smart-repository-manager-core)
[![GitHub](https://img.shields.io/github/license/smartlegionlab/smart-repository-manager-core)](https://github.com/smartlegionlab/smart-repository-manager-core/blob/master/LICENSE)
[![PyPI - Format](https://img.shields.io/pypi/format/smart-repository-manager-core)](https://pypi.org/project/smart-repository-manager-core)
[![GitHub stars](https://img.shields.io/github/stars/smartlegionlab/smart-repository-manager-core?style=social)](https://github.com/smartlegionlab/smart-repository-manager-core/stargazers)
[![GitHub forks](https://img.shields.io/github/forks/smartlegionlab/smart-repository-manager-core?style=social)](https://github.com/smartlegionlab/smart-repository-manager-core/network/members)

---

## ⚠️ Disclaimer

**By using this software, you agree to the full disclaimer terms.**

**Summary:** Software provided "AS IS" without warranty. You assume all risks.

**Full legal disclaimer:** See [DISCLAIMER.md](https://github.com/smartlegionlab/smart-repository-manager-core/blob/master/DISCLAIMER.md)

---

## Important Change: HTTP Migration

**As of version 0.3.2, repository synchronization now uses HTTPS instead of SSH.**

This change was made to:
- Simplify authentication (uses GitHub tokens instead of SSH keys)
- Improve compatibility across different network environments
- Reduce configuration complexity for users

If you were using previous versions with SSH, please note:
- **Existing SSH configurations are preserved but no longer used for synchronization**
- You'll need a **GitHub token** for authentication (see [GitHub Integration](#github-integration))
- SSH-related features (key validation, configuration) are being phased out

## Features

- **Repository Management**: Clone, pull, parallel download and sync GitHub repositories with intelligent health checks
- **GitHub Integration**: Token authentication, repository listing, and metadata retrieval
- **User Management**: Multiple user profiles with GitHub token authentication
- **Network Diagnostics**: Comprehensive connectivity checks and network validation
- **Smart Synchronization**: Intelligent sync with auto-repair for broken repositories
- **Configuration Persistence**: User settings and repository state storage

## Installation

```bash
pip install smart-repository-manager-core
```

## Core Services

### Repository Management
- Clone repositories via HTTPS
- Pull updates with health verification
- Automatic repair of broken repositories
- Repository health diagnostics
- Create repository archives
- Parallel repository downloading

### GitHub Integration
- Token authentication and validation
- Repository listing and metadata
- Rate limit monitoring
- User profile management
- **HTTPS-based operations** (SSH no longer used)

### SSH Management
- **Legacy feature - being phased out**
- SSH key validation and permissions checking (maintained for backward compatibility)
- SSH connection testing (will be removed in future versions)
- **New projects should use HTTPS with tokens instead**

### Network Services
- Connectivity checks for GitHub and Git services
- DNS resolution testing
- Network diagnostics

### Configuration
- User profile management
- Application settings persistence
- Multi-user support
- Token storage

## Requirements

- Python 3.6+
- Git installed and available in PATH
- GitHub token for authentication (SSH keys no longer required)

## License

BSD 3-Clause License - See [LICENSE](LICENSE) file for details.

## Related Projects

This core library powers two complete implementations:

### [CLI Version](https://github.com/smartlegionlab/smart-repository-manager-cli) 
A full-featured command-line interface built on top of this core library. Provides terminal-based repository management with all features accessible via commands.

### [GUI Version](https://github.com/smartlegionlab/smart-repository-manager-gui)  
A desktop graphical user interface that offers visual management of repositories and synchronization tasks. Built for users who prefer point-and-click interaction.

Both implementations use this core library as their engine, ensuring consistent behavior and feature parity across interfaces.

---

## Development Status

**Active Development** - This project is under active development. Features may change, and stability is not guaranteed. Not recommended for production use without thorough testing.

## Migration Notes

If you're upgrading from a version prior to 0.3.2:

1. **Obtain a GitHub token** from your GitHub account settings
2. **Update your user profile** with the new token
3. **Existing repositories** will automatically use HTTPS for future operations
4. **SSH configurations** are preserved but will be ignored for sync operations

## Contributing

Currently not accepting contributions as the project is in early development phase.

## Support

For issues and questions, please check the GitHub repository:  
[https://github.com/smartlegionlab/smart-repository-manager-core](https://github.com/smartlegionlab/smart-repository-manager-core)

---

**Developer**: [Alexander Suvorov](https://github.com/smartlegionlab/)
**Contact**: [smartlegiondev@gmail.com](mailto:smartlegiondev@gmail.com)
