{"id":38387801,"url":"https://github.com/devhoangkien/9plus-api","last_synced_at":"2026-01-17T03:45:38.154Z","repository":{"id":323597398,"uuid":"1061980141","full_name":"devhoangkien/9plus-api","owner":"devhoangkien","description":"9Plus CMS is a CMS backend platform based on microservice and plugin architecture, supporting flexible expansion, SSO integration, realtime search with Elasticsearch, event-driven with Kafka, and centralized logging via ELK stack.","archived":false,"fork":false,"pushed_at":"2026-01-12T14:49:49.000Z","size":999,"stargazers_count":2,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2026-01-12T21:26:03.985Z","etag":null,"topics":["cms","crm","erp","graphql","microservices","nestjs","prisma","rest-api"],"latest_commit_sha":null,"homepage":"","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/devhoangkien.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2025-09-22T16:34:41.000Z","updated_at":"2026-01-12T14:49:54.000Z","dependencies_parsed_at":null,"dependency_job_id":null,"html_url":"https://github.com/devhoangkien/9plus-api","commit_stats":null,"previous_names":["devhoangkien/9plus-api"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/devhoangkien/9plus-api","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/devhoangkien%2F9plus-api","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/devhoangkien%2F9plus-api/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/devhoangkien%2F9plus-api/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/devhoangkien%2F9plus-api/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/devhoangkien","download_url":"https://codeload.github.com/devhoangkien/9plus-api/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/devhoangkien%2F9plus-api/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28493674,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-17T02:39:23.645Z","status":"ssl_error","status_checked_at":"2026-01-17T02:34:19.649Z","response_time":85,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["cms","crm","erp","graphql","microservices","nestjs","prisma","rest-api"],"created_at":"2026-01-17T03:45:38.044Z","updated_at":"2026-01-17T03:45:38.140Z","avatar_url":"https://github.com/devhoangkien.png","language":"TypeScript","readme":"\u003cdiv align=\"center\"\u003e\n\n# 9Plus API\n\n**A scalable microservices-based CMS backend built with NestJS, GraphQL Federation, and event-driven architecture**\n\n[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)\n[![TypeScript](https://img.shields.io/badge/TypeScript-5.0-3178C6.svg)](https://www.typescriptlang.org/)\n[![NestJS](https://img.shields.io/badge/NestJS-10+-E0234E.svg)](https://nestjs.com/)\n\n[Features](#-key-features) • [Quick Start](#-quick-start) • [Documentation](#-documentation) • [Contributing](#-contributing)\n\n\u003c/div\u003e\n\n---\n\n## 📖 Overview\n\n9Plus API is a modular, production-ready CMS backend built with microservices architecture. It features GraphQL Federation, event-driven messaging with Kafka, full-text search with Elasticsearch, and a dynamic plugin system.\n\n### ✨ Key Features\n\n- 🏗️ **Microservices Architecture** - GraphQL Federation for service composition\n- 🔌 **Plugin System** - Extensible architecture with dynamic plugin loading\n- 🔐 **Authentication \u0026 Authorization** - JWT-based auth with CASL for RBAC\n- 🔍 **Full-Text Search** - Elasticsearch integration for fast search\n- 📊 **Event-Driven** - Apache Kafka for asynchronous messaging\n- 📝 **Observability** - Structured logging and monitoring\n- 🐳 **Container-Ready** - Docker and Docker Compose support\n\n---\n\n## 🚀 Quick Start\n\n### Prerequisites\n\n- **Node.js** 20+ or **Bun** 1.0+\n- **Docker** and **Docker Compose**\n- **Git** with submodule support\n\n### 📦 Quick Setup\n\n```bash\ngit clone --recursive https://github.com/devhoangkien/9plus-api.git\ncd 9plus-api\nbun run env:setup\nbun run install:all\ndocker compose up -d\n```\n\n**📖 For detailed setup instructions, see [Development Guide](./docs/development/)**\n\n---\n\n## 📚 Documentation\n\n- **[Development Guide](./docs/development/)** - Setup, configuration, and workflow\n- **[Architecture](./docs/architecture/)** - System design and microservices\n- **[Authentication \u0026 Authorization](./docs/auth/)** - Security implementation\n- **[Task Checklists](./docs/tasks/)** - Implementation guides\n\n---\n\n## 🤝 Contributing\n\nContributions are welcome! Please follow these steps:\n\n1. Fork the repository\n2. Create a feature branch: `git checkout -b feature/my-feature`\n3. Make your changes and add tests\n4. Run linting: `bun run app:lint`\n5. Commit with conventional commits: `git commit -m 'feat: add new feature'`\n6. Push to your fork: `git push origin feature/my-feature`\n7. Open a Pull Request\n\n### Commit Convention\n\nWe follow [Conventional Commits](https://www.conventionalcommits.org/):\n- `feat:` - New feature\n- `fix:` - Bug fix\n- `docs:` - Documentation changes\n- `refactor:` - Code refactoring\n- `test:` - Adding tests\n- `chore:` - Maintenance tasks\n\n---\n\n## 📄 License\n\nThis project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.\n\n---\n\n## 🙏 Acknowledgments\n\nBuilt with these amazing open-source technologies:\n- [NestJS](https://nestjs.com/) - Progressive Node.js framework\n- [GraphQL](https://graphql.org/) - Query language for APIs\n- [Apache Kafka](https://kafka.apache.org/) - Event streaming platform\n- [Elasticsearch](https://www.elastic.co/) - Search and analytics engine\n- [PostgreSQL](https://www.postgresql.org/) - Relational database\n- [Redis](https://redis.io/) - In-memory data store\n- [Docker](https://www.docker.com/) - Container platform\n\n---\n\n\u003cdiv align=\"center\"\u003e\n\n**⭐ If you find this project helpful, please consider giving it a star!**\n\nMade with ❤️ by [DevHoangKien](https://github.com/devhoangkien)\n\n[⬆ Back to Top](#9plus-api)\n\n\u003c/div\u003e\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdevhoangkien%2F9plus-api","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdevhoangkien%2F9plus-api","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdevhoangkien%2F9plus-api/lists"}