import node_fetch from "cross-fetch"; import { respostaComuns } from "p-respostas"; import { z } from "zod"; import { urlPilao, z_tipo_coluna_base_dados, } from "./variaveis"; export const zp_registrar_base_dados = z.object({ tabela: z.string(), colunas: z.array(z.object({ coluna: z.string(), tipo: z_tipo_coluna_base_dados, })), }); //enviar registros para base de dados export const zp_enviar_registros = z.object({ tabela: z.string(), registros: z.array(z.record(z.string(), z.object({ valor: z.any(), tipo: z_tipo_coluna_base_dados.optional().nullable(), }))), }); export const enviar_registros = ({ conta, produto, emDesenvolvimento }) => async ({ registros, tabela, }) => { const url = new URL(`${urlPilao(emDesenvolvimento).api}/${Object.keys({ enviar_registros })[0]}/${produto}/${conta}`); const tamanhoBlocos = 1000; while (registros.length > 0) { const bloco = registros .splice(0, tamanhoBlocos) .map((r) => Object.fromEntries(Object.entries(r).map(([k, v]) => [k, v === undefined ? null : v]))); const resp = await node_fetch(url.toString(), { method: "POST", body: JSON.stringify({ tabela, registros: bloco }), headers: { "Content-Type": "application/json" }, }) .then((r) => r.json()) .catch((e) => respostaComuns.erro("Erro ao enviar registros", [e.message])) .then((r) => r); if (resp.eErro) { return resp; } } return respostaComuns.valor(true); };