Skip to content

JaviARodriguez/CENPROJECT

 
 

Repository files navigation

Set Up

  1. Ensure you have node.js v21.7.3
  2. Install Docker Desktop and make sure you can use docker-compose on CLI
  3. Fork the main repository
  4. Clone your forked repository
  5. Important: You will need three .env files. Two will be inside the root and server package, while the other will be in the client package. These files are on our discord.
  6. Make sure you have your docker application open while running docker commands

Run the application

  1. Go to your local (forked) repository and build the containers: docker-compose up -d

  2. To stop the containers: docker-compose down

Usage

To access the frontend of the application, go to http://localhost:5173
To access the backend/api of the application, go to http://localhost:3001

Development guidelines

  1. Any changes in code must come in the form of a PR and from your forked repo

  2. You can develop by only running the mongodb container (if needed) and then running the commands below: For react/vite: npm run dev

For node/express: npm run dev

  1. Make sure you build after every successful change in the frontend: npm run build

  2. Make sure you update the containers after development with: docker-compose up --build

Testing (Postman)

To see a list of all users, go to http://localhost:3001/api/users
This can also be done as a POST on Postman using the same routing, it will return a list of all usernames, their account type, and unique id.

Creating an Account

To create a test customer account, POST to http://localhost:3001/api/users/customers in this format:
{
"username": "customer",
"password": "pass123",
"firstName": "first",
"lastName": "last",
"address": "426 W Plant St",
"zipCode": "34787",
"city": "Winter Garden",
"state": "FL",
"email": "email@email.com",
"phoneNumber": "1234567890"
}

To create a test business account, POST to http://localhost:3001/api/users/businesses in this format:
{
"username": "Business",
"password": "PASS123",
"businessName": "Company",
"address": "426 W Plant St",
"zipCode": "64138",
"city": "34787",
"state": "FL",
"email": "Email@Email.com",
"phoneNumber": "1234567890",
"availability":[ {"Monday":[{"start":"09:00","end":"18:00"}]},
{"Wednesday":[{"start":"09:00","end":"18:00"}]},
{"Friday":[{"start":"09:00","end":"18:00"}]}]
]
}

These will return a login token, the username, and the account type.

Logging In

To log in, Post to http://localhost:3001/api/login/ in this format:
{
"username": "A",
"password": "B"
}

This will return a login token, the username, and the account type.

Search

TBD

Services

To request all services from a specific business, POST to http://localhost:3001/api/services/from/BUSINESS-ID with the business id in the BUSINESS-ID spot.
This will require a valid login token, in Postman this is in the Authorization tab as a Bearer token. \

To request more details about a specific service, POST to http://localhost:3001/api/services/SERVICE-ID with the service id in the SERVICE-ID spot.
This will return

Bookings

TBD

Reviews

TBD

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 99.3%
  • Other 0.7%