2022-07-24 13:02:57 +03:00
|
|
|
module main
|
|
|
|
|
|
|
|
import vweb
|
|
|
|
import json
|
|
|
|
import databases
|
|
|
|
|
|
|
|
['/user/:id/get'; get]
|
|
|
|
pub fn (mut app App) controller_get_user_by_id(id int) vweb.Result {
|
|
|
|
response := app.service_get_user_by_id(id) or {
|
|
|
|
app.set_status(400, '')
|
2022-11-15 16:53:13 +03:00
|
|
|
return app.text('${err}')
|
2022-07-24 13:02:57 +03:00
|
|
|
}
|
|
|
|
return app.json(response)
|
|
|
|
}
|
|
|
|
|
|
|
|
['/user/create'; post]
|
|
|
|
pub fn (mut app App) controller_create_user() vweb.Result {
|
|
|
|
body := json.decode(User, app.req.data) or {
|
|
|
|
app.set_status(400, '')
|
2022-11-15 16:53:13 +03:00
|
|
|
return app.text('Failed to decode json, error: ${err}')
|
2022-07-24 13:02:57 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
response := app.service_add_user(body.username, body.password) or {
|
|
|
|
app.set_status(400, '')
|
2022-11-15 16:53:13 +03:00
|
|
|
return app.text('error: ${err}')
|
2022-07-24 13:02:57 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
return app.json(response)
|
|
|
|
}
|
|
|
|
|
|
|
|
['/user/get_all'; get]
|
|
|
|
pub fn (mut app App) controller_get_all_user() vweb.Result {
|
|
|
|
token := app.get_header('token')
|
|
|
|
|
|
|
|
if !auth_verify(token) {
|
|
|
|
app.set_status(401, '')
|
|
|
|
return app.text('Not valid token')
|
|
|
|
}
|
|
|
|
|
|
|
|
response := app.service_get_all_user() or {
|
|
|
|
app.set_status(400, '')
|
2022-11-15 16:53:13 +03:00
|
|
|
return app.text('${err}')
|
2022-07-24 13:02:57 +03:00
|
|
|
}
|
|
|
|
return app.json(response)
|
|
|
|
}
|
|
|
|
|
|
|
|
['/user/get_by_username/:username'; get]
|
|
|
|
pub fn (mut app App) controller_get_by_username(username string) vweb.Result {
|
|
|
|
response := app.service_get_by_username(username) or {
|
|
|
|
app.set_status(400, '')
|
2022-11-15 16:53:13 +03:00
|
|
|
return app.text('${err}')
|
2022-07-24 13:02:57 +03:00
|
|
|
}
|
|
|
|
return app.json(response)
|
|
|
|
}
|
|
|
|
|
|
|
|
['/user/drop'; delete]
|
|
|
|
pub fn (mut app App) delete() vweb.Result {
|
|
|
|
mut db := databases.create_db_connection() or {
|
|
|
|
app.set_status(400, '')
|
2022-11-15 16:53:13 +03:00
|
|
|
return app.text('${err}')
|
2022-07-24 13:02:57 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
defer {
|
2022-08-12 17:24:57 +03:00
|
|
|
db.close() or { panic(err) }
|
2022-07-24 13:02:57 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
sql db {
|
|
|
|
drop table User
|
|
|
|
}
|
|
|
|
|
2022-08-12 17:24:57 +03:00
|
|
|
return app.text('Successfully deleted table')
|
2022-07-24 13:02:57 +03:00
|
|
|
}
|