-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
64 lines (55 loc) · 1.52 KB
/
server.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
/*
CRUD
CREAT
READ
UPDATE
DELETE
//=====================================================
*/
//GET=>BUSCA INFORMAÇOES
//POST=>CRIAR
//PUT=>ALTERAÇAO
//DELETE=>DELETAR
//PATCH=>ALTERAÇAO PARCIAL
//===================================================
import {fastify} from 'fastify'
//import { DatabaseMemory } from './database-memory.js'
import { DatabasePostgres } from './database-postgres.js'
const server = fastify()
//const database = new DatabaseMemory()
const database =new DatabasePostgres()
server.post('/videos',async (request,reply) =>{
const {title,description,duration} = request.body
await database.create({
title,
description,
duration,
})
return reply.status(201).send()
})
server.get('/videos',async (request) =>{
const search=request.query.search
console.log(search)
const videos =await database.list(search)
console.log(videos)
return videos
})
//criar id utilizamos o ROUTE parameter
server.put('/videos/:id', async (request, reply) =>{
const videoId =request.params.id
const {title,description,duration} = request.body
await database.update(videoId,{
title,
description,
duration,
})
return reply.status(204).send()
})
server.delete('/videos/:id',async (request, reply) =>{
const videoId = request.params.id
await database.delete(videoId)
return reply.status(204).send()
})
server.listen({
port: process.env.PORT ?? 5000,
})