2025-11-12 11:13:39 -03:00
|
|
|
const axios = require("axios");
|
|
|
|
|
|
2025-11-18 08:26:50 -03:00
|
|
|
// Consulta o endereço completo usando a API externa de CEP
|
|
|
|
|
|
2025-11-14 08:16:04 -03:00
|
|
|
const getConsultaCep = async (rawCep, rawNumero) => {
|
|
|
|
|
if (!rawCep) {
|
|
|
|
|
throw new Error("cep é obrigatório");
|
|
|
|
|
}
|
2025-11-12 11:13:39 -03:00
|
|
|
const cep = String(rawCep).trim().replace(/\D/g, "");
|
2025-11-14 08:16:04 -03:00
|
|
|
if (cep.length !== 8) {
|
|
|
|
|
throw new Error("cep inválido, verifique se foram digitados apenas números");
|
|
|
|
|
}
|
2025-11-18 08:26:50 -03:00
|
|
|
|
|
|
|
|
// Número é opcional na consulta, mas se fornecido, deve ser uma string limpa
|
|
|
|
|
|
2025-11-12 11:13:39 -03:00
|
|
|
const numero = rawNumero ? String(rawNumero).trim() : "";
|
|
|
|
|
try {
|
|
|
|
|
const cepRestUrl = 'https://api.cep.rest/';
|
|
|
|
|
const address = await axios.post(cepRestUrl, { cep });
|
2025-11-14 08:16:04 -03:00
|
|
|
|
2025-11-12 11:13:39 -03:00
|
|
|
if (address.data && address.data.code === 404) {
|
2025-11-14 08:16:04 -03:00
|
|
|
return null; // Controller tratará como 'Endereço não encontrado'
|
2025-11-12 11:13:39 -03:00
|
|
|
} else if (address.data && address.data.code) {
|
2025-11-14 08:16:04 -03:00
|
|
|
throw new Error("Erro ao consultar o CEP na API externa");
|
2025-11-12 11:13:39 -03:00
|
|
|
} else {
|
|
|
|
|
if (numero) address.data.numero = numero;
|
2025-11-14 08:16:04 -03:00
|
|
|
return address.data;
|
2025-11-12 11:13:39 -03:00
|
|
|
}
|
|
|
|
|
} catch (error) {
|
|
|
|
|
console.error("Erro ao consultar o CEP:", error);
|
2025-11-14 08:16:04 -03:00
|
|
|
throw new Error("Erro ao consultar o CEP");
|
2025-11-12 11:13:39 -03:00
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
2025-11-24 10:59:46 -03:00
|
|
|
module.exports = { getConsultaCep };
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
DESCRIÇÃO:
|
|
|
|
|
Este arquivo define um serviço para consultar endereços a partir de um CEP.
|
|
|
|
|
|
|
|
|
|
FLUXO:
|
|
|
|
|
1. É chamado principalmente pelo `contratacao.service.js`.
|
|
|
|
|
2. Recebe um CEP e um número.
|
|
|
|
|
3. Formata e valida o CEP.
|
|
|
|
|
4. Realiza uma requisição POST para a API externa `https://api.cep.rest/`.
|
|
|
|
|
5. Trata a resposta da API:
|
|
|
|
|
- Se o CEP não for encontrado (código 404), retorna `null`.
|
|
|
|
|
- Se houver outro erro na API, lança uma exceção.
|
|
|
|
|
- Se for bem-sucedido, anexa o número ao objeto de dados e retorna os dados do endereço.
|
|
|
|
|
6. Em caso de erro na comunicação, loga o erro e lança uma exceção genérica.
|
|
|
|
|
|
|
|
|
|
Este serviço abstrai a complexidade da comunicação com a API de CEP, fornecendo uma interface simples para outras partes da aplicação obterem dados de endereço.
|
|
|
|
|
*/
|