Mathis HERRIOT edc1ab2438
Some checks failed
Lint / lint (backend) (push) Failing after 2m22s
Backend Tests / test (push) Successful in 2m47s
Lint / lint (documentation) (push) Successful in 1m11s
Lint / lint (frontend) (push) Successful in 1m9s
feat(logging): introduce HTTP logging middleware
Add middleware to log HTTP request and response details, including method, URL, status, duration, user agent, and hashed IP address. Logs categorized by severity based on response status code.
2026-01-20 09:45:06 +01:00
2026-01-03 14:42:48 +01:00

🐐 Memegoat

Memegoat est une plateforme moderne de partage et de création de mèmes, conçue avec une architecture robuste et sécurisée.

Ce dépôt est en cours de développement. Nous intégrons actuellement les fonctionnalités clés dans le monorepo. Il n'est pas encore totalement prêt pour un déploiement auto-hébergé simplifié, mais vous pouvez le lancer localement.

Qu'est-ce que Memegoat ?

Memegoat est votre destination ultime pour découvrir, créer et partager les meilleurs mèmes du web. Notre plateforme se concentre sur la performance, la sécurité des données et une expérience utilisateur fluide.

Retrouvez notre documentation complète sur : docs.memegoat.fr

Architecture & Stack Technique

Le projet est structuré en monorepo :

  • Frontend : Next.js avec Tailwind CSS et Shadcn/ui.
  • Backend : NestJS (TypeScript) avec PostgreSQL.
  • Base de données : Drizzle ORM avec chiffrement natif PGP pour les données sensibles.
  • Infrastructure : Docker, Caddy (Reverse Proxy & TLS), stockage compatible S3.

Documentation Rapide

Pour approfondir vos connaissances techniques sur le projet :

Comment l'utiliser ?

Installation locale

  1. Clonez le dépôt.
  2. Installez les dépendances avec pnpm install.
  3. Configurez les variables d'environnement (voir .env.example).
  4. Lancez les services via Docker ou manuellement.

Clés API

Pour utiliser l'API, vous pouvez générer des clés API sécurisées directement depuis votre profil sur memegoat.fr.

Fonctionnalités Clés

  • Sécurité Avancée : Chiffrement des données personnelles au repos et hachage aveugle pour la recherche.
  • RGPD by Design : Mécanismes de Soft Delete, purge automatique et hachage des IPs.
  • Multi-Authentification : Support des sessions JWT, des clés API et de la double authentification (2FA).
  • Gestion de Contenu : Support des mèmes et GIFs avec système de tags et signalements.
  • Traitement Médias Sécurisé : Scan antivirus (ClamAV) systématique et transcodage haute performance (WebP, WebM, AVIF, AV1).

Contribution

Les contributions sont les bienvenues ! Veuillez consulter notre guide de contribution avant de soumettre une pull request.

Licence

Ce projet est principalement sous licence GNU Affero General Public License v3.0 (AGPL-3.0). Certains composants, comme les SDKs, peuvent être sous licence MIT. Veuillez vous référer aux fichiers LICENSE dans les répertoires respectifs pour plus de détails.

↑ Retour en haut ↑

Description
No description provided
Readme AGPL-3.0 4.8 MiB
Languages
TypeScript 94.8%
PowerShell 1.5%
Shell 1.4%
CSS 1.1%
CMake 0.8%
Other 0.4%