Refactored maps API. Added ability to seacrh by mapper.
This commit is contained in:
parent
0bafd5e4a6
commit
5fbcc2cc68
93
api/maps.js
93
api/maps.js
|
@ -5,31 +5,55 @@ const mapApi = Router()
|
|||
|
||||
mapApi.get(
|
||||
'/count',
|
||||
async (req, res) => {
|
||||
const mapAmount = await Level.find({}).count()
|
||||
|
||||
res.json({
|
||||
success: true,
|
||||
response: mapAmount
|
||||
})
|
||||
(req, res) => {
|
||||
Level.find({}).count().then(
|
||||
mapAmount => {
|
||||
res.json({
|
||||
success: true,
|
||||
response: mapAmount
|
||||
})
|
||||
}
|
||||
)
|
||||
}
|
||||
)
|
||||
|
||||
mapApi.get(
|
||||
'/get/:map',
|
||||
async (req, res) => {
|
||||
const map = await Level.findOne({ name: req.params.map })
|
||||
(req, res) => {
|
||||
Level.findOne({ name: req.params.map }).then(
|
||||
map => {
|
||||
if (!map)
|
||||
return res.json({
|
||||
success: false,
|
||||
response: "No map found!"
|
||||
})
|
||||
|
||||
res.json({
|
||||
success: true,
|
||||
response: map
|
||||
})
|
||||
}
|
||||
)
|
||||
}
|
||||
)
|
||||
|
||||
if (!map)
|
||||
return res.json({
|
||||
success: false,
|
||||
response: "No map found!"
|
||||
})
|
||||
|
||||
res.json({
|
||||
success: true,
|
||||
response: map
|
||||
})
|
||||
mapApi.get(
|
||||
'/category/:category',
|
||||
(req, res) => {
|
||||
Level.find({ category: req.params.category }).then(
|
||||
maps => {
|
||||
if (!maps[0])
|
||||
return res.json({
|
||||
success: false,
|
||||
response: "Invalid category name!"
|
||||
})
|
||||
|
||||
res.json({
|
||||
success: true,
|
||||
response: maps
|
||||
})
|
||||
}
|
||||
)
|
||||
}
|
||||
)
|
||||
|
||||
|
@ -46,23 +70,26 @@ mapApi.get(
|
|||
const sort = req.query.sort ?? 'name'
|
||||
const order = req.query.order === "desc" ? -1 : 1
|
||||
const page = req.query.page ?? 1
|
||||
|
||||
const filter = req.query.byMapper ? { mapper: { $regex: name, $options: 'i' }} : { name: { $regex: name, $options: 'i' }}
|
||||
const pageCount = Math.ceil((await Level.find({ name: { $regex: name, $options: 'i' }}).count()) / 20)
|
||||
const maps = await Level.find({ name: { $regex: name, $options: 'i' }}).sort([[sort, order]]).limit(20).skip((page - 1) * 20)
|
||||
|
||||
if (!maps[0])
|
||||
return res.json({
|
||||
success: false,
|
||||
response: "No maps found!"
|
||||
})
|
||||
|
||||
res.json({
|
||||
success: true,
|
||||
response: {
|
||||
pageCount,
|
||||
maps
|
||||
Level.find(filter).sort([[sort, order]]).limit(20).skip((page - 1) * 20).then(
|
||||
maps => {
|
||||
if (!maps[0])
|
||||
return res.json({
|
||||
success: false,
|
||||
response: "No maps found!"
|
||||
})
|
||||
|
||||
res.json({
|
||||
success: true,
|
||||
response: {
|
||||
pageCount,
|
||||
maps
|
||||
}
|
||||
})
|
||||
}
|
||||
})
|
||||
)
|
||||
}
|
||||
)
|
||||
|
||||
|
|
Loading…
Reference in New Issue
Block a user