Files
api.pawol.nu/src/api/artiste/controllers/artiste.js
T

58 lines
1.5 KiB
JavaScript
Raw Normal View History

2022-05-12 03:22:15 +04:00
'use strict';
2022-05-12 03:03:29 +04:00
const { createCoreController } = require('@strapi/strapi').factories;
2022-05-20 00:06:01 +04:00
const slugify = require('slugify')
2022-05-12 03:03:29 +04:00
2022-05-20 00:06:01 +04:00
const getSlug = text => {
return slugify(text, {lower: true, remove: /[*#+~.()'"!:@]/g})
}
module.exports = createCoreController('api::artiste.artiste', ({strapi}) => ({
async create(ctx) {
const {body} = ctx.request
let {data} = body
if (ctx.request && ctx.request.header && ctx.request.header.authorization) {
try {
const {id} = await strapi.plugins[
'users-permissions'
].services.jwt.getToken(ctx)
if (id !== data.user.id) {
throw new UnauthorizedError('Opération non autorisée')
}
} catch (err) {
throw new UnauthorizedError(ctx, err, 'Opération non autorisée')
}
}
2026-04-21 21:35:59 +04:00
const user = await strapi.documents('plugin::users-permissions.user').findOne({
documentId: "__TODO__"
})
2022-05-20 00:06:01 +04:00
if (!user) {
throw new NotFoundError('Utilisateur introuvable.')
}
if (user.id !== data.user.id || user.username !== data.user.username || user.email !== data.user.email) {
ctx.badRequest('Informations non valides.')
2022-05-20 00:06:01 +04:00
}
const artiste = await strapi.db.query('api::artiste.artiste').findOne({
where: {slug: getSlug(data.alias)}
})
if (artiste) {
return artiste
} else {
2026-04-21 21:35:59 +04:00
const newArtiste = await strapi.documents('api::artiste.artiste').create({
2022-05-20 00:06:01 +04:00
data: {
...data
}
})
return newArtiste
}
}
}))