Added poll create route in backend✔️
This commit is contained in:
63
backend/src/routes/v1/poll.route.js
Normal file
63
backend/src/routes/v1/poll.route.js
Normal file
@@ -0,0 +1,63 @@
|
||||
import express from "express";
|
||||
import { verifyToken } from "../../middlwares/verifyToken.js";
|
||||
import { createPollController } from "../../controllers/poll.controller.js";
|
||||
import pollDataSchema from "../../validations/pollDataValidation.js";
|
||||
import validator from "../../validations/validator.js";
|
||||
const pollRouter = express.Router();
|
||||
|
||||
/**
|
||||
* @swagger
|
||||
* /poll/test:
|
||||
* get:
|
||||
* summary: Test route for poll
|
||||
* tags: [Poll]
|
||||
* responses:
|
||||
* 200:
|
||||
* description: Success
|
||||
*/
|
||||
pollRouter.get("/test", (req, res) => {
|
||||
res.json({
|
||||
success : true,
|
||||
message : "Poll route is working✔️"
|
||||
})
|
||||
})
|
||||
|
||||
/**
|
||||
* @swagger
|
||||
* /poll/create:
|
||||
* post:
|
||||
* summary: Create poll
|
||||
* tags: [Poll]
|
||||
* requestBody:
|
||||
* required: true
|
||||
* content:
|
||||
* application/json:
|
||||
* schema:
|
||||
* type: object
|
||||
* properties:
|
||||
* title:
|
||||
* type: string
|
||||
* description:
|
||||
* type: string
|
||||
* options:
|
||||
* type: array
|
||||
* items:
|
||||
* type: string
|
||||
* required:
|
||||
* - title
|
||||
* - description
|
||||
* - options
|
||||
* responses:
|
||||
* 201:
|
||||
* description: Poll created successfully
|
||||
* 400:
|
||||
* description: Validation error
|
||||
* 401:
|
||||
* description: Unauthorized
|
||||
* 500:
|
||||
* description: Internal server error
|
||||
*
|
||||
*/
|
||||
pollRouter.post("/create", validator(pollDataSchema), verifyToken, createPollController);
|
||||
|
||||
export default pollRouter;
|
||||
@@ -1,5 +1,5 @@
|
||||
import express from "express";
|
||||
import { signinController, signupController } from "../../controllers/user.controller.js";
|
||||
import { checkUser, logOutController, signinController, signupController } from "../../controllers/user.controller.js";
|
||||
import validate from "../../validations/validator.js";
|
||||
import signupSchema from "../../validations/signupValidation.js";
|
||||
import signinSchema from "../../validations/signinValidation.js";
|
||||
@@ -81,20 +81,18 @@ userRouter.post("/signup", validate(signupSchema), signupController);
|
||||
*/
|
||||
userRouter.post("/signin", validate(signinSchema), signinController);
|
||||
|
||||
userRouter.get("/user", verifyToken, (req, res) => {
|
||||
try{
|
||||
res.json({
|
||||
success : true,
|
||||
message : "Found",
|
||||
data : req.user
|
||||
})
|
||||
}
|
||||
catch(err){
|
||||
res.status(500).json({
|
||||
success : false,
|
||||
message : err.message
|
||||
})
|
||||
}
|
||||
})
|
||||
userRouter.get("/logout", logOutController);
|
||||
|
||||
/**
|
||||
* @swagger
|
||||
* /check:
|
||||
* get:
|
||||
* summary: Get user details
|
||||
* tags: [User]
|
||||
* responses:
|
||||
* 200:
|
||||
* description: Success
|
||||
*/
|
||||
userRouter.get("/check", verifyToken, checkUser);
|
||||
|
||||
export default userRouter;
|
||||
Reference in New Issue
Block a user