const axios = require("axios"); const logger = require('../utils/logger.js'); // Consulta o endereço completo usando a API externa de CEP const getConsultaCep = async (rawCep, rawNumero) => { logger.info('Iniciando consulta de CEP', { cep: rawCep, numero: rawNumero }); if (!rawCep) { logger.warn('CEP não fornecido para getConsultaCep'); throw new Error("cep é obrigatório"); } const cep = String(rawCep).trim().replace(/\D/g, ""); if (cep.length !== 8) { logger.warn('CEP inválido fornecido para getConsultaCep', { cepBruto: rawCep, cepLimpo: cep }); throw new Error("cep inválido, verifique se foram digitados apenas números"); } // Número é opcional na consulta, mas se fornecido, deve ser uma string limpa const numero = rawNumero ? String(rawNumero).trim() : ""; try { const cepRestUrl = 'https://api.cep.rest/'; logger.info('Consultando API de CEP', { url: cepRestUrl, cep }); const address = await axios.post(cepRestUrl, { cep }); if (address.data && address.data.code === 404) { logger.warn('CEP não encontrado na API externa', { cep, response: address.data }); return null; // Controller tratará como 'Endereço não encontrado' } else if (address.data && address.data.code) { logger.error('API de CEP retornou um código de erro', { cep, response: address.data }); throw new Error("Erro ao consultar o CEP na API externa"); } else { if (numero) address.data.numero = numero; logger.info('Endereço obtido com sucesso da API de CEP', { response: address.data }); return address.data; } } catch (error) { logger.error("Erro na chamada da API de CEP", { message: error.message, stack: error.stack, cep }); throw new Error("Erro ao consultar o CEP"); } }; 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. */