40 lines
1.6 KiB
JavaScript
40 lines
1.6 KiB
JavaScript
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);
|
|
};
|