Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/poly-glot/agile-poker

A serverless application built on Firebase Cloud to make agile team's story estimating efficient and fun.
https://github.com/poly-glot/agile-poker

firebase firebase-auth firebase-realtime-database firebase-testing micro-app serverless tdd-javascript vanilla-javascript vanilla-js webpack5 year-2021

Last synced: about 1 month ago
JSON representation

A serverless application built on Firebase Cloud to make agile team's story estimating efficient and fun.

Awesome Lists containing this project

README

        

# AGILE POKER ([Demo](https://agile.junaid.guru))
![CI/CD](https://github.com/poly-glot/agile-poker/workflows/CI/CD/badge.svg)
[![codecov](https://codecov.io/gh/poly-glot/agile-poker/branch/main/graph/badge.svg)](https://codecov.io/gh/poly-glot/agile-poker)
[![This project is using Percy.io for visual regression testing.](https://percy.io/static/images/percy-badge.svg)](https://percy.io/328a6753/agile-poker)
[![Cypress.io Dashboard](https://img.shields.io/badge/cypress-dashboard-brightgreen.svg)](https://dashboard.cypress.io/projects/coqb3r/runs)
[![DeepScan grade](https://deepscan.io/api/teams/8408/projects/10623/branches/149386/badge/grade.svg)](https://deepscan.io/dashboard#view=project&tid=8408&pid=10623&bid=149386)
[![Maintainability](https://api.codeclimate.com/v1/badges/e9ab18c4667689e347de/maintainability)](https://codeclimate.com/github/poly-glot/agile-poker/maintainability)
[![Open in Gitpod](https://gitpod.io/button/open-in-gitpod.svg)](https://gitpod.io/#https://github.com/poly-glot/agile-poker)

Creating the Agile team's story estimating session as efficient and fun as possible with a serverless application built on Firebase Cloud.

# System Requirements
- [Java 11](https://sdkman.io/) `sdk install java 11.0.14-zulu`
- [Nodejs 16+](https://nodejs.org/en/download/)
- [Firebase CLI](https://firebase.google.com/docs/cli) `npm i -g firebase-tools`

# Getting Started

## Setup (One off)
```
npm install
cd functions
npm install
cd ..
```

## Start
```
npm start
```

# Browser Support
2 most recent versions of Chrome, Firefox, Safari & MS Edge.

# Security Consideration
- Enabled [App Check](https://firebase.google.com/docs/app-check)
- Setup Monitoring on [Realtime Database](https://firebase.google.com/docs/database/usage/monitor-usage)
- Locked read & write access. Added Security Rules & Validation on firebase to test the protection on abusive behaviour.
- Make sure to set up max-instances on [Cloud functions](https://cloud.google.com/functions/docs/max-instances)

# Scalability Consideration
- Solution can handle up to 200k concurrent connections on [Firebase Blaze Plan](https://firebase.google.com/pricing)
- [Tested with 1000+ Realtime users making 40k requests using flood.io](https://app.flood.io/28CLJ92Tg10MkW9bWbxtwV4TiDG)