From b3c56012e62b8ed1ebc55066c9a0cba2afdf3fb9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EA=A7=81Ash=C3=BB=EA=A7=82?= <30575805+Ashu11-A@users.noreply.github.com> Date: Wed, 10 Apr 2024 11:43:27 -0400 Subject: [PATCH] =?UTF-8?q?=F0=9F=90=9B=20Fix:=20merge=20link.json?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/start.ts | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/src/start.ts b/src/start.ts index 1c6e8a4..a79442a 100644 --- a/src/start.ts +++ b/src/start.ts @@ -29,6 +29,7 @@ interface LinkData { async function start() { const links: LinkData[] = [] + let linkData = JSON.parse(readFileSync('api/links.json', 'utf8')) as LinkData[] for (const { repository, branch } of repos) { const array = repository.split('/') @@ -40,7 +41,6 @@ async function start() { } const repoData = (await axios.get(`https://api.github.com/repos/${repository}`)).data - const linkData = JSON.parse(readFileSync('api/links.json', 'utf8')) as LinkData[] if (repoData.updated_at === linkData.find((element) => element.author === array[0])?.updated_at) { console.log('Repositorio sem alterações'); @@ -58,7 +58,7 @@ async function start() { author: array[0], link: `https://raw.githubusercontent.com/Ashu11-A/Eggs-Tracker/main/api/${array[0]}.min.json`, eggs: eggs.length, - updated_at: repoData.updated_at + updated_at: repoData?.updated_at }) } else { console.log(`Download do Repositorio ${repoName} não foi realizado!`) @@ -72,7 +72,18 @@ async function start() { }) } - writeFile('api/links.json', JSON.stringify(links, null, 2), {}, ((err) => { + // Sistema de mesclagem + for (const link of links) { + const index = linkData.findIndex((element) => element.author === link.author) + if (index !== -1) { + linkData[index] = link + continue + } + + linkData.push(link) + } + + writeFile('api/links.json', JSON.stringify(linkData, null, 2), {}, ((err) => { if (err) console.log('Ocorreu um erro ao salvar os Dados:', err) })) }