Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/getz-devs/librakeeper-server
Robust Backend System for a Personal Book Library 📜
https://github.com/getz-devs/librakeeper-server
book-library book-management books docker docker-compose firebase-auth gin golang grpc microservices mongodb rabbitmq rest-api
Last synced: 3 months ago
JSON representation
Robust Backend System for a Personal Book Library 📜
- Host: GitHub
- URL: https://github.com/getz-devs/librakeeper-server
- Owner: getz-devs
- Created: 2024-06-20T15:15:37.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-07-21T01:43:09.000Z (6 months ago)
- Last Synced: 2024-10-02T05:21:29.467Z (4 months ago)
- Topics: book-library, book-management, books, docker, docker-compose, firebase-auth, gin, golang, grpc, microservices, mongodb, rabbitmq, rest-api
- Language: Go
- Homepage:
- Size: 161 KB
- Stars: 0
- Watchers: 0
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Librakeeper Server
*― A Robust Backend System for a Personal Book Library*
Librakeeper Server is a backend system designed for managing a personal book library. It provides a robust set of
features, including user authentication, book management, bookshelf organization, and advanced search capabilities. The
system is built using a microservices architecture with asynchronous processing, ensuring efficient and scalable
operations.## Key Features
* **User Authentication:** Secure authentication using Firebase.
* **Book Management:** Add, view, update, and delete books with detailed information (ISBN, title, author, publishing,
description, cover image, and shop).
* **Bookshelf Organization:** Create and manage personalized bookshelves to categorize books.
* **Search Functionality:** Find books by ISBN using simple (local database) or advanced (gRPC-based) search.
* **Microservice Architecture:** Leverage gRPC for efficient communication between the server, searcher, and
searcher-agent microservices.
* **Asynchronous Processing:** Utilize RabbitMQ for asynchronous book searching and processing.
* **Persistent Storage:** Store book and bookshelf data in a MongoDB database.
* **Containerization:** Easy deployment and setup using Docker and Docker Compose.## API Documentation
For detailed information about the Librakeeper Server API, including available endpoints, data structures, and
authentication requirements, please refer to the comprehensive [API documentation](API.md).## Architecture Overview
The system follows a microservice architecture, with components communicating via gRPC and RabbitMQ.
```mermaid
graph TB
Server[Librakeeper Server] -- gRPC --> Searcher[Book Searcher Service]
Searcher -- RabbitMQ --> SearcherAgent[Book Searcher Agent]
SearcherAgent -- HTTP --> Websites[(External Websites)]
Server -- MongoDB --> Database[(MongoDB Database)]
Searcher -- MongoDB --> Database
SearcherAgent -- MongoDB --> Database
```## Getting Started
Here's how to set up and run Librakeeper Server locally:
### Prerequisites
* **Go:** [https://golang.org/](https://golang.org/)
* **Docker:** [https://www.docker.com/](https://www.docker.com/)
* **Docker Compose:** [https://docs.docker.com/compose/](https://docs.docker.com/compose/)
* **MongoDB:** [https://www.mongodb.com/](https://www.mongodb.com/)### Configuration
1. **Configuration Files:**
- Configure the server, searcher, and searcher-agent microservices using the provided YAML configuration files (
e.g., `config/server/docker-local.yaml`).
- Update database connection details, RabbitMQ settings, and other relevant parameters in these files.
2. **Firebase Credentials:**
- Obtain Firebase service account credentials (a JSON file).
- Place the credentials file in the `config/server` directory and reference it in the server's configuration
file (`auth.config_path`).### Installation
1. **Clone the Repository:**
```bash
git clone https://github.com/your-username/librakeeper-server.git
cd librakeeper-server
```
2. **Start Services:**
```bash
docker-compose up -d
```### Running the Server
Once the services are up and running, the Librakeeper Server will be accessible at `http://localhost:8080`.