diff --git a/app.js b/app.js index 43635e8..b02365d 100644 --- a/app.js +++ b/app.js @@ -8,21 +8,19 @@ const courseRoute = require("./routes/course"); const couponRoute = require("./routes/Coupon"); const queryRoute = require("./routes/query"); const adminRoute = require("./routes/admin"); +const blogRouter = require("./routes/blog"); const port = process.env.PORT || 5000; - const cors = require("cors"); +const app = express(); //const passport = require('passport'); //const cookieSession = require('cookie-session') ; //require('./passport-setup') ; -const app = express(); - const MONGO_URI = `mongodb+srv://${process.env.MONGO_USER}:${process.env.MONGO_PASSWORD}@cluster0.dqxva.mongodb.net/${process.env.MONGO_DEFAULT_DATABASE}?retryWrites=true&w=majority`; app.use(cors()); app.use(bodyparser.json()); -require("./models/Coupon"); // app.use(cookieSession({ // name: 'test-session', @@ -104,4 +102,6 @@ app.use(adminRoute); app.use(couponRoute); +app.use(blogRouter); + app.use(queryRoute); diff --git a/controllers/auth.js b/controllers/auth.js index d6558d0..b80d0cc 100644 --- a/controllers/auth.js +++ b/controllers/auth.js @@ -13,11 +13,11 @@ const smtpTransport = require("nodemailer-smtp-transport"); var transport = nodemailer.createTransport( smtpTransport({ - host: `${process.env.HOST}`, //`${process.env.HOST}` + host: `email-smtp.us-east-1.amazonaws.com`, //`${process.env.HOST}` port: 465, auth: { - user: `${process.env.EMAIL}`, //`${process.env.EMAIL}` - pass: `${process.env.PASS}`, //`${process.env.PASS}` + user: `AKIA2G7743RRTZMVXE3X`, //`${process.env.EMAIL}` + pass: `BJSjV3jArJfsnk1LhFc/hUmisEyEtbLNGgrRbv0noh8c`, //`${process.env.PASS}` }, }) ); @@ -289,7 +289,9 @@ module.exports.forgotpassword = async (req, res, next) => { Facing any issue? Write us at

info@cantileverlabs.com

logo + src="" + title="logo" alt="logo"> +

Privacy Policy Terms Of Use @@ -369,6 +371,8 @@ module.exports.resetpassword = async (req, res, next) => { await user .save() .then((ok) => { + res.header("Access-Control-Allow-Origin", "*"); + res.header("Access-Control-Allow-Headers", "*"); res.json({ message: "Password Updated!" }); }) .catch((err) => { diff --git a/controllers/blog.js b/controllers/blog.js new file mode 100644 index 0000000..f6ea6c1 --- /dev/null +++ b/controllers/blog.js @@ -0,0 +1,103 @@ +const { log } = require("handlebars"); +const Blog = require("../models/Blog"); +const Course = require("../models/Course"); + +module.exports.getAllBlogs = async (req, res, next) => { + try { + let blog = await Blog.find(); + if (blog) { + res.json({ blogs: blog }); + } else { + console.log("Error in Blog", blog); + return; + } + } catch { + (err) => { + res.status(422).json({ error: err }); + }; + } +}; + +module.exports.addBlog = async (req, res, next) => { + const { _id, title, body, image } = req.body; //_id is of user from frontend who is adding the blog. + try { + let course = await Course.find({ _id }); + if (!title) { + res.status(422).json({ message: "Please, Add Title of the Blog" }); + return; + } + if (!body) { + res.status(422).json({ message: "Please, Add Body of the Blog" }); + return; + } + if (course) { + let blog = new Blog({ + title, + body, + image, + date: new Date(), + }); + await blog.save(); + res.json({ message: "Blog Saved Successfully!" }); + } else { + res.status.json({ error: "User Doesn't Exists" }); + return; + } + } catch { + (err) => { + res.status(422).json({ error: err }); + }; + } +}; + +module.exports.deleteBlog = async (req, res, next) => { + const { _id } = req.body; + try { + let blog = await Blog.find({ _id }); + if (blog) { + await Blog.findByIdAndDelete(_id); + res.json({ message: "Blog Deleted!" }); + } else { + res.status(404).json({ message: "Blog Not Found" }); + return; + } + } catch { + (err) => { + res.status(422).json({ error: err }); + }; + } +}; + +module.exports.editBlog = async (req, res, next) => { + const { _id, body, title, image } = req.body; + + try { + if (!title) { + res.status(422).json({ message: "Please, Add the Title of the Blog." }); + return; + } + if (!body) { + res.status(422).json({ message: "Please, Add the Body of the Blog." }); + return; + } + if (!image) { + res.status(422).json({ message: "Please, Add the Image of the Blog." }); + return; + } + let blog = Blog.findById(_id); + if (blog) { + blog.title = title; + blog.body = body; + blog.image = image; + await blog.save(); + res.json({ message: "Blog Updated!" }); + } else { + res.status(422).json({ error: "Blog Doesn't Found" }); + return; + } + } catch { + (err) => { + res.status(422).json({ error: err }); + }; + } +}; diff --git a/controllers/coupon.js b/controllers/coupon.js index 2220624..238e1ed 100644 --- a/controllers/coupon.js +++ b/controllers/coupon.js @@ -1,64 +1,52 @@ const Coupon = require("../models/Coupon"); -module.exports.getAllCoupons = async (req , res , next) => { - try - { - const coupons = await Coupon.find() ; - console.log(coupons) ; - res.json({ - coupons : coupons - }) ; - } - catch(err) - { - console.log(err) ; - } -} +module.exports.getAllCoupons = async (req, res, next) => { + try { + const coupons = await Coupon.find(); + console.log(coupons); + res.json({ + coupons: coupons, + }); + } catch (err) { + console.log(err); + } +}; -module.exports.addCoupon = async (req , res , next) => { - try - { - const couponCode = req.body.couponCode ; - const percentage = req.body.percentage ; - const numAllowed = req.body.numAllowed ; - - let coupon = await Coupon.findOne({couponCode : couponCode}) ; - if(coupon) - { - res.json({ - error:"coupon already Exist" - }) - } - else - { - let coupon = new Coupon({ - couponCode : couponCode , - percentage : percentage , - numAllowed : numAllowed - }) ; - coupon = await coupon.save() ; - res.json({ - message: "Created Successfully" - }) - } - } - catch(err) - { - console.log(err); - } -} +module.exports.addCoupon = async (req, res, next) => { + try { + const couponCode = req.body.couponCode; + const percentage = req.body.percentage; + const numAllowed = req.body.numAllowed; -module.exports.deleteCoupon = async (req , res, next) => { - try - { - const couponCode = req.body.couponCode ; - await Coupon.deleteOne({couponCode : couponCode}) ; - res.json({ - message: "Deleted Successfully" - }) + let coupon = await Coupon.findOne({ couponCode: couponCode }); + if (coupon) { + res.json({ + error: "Coupon already Exist", + }); + } else { + let coupon = new Coupon({ + couponCode: couponCode, + percentage: percentage, + numAllowed: numAllowed, + }); + coupon = await coupon.save(); + res.json({ + message: "Created Successfully", + }); } - catch(err) - { - console.log(err); - } -} \ No newline at end of file + } catch (err) { + console.log(err); + } +}; + +module.exports.deleteCoupon = async (req, res, next) => { + try { + const couponCode = req.body.couponCode; + await Coupon.deleteOne({ couponCode: couponCode }); + res.json({ + message: "Deleted Successfully", + }); + } catch (err) { + console.log(err); + } +}; diff --git a/models/Blog.js b/models/Blog.js new file mode 100644 index 0000000..33e6c55 --- /dev/null +++ b/models/Blog.js @@ -0,0 +1,27 @@ +const mongoose = require("mongoose"); +const blogSchema = new mongoose.Schema({ + title: { + type: String, + require: true, + }, + author: { + type: String, + ref: "Course", + }, + date: { + type: Date, + }, + image: { + type: String, + default: "", + }, + body: { + type: String, + required: true, + }, + isBookMarked: { + type: Boolean, + default: false, + }, +}); +module.exports = mongoose.model("Blog", blogSchema); diff --git a/routes/blog.js b/routes/blog.js new file mode 100644 index 0000000..51e5d57 --- /dev/null +++ b/routes/blog.js @@ -0,0 +1,14 @@ +const express = require("express"); +const router = express.Router(); +const BlogController = require("../controllers/blog"); +const isAuth = require("../middleware/requirelogin"); + +router.post("/add-blog", BlogController.addBlog); + +router.get("/get-all-blogs", BlogController.getAllBlogs); + +router.post("/delete-blog/", isAuth, BlogController.deleteBlog); + +router.post("/edit-blog/", isAuth, BlogController.editBlog); + +module.exports = router;