Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cooper-gadd/bug-tracker
🐛 Bug tracking system.
https://github.com/cooper-gadd/bug-tracker
bun mysql php react shadcn-ui swr tailwindcss vite
Last synced: 17 days ago
JSON representation
🐛 Bug tracking system.
- Host: GitHub
- URL: https://github.com/cooper-gadd/bug-tracker
- Owner: cooper-gadd
- Created: 2024-10-03T18:19:24.000Z (4 months ago)
- Default Branch: main
- Last Pushed: 2024-11-01T21:06:17.000Z (3 months ago)
- Last Synced: 2024-11-10T20:05:47.545Z (3 months ago)
- Topics: bun, mysql, php, react, shadcn-ui, swr, tailwindcss, vite
- Language: TypeScript
- Homepage: https://solace.ist.rit.edu/~ctg7866/ISTE341/bug-tracker/
- Size: 4.71 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Bug Tracking System
## Table of Contents
- [Project Overview](#project-overview)
- [Demo](#demo)
- [Bugs Dashboard](#bugs-dashboard)
- [Filtering](#filtering)
- [Actions](#actions)
- [New Bug](#new-bug)
- [Projects Dashboard](#projects-dashboard)
- [New Project](#new-project)
- [Users Dashboard](#users-dashboard)
- [New User](#new-user)
- [Delete User](#delete-user)
- [Key Features](#key-features)
- [Test Users](#test-users)
- [System Architecture Diagram](#system-architecture-diagram)
- [Technical Stack](#technical-stack)
- [Libraries and Tools](#libraries-and-tools)
- [API Endpoints](#api-endpoints)
- [User Roles and Permissions](#user-roles-and-permissions)
- [Security Measures](#security-measures)
- [Code Structure](#code-structure)
- [Frontend](#frontend)
- [Backend](#backend)
- [Development](#development)
- [Deployment](#deployment)## Project Overview
This bug tracking system is developed for my Server Programming class, featuring a React frontend and PHP backend. It efficiently manages bugs across various projects with role-based access control.## Demo
### Bugs Dashboard
![Bugs Dashboard](./images/bugs-dashboard.png)### Filtering
![Filtering](./images/filtering.png)### Actions
![Actions](./images/actions.png)### New Bug
![New Bug](./images/new-bug.png)### Projects Dashboard
![Projects Dashboard](./images/projects-dashboard.png)### New Project
![New Project](./images/new-project.png)### Users Dashboard
![Users Dashboard](./images/users-dashboard.png)### New User
![New User](./images/new-user.png)### Delete User
![Delete User](./images/delete-user.png)## Key Features
- Single Page Application (SPA) with React
- RESTful API backend in PHP
- User Authentication with sessions
- Role-Based Access Control: Admin, Manager, and User roles
- Bug Management: Create, update, and read operations for bugs
- Project Management: Create and manage projects (Admin and Manager)
- User Management: Add, update, and delete users (Admin only)
- Data Visualization: Dynamic views of bugs by project, status, and due date
- Security: Input validation, data sanitization, and password hashing## Test Users
- **Admin**: Username: `[email protected]`, Password: `me`
- **Manager**: Username: `[email protected]`, Password: `me`
- **User**: Username: `[email protected]`, Password: `me`## System Architecture Diagram
```mermaid
graph LR
A[Web App] <--> B[API]
B <--> C[Controller]
C <--> D[(Database)]
```## Technical Stack
- Frontend: React
- Backend: PHP
- Database: MySQL
- API: RESTful
- Authentication: Sessions## Libraries and Tools
- **Data Fetching**: [SWR](https://swr.vercel.app/)
- **Library**: [React](https://reactjs.org/)
- **Styling**: [Tailwind CSS](https://tailwindcss.com)
- **Components**: [Shadcn](https://ui.shadcn.com/)
- **Package Manager**: [Bun](https://bun.sh/)## API Endpoints
- `/api/` - Initialize seed data
- `/api/login` - User login
- `/api/logout` - User logout
- `/api/current-user` - Get current logged-in user
- `/api/bugs` - Get all bugs
- `/api/bug` - Create a new bug
- `/api/bug/{id}` - Update a bug by ID
- `/api/projects` - Get all projects
- `/api/project` - Create a new project
- `/api/roles` - Get all roles
- `/api/priorities` - Get all priorities
- `/api/assign` - Assign a bug to a user
- `/api/close` - Close a bug with a fix description
- `/api/users` - Get all users
- `/api/users/project/{projectId}` - Get users by project ID
- `/api/user/{id}` - Get a user by ID
- `/api/user` - Create a new user
- `/api/user/{id}` - Update a user by ID
- `/api/user/delete/{id}` - Delete a user by ID (GET method due to server limitations)## User Roles and Permissions
- **Admin**: Full system access
- **Manager**: Project and bug management across all projects
- **User**: Bug entry and management within assigned project## Security Measures
- Session-based authentication
- Password hashing using bcrypt
- Parameterized queries to prevent SQL injection
- Input validation on both frontend and backend## Code Structure
### Frontend
- Components: Reusable React components
- Hooks: API communication services### Backend
- Index: Entry point for API requests
- Controllers: Handle API requests## Development
- Frontend: Run `bun run dev` in the frontend directory
- Backend: Ensure your PHP server is running and pointing to the backend directory## Deployment
- Frontend: Build using `bun run build`, deploy the `build` folder
- Backend: Deploy PHP files to a production PHP server