An internal app ticketing system for IT Department's to trouble-shoot and communicate with techs using a system log entries and server up/down status. A tech can create a log and prioritize the issue. If the logs needs further details the has edit capabilities to make changes to the log. Once the issue is resolved a tech can delete the issue.
**The app is hosted on render which can take 45-60 seconds to fully spin up sleep servers on first load
Video coming soon...
- Fullscreen mode
- Cross platform
- Mobile Responsive
- User Login / Registration
- Prioritize a log to high
- Authenticated with JWT
- Authenticated users have their own private dashboard
- A user full CRUD operations of their logs
- Authenticated users can read only all other public logs
- A search filter is used to filter through all logs
Technologies:
Testing
Challenges
- Setting token to be checked for all request, adjusting store subscriber and when to loadTech()
- Multiple checkboxes with local state
- Materialize css for edit modal, had to use Material Select component
- Filter state vs filter DB
- Error checking state and component
- Add charts for server and tech statistics
- Change StatusCards for server status to be manage by Redux
- Add Profile
- Tag a tech on a log
- Up time and Down time Warnings
- Upload an screenshot to the log
- Comment on a specific log similar to slack channels
If you have any feedback, please reach out to gregpetropoulos@yahoo.com
- Go to the Register page and create a user
Clone the project
# https
git clone https://github.com/GregPetropoulos/IT-Logger-App.git
# ssh
git clone git@github.com:GregPetropoulos/IT-Logger-App.git
In the root folder
Install dependencies
npm install
Start the both frontend and backend servers
npm run dev
In the root folder
Install dependencies
npm install
Start the server
npm run server
In the root folder
cd client
Install dependencies
npm install
Start the server
npm run start
There are three core API categories and more detail can be found at the postman docs
/api/techs
/api/logs
/api/auth
- Protected routes for each tech.
- Each Tech can Create Read Updated Delete (CRUD) a log in their own private view. Once Ready a tech can add log to public interface
- Outside of a tech's log they can read only all other logs
- Routes that are protected are by design of middleware for checking tokens and valid database id's
The database has two collections:
-
logs
-
techs
Logs are cross referenced by the techs id that created the log
The collections are created by the mongoose schema in the models folder. The log schema is associated to the tech schema by objectId.
const mongoose = require('mongoose');
const LogSchema = mongoose.Schema({
// *Specific to a users logs
tech:{
type: mongoose.Schema.Types.ObjectId,
ref: 'techs'
},
This allows the tech to have their own private view of the logs on their account.
The express-validator npm package was utilized to handle the backend validation for Registration
, Login
, and Log routes
.
The validation comes after the auth middleware,
check('firstName','A first name is required').not.isEmpty(), (req,res)....
.not
negates the result of the next validator in the chain and the .isEmpty()
returns a boolean value for no errors within the result object
https://express-validator.github.io/docs/validation-result-api.html#isempty
A tech will have an authenticated route to login into after being registered. A middleware is used at login to check and verify the JSON Web Token. The tech.id is then stored in the payload to be used as reference of the logged in user.
The JSON Web Token is used to identify tech in the db by header, payload data, and signature JWT
To run this project, you will need to add the following environment variables to your .env file
, see the .env-example
in the root folder
PORT=5000
NODE_ENV=development
MY_MONGODB_URI=ADD_YOUR_CONNECTION_STRING_HERE
MY_JWT_SECRET=ADD_YOUR_SECRET
SUPPRESS_NO_CONFIG_WARNING=false
To deploy this project on a platform such as render or heroku:
npm run deploy
Contributions are always welcome!
See contribute for ways to get started.
Please adhere to this project's code of conduct
.
I am a React/React-Native Front End Developer and enjoy building applications with engaging UI/UX and robust backend API's with Node.js
React, React Native, Javascript, HTML, CSS, Node, Express
π©βπ» I'm currently working on React migration to React Native code base
π§ I'm currently learning Cypress testing strategy and Next.js
π―ββοΈ I'm looking to collaborate on open source Veterans Health apps
π¬ Ask me about anything frontend
π« How to reach me gregpetropoulos@yahoo.com
β‘οΈ Fun fact...I found a dinosaur fossil that remains in the Las Vegas Natural History Museum.