Skip to content

Restaurant App πŸ” is a sample open-source e-Commerce πŸ›’ application for ordering foods, powered by polyglot microservices architecture and cross-platform development including mobile and web

Notifications You must be signed in to change notification settings

chayxana/Restaurant-App

Repository files navigation

Restaurant App

Open in Gitpod

if you have any questions, please reach me out:

Gitter

Restaurant App is containerized polyglot microservices application that contains projects based on .NET Core, Golang, Java, Xamarin, React, Angular and etc. The project demonstrates how to develop small microservices for larger applications using containers, orchestration, service discovery, gateway, and best practices. You are always welcome to improve code quality and contribute it, if you have any questions or issues don't hesitate to ask in our gitter chat.

To getting started, simply fork this repository. Please refer to CONTRIBUTING.md for contribution guidelines.

Motivation

  • Developing independently deployable and scalable micro-services based on best practies using containerization ☸ 🐳
  • Developing cross-platform beautiful mobile apps using Xamarin.Forms
  • Developing Single Page applications using React and Angular including best practices
  • Configuring fully automated CI/CD pipelines using Github Actions to mono-repo and Azure Pipelines and AppCenter for mobile
  • Using modern technologies such as GraphQL, gRPC, Apache Kafka, Serverless, Istio
  • Writing clean, maintainable and fully testable code, Unit Testing, Integration Testing and Mocking practices
  • Using SOLID Design Principles
  • Using Design Patterns and Best practices in different programming languages

Architecture overview

The architecture proposes a micro-service oriented architecture implementation with multiple autonomous micro-services (each one owning its own data/db and programming language) and using REST/HTTP as the communication protocol between the client apps, and gRPC for the backend communication in order to support data update propagation across multiple services.

List of micro-services and infrastructure components

β„– Service Description Build Status Endpoints
1. Identity API (.NET Core + IdentityServer4) Identity management service, powered by OAuth2 and OpenID Connect Build Status dev | prod
2. Cart API (Golang + Redis) Manages customer basket in order to keep items on in-memory cache using redis Build Status dev | prod
3. Catalog API (Rust + Rocket, PostgreSQL) Manages data for showing restaurant menu Build Status dev | prod
4. Order API (Java + Quarkus + Native Build) Manages customer orders Build Status dev | prod
5. Ceckout API (Node.js + Express) Responsible for checkout functionality Build Status dev | prod
6. Payment API (Golang) Fake payment API (Payment service abstracting PSP) Build Status dev | prod
6. Web App (Typescript + Next.js ❀️ ) Frontend application Build Status dev | prod

Web App

Web app developed using Next.js with SSR image

Mobile app

Unfortunately I no longer be able to maintain Xamarin(mobile) part

Mobile Build status Release
Android Build Status Download Android
iOS Build Status Download iOS

Mobile app developed by Xamarin.Forms and supports iOS and Android, here you can find how to develop cross-platform mobile apps using C#. The example shows how to develop beautiful user interfaces using Xamarin.Forms and how to manage your code with Clean Architecture on the mobile side and get a clean, maintainable, testable code.

Contributors

Thank you to all the people who have already contributed to our project!