Exemplo — API REST + PostgreSQL
Uma API REST com cara de produção usando Express, PostgreSQL e tratamento adequado de erros.
Estrutura do projeto
my-api/
├── index.js
├── package.json
└── .gitignoreCódigo
package.json
{
"name": "my-api",
"version": "1.0.0",
"scripts": {
"start": "node index.js"
},
"dependencies": {
"express": "^4.18.0",
"pg": "^8.11.0"
}
}index.js
const express = require('express');
const { Pool } = require('pg');
const app = express();
app.use(express.json());
// Conexão com o banco
const pool = new Pool({
connectionString: process.env.DATABASE_URL,
ssl: { rejectUnauthorized: false },
});
// Cria tabelas na inicialização
async function initDB() {
await pool.query(`
CREATE TABLE IF NOT EXISTS users (
id SERIAL PRIMARY KEY,
name TEXT NOT NULL,
email TEXT UNIQUE NOT NULL,
created_at TIMESTAMP DEFAULT NOW()
)
`);
}
initDB();
// Rotas
app.get('/users', async (req, res) => {
const { rows } = await pool.query('SELECT * FROM users ORDER BY created_at DESC');
res.json(rows);
});
app.get('/users/:id', async (req, res) => {
const { rows } = await pool.query('SELECT * FROM users WHERE id = $1', [req.params.id]);
if (rows.length === 0) return res.status(404).json({ error: 'User not found' });
res.json(rows[0]);
});
app.post('/users', async (req, res) => {
const { name, email } = req.body;
if (!name || !email) return res.status(400).json({ error: 'Name and email required' });
const { rows } = await pool.query(
'INSERT INTO users (name, email) VALUES ($1, $2) RETURNING *',
[name, email]
);
res.status(201).json(rows[0]);
});
app.delete('/users/:id', async (req, res) => {
const { rowCount } = await pool.query('DELETE FROM users WHERE id = $1', [req.params.id]);
if (rowCount === 0) return res.status(404).json({ error: 'User not found' });
res.json({ message: 'Deleted' });
});
// Health check
app.get('/health', (req, res) => res.json({ status: 'ok' }));
const PORT = process.env.PORT || 3000;
app.listen(PORT, '0.0.0.0', () => {
console.log(`API running on port ${PORT}`);
});Configuração no console
Configure a aplicação no console com origem GitHub e a variável DATABASE_URL.
Publicação
- Envie o código para um repositório GitHub.
- No console, escolha Origem de Projeto como Repositório GitHub.
- Selecione a branch principal e crie o projeto.
- Faça push para atualizar a instância automaticamente.
Teste
Use a URL do projeto em *.clients.zenifra.com para testar as rotas /users.
Respostas esperadas
// POST /users → 201
{ "id": 1, "name": "Alice", "email": "[email protected]", "created_at": "2026-04-30T14:00:00.000Z" }
// GET /users → 200
[ { "id": 1, "name": "Alice", "email": "[email protected]", "created_at": "2026-04-30T14:00:00.000Z" } ]
// GET /users/999 → 404
{ "error": "User not found" }