code in
code in
ejs`
This page displays all the listings:
```ejs
<% layout("/layouts/boilerplate") %>
<h3>All Listings</h3>
### `show.ejs`
This page shows the details of a single listing:
```ejs
<% layout("/layouts/boilerplate") %>
### `app.js`
Here’s your server-side code:
```javascript
const express = require("express");
const app = express();
const mongoose = require("mongoose");
const Listing = require("./models/listing.js");
const path = require("path");
const methodOverride = require("method-override");
const ejsMate = require("ejs-mate");
main()
.then(() => {
console.log("Connected to MongoDB");
})
.catch((err) => {
console.log("Connection Error:", err);
});
app.engine("ejs", ejsMate);
app.set("view engine", "ejs");
app.set("views", path.join(__dirname, "views"));
// Index Route
app.get("/listings", async (req, res) => {
const allListings = await Listing.find({});
res.render("listings/index.ejs", { allListings });
});
// New Route
app.get("/listings/new", (req, res) => {
res.render("listings/new.ejs");
});
// Show Route
app.get("/listings/:id", async (req, res) => {
const { id } = req.params;
const listing = await Listing.findById(id);
if (!listing) {
return res.status(404).send("Listing not found");
}
res.render("listings/show.ejs", { listing });
});
// Create Route
app.post("/listings", async (req, res) => {
const newListing = new Listing(req.body.listing);
await newListing.save();
res.redirect("/listings");
});
// Edit Route
app.get("/listings/:id/edit", async (req, res) => {
const { id } = req.params;
const listing = await Listing.findById(id);
res.render("listings/edit.ejs", { listing });
});
// Update Route
app.put("/listings/:id", async (req, res) => {
const { id } = req.params;
await Listing.findByIdAndUpdate(id, { ...req.body.listing });
res.redirect(`/listings/${id}`);
});
// Delete Route
app.delete("/listings/:id", async (req, res) => {
const { id } = req.params;
await Listing.findByIdAndDelete(id);
res.redirect("/listings");
});
app.listen(8080, () => {
console.log("Server is listening on port 8080");
});
```
### `models/listing.js`
Here’s the schema for the listings:
```javascript
const mongoose = require("mongoose");