Skip to content

omgbwa-yasse/shelve

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

📚 Shelve - Système de Gestion d'Archives Intelligentes

Laravel 12 PHP 8.2+ MySQL 8.0+ Vue.js 3 AI Powered

Shelve est une plateforme complète de gestion d'archives modernes développée avec Laravel 12, intégrant l'intelligence artificielle pour automatiser et optimiser la gestion documentaire. Ce système offre une solution robuste pour l'archivage, la recherche intelligente, la gestion des workflows et la publication publique de documents.

🚀 Fonctionnalités Principales

📁 Gestion d'Archives Avancée

  • Gestion de documents : Upload, organisation et archivage automatisé
  • Support multi-formats : PDF, images, vidéos, documents Office
  • Générations de codes-barres : Traçabilité physique des documents
  • Conteneurs intelligents : Organisation hiérarchique des archives
  • Versioning automatique : Historique complet des modifications

🔍 Recherche Intelligente Intégrée

  • Recherche textuelle avancée avec TNTSearch
  • Recherche sémantique basée sur l'IA
  • Filtres multicritères : dates, auteurs, types, contenus
  • Thésaurus intégré : Recherche par concepts et relations
  • Indexation automatique des contenus

📧 Système de Courrier Électronique

  • Gestion complète des emails entrants et sortants
  • Workflows automatisés de traitement du courrier
  • Assignation et délégation de tâches
  • Suivi des deadlines et alertes automatiques
  • Archivage intelligent des correspondances

🤖 Intelligence Artificielle Intégrée

  • Extraction automatique de mots-clés et métadonnées
  • Analyse de contenu et classification automatique
  • Résumés automatiques de documents longs
  • Chat IA pour assistance utilisateur
  • Support multi-providers : Ollama, OpenAI, LM Studio, AnythingLLM

🌐 Portail Public

  • Publication sélective de documents publics
  • Interface de recherche pour le grand public
  • Système de demandes de documents
  • Gestion des feedbacks et commentaires
  • Chat public avec support IA

🔄 Workflows et Automatisation

  • Workflows configurables pour tous les processus
  • Assignation automatique de tâches
  • Escalade conditionnelle en cas de retard
  • Templates d'emails personnalisables
  • Notifications multi-canaux

📊 Thésaurus et Classification

  • Thésaurus normé SKOS intégré
  • Relations hiérarchiques et associatives
  • Import/Export au format SKOS, CSV, JSON
  • Gestion multilingue des concepts
  • API RESTful pour intégrations externes

🛠️ Technologies et Architecture

Framework Principal

  • Laravel 12.21.0 - Framework PHP moderne
  • PHP 8.2+ - Langage backend performant
  • MySQL 8.0+ - Base de données relationnelle

Frontend et Interface

  • Vue.js 3 - Interface utilisateur réactive
  • TailwindCSS - Framework CSS moderne
  • Intervention Image - Traitement d'images
  • PDF.js - Visualisation PDF intégrée

Intelligence Artificielle

  • Ollama - Modèles IA locaux
  • OpenAI API - GPT et modèles cloud
  • LM Studio - Modèles locaux personnalisés
  • AnythingLLM - Plateforme IA unifiée

Recherche et Indexation

  • TNTSearch - Moteur de recherche Laravel
  • Scout - Interface de recherche élégante
  • Elasticsearch (optionnel) - Recherche enterprise

Génération de Documents

  • DomPDF - Génération PDF
  • PHPWord - Documents Word
  • Maatwebsite Excel - Tableurs Excel
  • Codes-barres - Génération automatique

Intégrations et API

  • MCP (Model Context Protocol) - Serveur d'intégration IA
  • RESTful API complète
  • WebSockets - Notifications temps réel
  • Queue système - Traitement asynchrone

📋 Prérequis Système

- PHP >= 8.2
- MySQL >= 8.0 ou MariaDB >= 10.6
- Composer >= 2.0
- Node.js >= 18.0 et npm
- Extensions PHP : pdo, mbstring, openssl, tokenizer, xml, ctype, json, bcmath, fileinfo, gd
- Redis (optionnel, recommandé pour les performances)
- FFmpeg (pour le traitement vidéo)

🚀 Installation Rapide

1. Cloner le Repository

git clone https://github.com/yourusername/shelve.git
cd shelve

2. Installation des Dépendances

# Dépendances PHP
composer install

# Dépendances JavaScript
npm install && npm run build

3. Configuration de l'Environnement

# Copier le fichier d'environnement
cp .env.example .env

# Générer la clé d'application
php artisan key:generate

4. Configuration Base de Données

# Éditer .env avec vos paramètres
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=shelve_db
DB_USERNAME=root
DB_PASSWORD=your_password

5. Migration et Initialisation

# Créer la base de données
php artisan migrate

# Installer les données de base
php artisan db:seed

# Optimiser l'application
php artisan optimize

6. Démarrage du Serveur

# Serveur de développement
php artisan serve

# Queue worker (terminal séparé)
php artisan queue:work

👤 Comptes par Défaut

Après l'installation, vous pouvez vous connecter avec :

🔐 Superadministrateur
Email: superadmin@example.com
Mot de passe: superadmin
Permissions: Accès complet au système (125 permissions)

🔧 Configuration Avancée

Configuration IA (Optionnel)

# Ollama (recommandé pour usage local)
OLLAMA_BASE_URL=http://localhost:11434

# OpenAI (pour usage cloud)
OPENAI_API_KEY=your_openai_key

# LM Studio (modèles locaux personnalisés)
LMSTUDIO_BASE_URL=http://localhost:1234

Configuration Redis (Recommandé)

REDIS_HOST=127.0.0.1
REDIS_PASSWORD=null
REDIS_PORT=6379

CACHE_DRIVER=redis
SESSION_DRIVER=redis
QUEUE_CONNECTION=redis

Configuration Email

MAIL_MAILER=smtp
MAIL_HOST=your-smtp-host
MAIL_PORT=587
MAIL_USERNAME=your-email
MAIL_PASSWORD=your-password
MAIL_ENCRYPTION=tls

📖 Documentation Complète

Modules Principaux

Administration

Développement

🛠️ Scripts d'Optimisation

Le projet inclut des scripts d'optimisation prêts à l'emploi :

# Optimisation pour production
./optimize-production.sh     # Linux/Mac
optimize-production.bat      # Windows

# Basculement vers Redis
./switch-to-redis.bat        # Configuration Redis automatique

🧪 Tests et Qualité

# Tests unitaires et fonctionnels
php artisan test

# Analyse de code statique
./vendor/bin/phpstan analyse

# Formatage du code
./vendor/bin/php-cs-fixer fix

🔐 Sécurité

  • Authentification multi-niveaux avec Laravel Sanctum
  • Permissions granulaires par module et action
  • Chiffrement des données sensibles
  • Logs d'audit complets
  • Validation stricte des entrées utilisateur
  • Protection CSRF et XSS

📊 Performances

  • Cache intelligent avec Redis
  • Optimisation base de données avec indexation
  • Compression d'images automatique
  • Lazy loading des relations Eloquent
  • Queue système pour tâches lourdes
  • CDN ready pour assets statiques

🌍 Support Multilingue

  • Interface en français et anglais
  • Thésaurus multilingue avec traductions
  • Dates et formats localisés
  • Extensible pour autres langues

🤝 Contribution

Ce projet est développé par Omgbwa Yasse Emmanuel Fabrice et Njandjeu Lahakio David Andreas.

Pour contribuer :

  1. Fork le projet
  2. Créer une branche feature (git checkout -b feature/nouvelle-fonctionnalite)
  3. Commit vos changements (git commit -am 'Ajout nouvelle fonctionnalité')
  4. Push vers la branche (git push origin feature/nouvelle-fonctionnalite)
  5. Ouvrir une Pull Request

📝 Licence

Ce projet est sous licence MIT. Voir le fichier LICENSE pour plus de détails.

🆘 Support et Contact


Shelve - Révolutionnez votre gestion d'archives avec l'IA
Développé avec ❤️ en Laravel 12

About

Système intégré de gestion du courrier et des locaux d'archives

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •