Files
pfadi-bussle/db/index.js
2020-07-29 23:35:14 +02:00

41 lines
1.3 KiB
JavaScript

import mongoose from 'mongoose'
import { BookingSchema, BookerSchema } from './schema'
mongoose.connect(process.env.MONGO_URI, {
useNewUrlParser: true,
useUnifiedTopology: true,
connectTimeoutMS: 1000,
serverSelectionTimeoutMS: 5000,
})
if (process.env.NODE_ENV !== 'production') {
mongoose.modelNames().includes('Booker') && mongoose.deleteModel('Booker')
mongoose.modelNames().includes('Booking') && mongoose.deleteModel('Booking')
}
export const Booker = mongoose.model('Booker', BookerSchema)
export const Booking = mongoose.model('Booking', BookingSchema)
export async function getBookedDays() {
const bookings = await Booking.find({
status: { $ne: 'rejected' },
$or: [{ endDate: { $gt: new Date() } }, { startDate: { $gt: new Date() } }],
}).exec()
return bookings.map((booking) => booking.days).flat()
}
export async function createBooking({ name, email, startDate, endDate }) {
const ignoreCaseEmailMatcher = new RegExp(email, 'i')
let booker = await Booker.findOne({ email: ignoreCaseEmailMatcher }).exec()
if (!booker) {
booker = new Booker({ name, email })
await booker.save()
}
const booking = new Booking({ startDate, endDate, booker: booker._id })
await booking.save()
await booking.populate('booker').execPopulate()
return booking.toJSON()
}