API: Move character routes to separate file
This commit is contained in:
@@ -7,6 +7,7 @@ const { isAuthorized } = require('./middleware/apiKeyAuth');
|
|||||||
const { Op } = require('sequelize');
|
const { Op } = require('sequelize');
|
||||||
|
|
||||||
const groupRoutes = require('./routes/groups');
|
const groupRoutes = require('./routes/groups');
|
||||||
|
const characterRoutes = require('./routes/characters');
|
||||||
|
|
||||||
const ACCESS_TOKEN = process.env.API_ACCESS_TOKEN;
|
const ACCESS_TOKEN = process.env.API_ACCESS_TOKEN;
|
||||||
const app = express();
|
const app = express();
|
||||||
@@ -82,69 +83,7 @@ router.get('/most-recent-drop', async (req, res) => {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
/**
|
|
||||||
* Characters
|
|
||||||
*/
|
|
||||||
router.get('/characters', async (req, res) => {
|
|
||||||
let condition = {
|
|
||||||
where: {
|
|
||||||
[Sequelize.Op.or]: [
|
|
||||||
{enabled: 1}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(isAuthorized && req.query.include_disabled) {
|
|
||||||
condition['where'][Sequelize.Op.or].push({enabled: 0});
|
|
||||||
}
|
|
||||||
|
|
||||||
let characters = await Character.findAll(condition);
|
|
||||||
res.json(characters);
|
|
||||||
});
|
|
||||||
|
|
||||||
router.get('/characters/:character_id', async (req, res) => {
|
|
||||||
let character = await Character.findByPk(req.params.character_id);
|
|
||||||
|
|
||||||
if (!character.enabled && !isAuthorized(req)) {
|
|
||||||
res.status(404).json({ error: 'Character not found' });
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
res.json(character);
|
|
||||||
});
|
|
||||||
|
|
||||||
router.post('/characters', async (req, res) => {
|
|
||||||
try {
|
|
||||||
const newCharacterData = req.body;
|
|
||||||
|
|
||||||
const newCharacter = await Character.create(newCharacterData);
|
|
||||||
|
|
||||||
res.status(201).json({ message: 'Character created successfully.', character: newCharacter });
|
|
||||||
} catch (error) {
|
|
||||||
res.status(500).json({ message: 'Error creating character.', error });
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
router.put('/characters/:character_id', async (req, res) => {
|
|
||||||
if(!isAuthorized(req, res)){return;}
|
|
||||||
|
|
||||||
try {
|
|
||||||
const characterId = req.params.character_id;
|
|
||||||
const updatedCharacterData = req.body;
|
|
||||||
|
|
||||||
const [updatedRowCount] = await Character.update(updatedCharacterData, {
|
|
||||||
where: { id: characterId }
|
|
||||||
});
|
|
||||||
|
|
||||||
if (updatedRowCount === 0) {
|
|
||||||
return res.status(404).json({ message: 'Character not found.' });
|
|
||||||
}
|
|
||||||
|
|
||||||
res.status(200).json({ message: 'Character updated successfully.' });
|
|
||||||
} catch (error) {
|
|
||||||
res.status(500).json({ message: 'Error updating character.', error });
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
app.use(PREFIX, router);
|
app.use(PREFIX, router);
|
||||||
app.use(PREFIX, groupRoutes);
|
app.use(PREFIX, groupRoutes);
|
||||||
|
app.use(PREFIX, characterRoutes);
|
||||||
module.exports = app;
|
module.exports = app;
|
||||||
|
|||||||
71
api/routes/characters.js
Normal file
71
api/routes/characters.js
Normal file
@@ -0,0 +1,71 @@
|
|||||||
|
const express = require('express');
|
||||||
|
const Sequelize = require('sequelize');
|
||||||
|
const { Character } = require('../../models');
|
||||||
|
const { isAuthorized } = require('../middleware/apiKeyAuth');
|
||||||
|
|
||||||
|
const router = express.Router();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Characters
|
||||||
|
*/
|
||||||
|
router.get('/characters', async (req, res) => {
|
||||||
|
let condition = {
|
||||||
|
where: {
|
||||||
|
[Sequelize.Op.or]: [
|
||||||
|
{ enabled: 1 }
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isAuthorized && req.query.include_disabled) {
|
||||||
|
condition['where'][Sequelize.Op.or].push({ enabled: 0 });
|
||||||
|
}
|
||||||
|
|
||||||
|
let characters = await Character.findAll(condition);
|
||||||
|
res.json(characters);
|
||||||
|
});
|
||||||
|
|
||||||
|
router.get('/characters/:character_id', async (req, res) => {
|
||||||
|
let character = await Character.findByPk(req.params.character_id);
|
||||||
|
|
||||||
|
if (!character.enabled && !isAuthorized(req)) {
|
||||||
|
res.status(404).json({ error: 'Character not found' });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
res.json(character);
|
||||||
|
});
|
||||||
|
|
||||||
|
router.post('/characters', async (req, res) => {
|
||||||
|
try {
|
||||||
|
const newCharacterData = req.body;
|
||||||
|
|
||||||
|
const newCharacter = await Character.create(newCharacterData);
|
||||||
|
|
||||||
|
res.status(201).json({ message: 'Character created successfully.', character: newCharacter });
|
||||||
|
} catch (error) {
|
||||||
|
res.status(500).json({ message: 'Error creating character.', error });
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
router.put('/characters/:character_id', async (req, res) => {
|
||||||
|
if (!isAuthorized(req, res)) { return; }
|
||||||
|
|
||||||
|
try {
|
||||||
|
const characterId = req.params.character_id;
|
||||||
|
const updatedCharacterData = req.body;
|
||||||
|
|
||||||
|
const [updatedRowCount] = await Character.update(updatedCharacterData, {
|
||||||
|
where: { id: characterId }
|
||||||
|
});
|
||||||
|
|
||||||
|
if (updatedRowCount === 0) {
|
||||||
|
return res.status(404).json({ message: 'Character not found.' });
|
||||||
|
}
|
||||||
|
|
||||||
|
res.status(200).json({ message: 'Character updated successfully.' });
|
||||||
|
} catch (error) {
|
||||||
|
res.status(500).json({ message: 'Error updating character.', error });
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
module.exports = router;
|
||||||
Reference in New Issue
Block a user