Files
artdanj-api/app/Controllers/Http/UsersController.ts
Arthur DANJOU 404d193b46 Working
Signed-off-by: Arthur DANJOU <arthurdanjou@outlook.fr>
2021-07-01 16:13:22 +02:00

52 lines
1.5 KiB
TypeScript
Executable File

import {HttpContextContract} from '@ioc:Adonis/Core/HttpContext'
import User from "App/Models/User";
import UserStoreValidator from "App/Validators/users/UserStoreValidator";
import UserUpdateValidator from "App/Validators/users/UserUpdateValidator";
export default class UsersController {
public async index({response}: HttpContextContract) {
return response.status(200).send({
users: User.query()
})
}
public async store({request, response}: HttpContextContract) {
const data = await request.validate(UserStoreValidator)
return response.status(200).send({
user: await User.create(data)
})
}
public async show({params, response}: HttpContextContract) {
return response.status(200).send({
user: await User.findOrFail(params.id)
})
}
public async update({request, params, response}: HttpContextContract) {
const user = await User.findOrFail(params.id)
const data = await request.validate(UserUpdateValidator)
await user.merge(data).save()
return response.status(200).send({
message: 'User successfully updated!'
})
}
public async destroy({ response, params, auth }: HttpContextContract) {
const user = await User.findOrFail(params.id)
const admin = await User.findBy('email', 'arthurdanjou@outlook.fr')
if (auth.user?.id != admin?.id) {
return response.unauthorized()
}
await user.delete()
return response.status(200).send({
message: 'User successfully deleted!'
})
}
}