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
+ 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;