import 'dotenv/config' import 'https' import fs from 'fs' import pg from 'pg' const { Client } = pg const scryfallSets = await fetch('https://api.scryfall.com/sets'); console.log('Status Code:', scryfallSets.status); const sets = await scryfallSets.json(); // Read the data from the exported fr_cards.json extracted from Scryfall Bulk Data const fileBytes = fs.readFileSync(import.meta.dirname + '/data/fr_cards.json') let scryfallData = JSON.parse(fileBytes) // Connect to postgres database const client = new Client({ user: process.env.DATABASE_USER, password: process.env.DATABASE_PASSWORD, host: process.env.DATABASE_HOST, port: process.env.DATABASE_PORT, database: process.env.DATABASE_DB }) await client.connect() try { const setRes = await client.query('SELECT id FROM set') const preUpdateSetRows = setRes.rows let preUpdateSetIds = [] preUpdateSetRows.forEach(element => { preUpdateSetIds.push(element.id) }); for (const set of sets.data) { if(!preUpdateSetIds.includes(set.id)){ const addingSetQuery = await client.query('INSERT INTO set(id, name_en, code, set_type, released_at, icon_svg_uri) VALUES($1, $2, $3, $4, $5, $6)', [set.id, set.name, set.code, set.set_type, set.released_at, set.icon_svg_uri]) } } // Select already imported cards in database const cardsRes = await client.query('SELECT id FROM carte') const preUpdateCardsRows = cardsRes.rows let preUpdateCardsIds = [] preUpdateCardsRows.forEach(element => { preUpdateCardsIds.push(element.id) }); // Define counter for logging let total_no_fr_name = 0 let total_inserted = 0 let total_skipped = 0 // For each card check if we need to upload it to the database for (const carte of scryfallData) { if(!preUpdateCardsIds.includes(carte.id)){ if(carte.printed_name == undefined) { // If the card doesn't have a french name, print it to the console and skip //console.log("Erreur sur la carte : " + carte.name) //console.log("Scryfall URI : " + carte.scryfall_uri) //console.log("API URI : " + carte.uri) total_no_fr_name = total_no_fr_name + 1 continue } // Add the card to the database const addingCardsQuery = await client.query('INSERT INTO carte(id, name_en, name_fr, released_at, small_image, normal_image, mana_cost, cmc, type_line_en, type_line_fr, oracle_text_en, oracle_text_fr, power, toughness, colors, keywords, set_id, rarity, cardmarket_uri) VALUES($1, $2, $3, $4, $5, $6, $7, $8, $9, $10, $11, $12, $13, $14, $15, $16, $17, $18, $19)', [carte.id, carte.name, carte.printed_name, carte.released_at, carte.image_uris.small, carte.image_uris.normal, carte.mana_cost, carte.cmc, carte.type_line, carte.printed_type_line, carte.oracle_text, carte.printed_text, carte.power, carte.toughness, carte.colors, carte.keywords, carte.set_id, carte.rarity, carte.purchase_uris?.cardmarket]) total_inserted = total_inserted + 1 } else { total_skipped = total_skipped + 1 } } console.log("Un total de " + total_no_fr_name + " cartes n'ont pas de nom français.") console.log("Un total de " + total_inserted + " cartes ont été insérées.") console.log("Un total de " + total_skipped + " cartes ont été ignorées.") } catch (err) { console.error(err); } finally { await client.end() }