forked from bankless-academy/bankless-academy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathimport-poaps.js
84 lines (81 loc) · 2.85 KB
/
import-poaps.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/* eslint-disable no-console */
const knex = require('knex')
const fs = require('fs')
const path = require('path')
const config = require('./knexfile.js')
const db = knex(config)
const { TABLES } = require('./db.js')
const POAPS_DIR = 'poaps'
const CLAIM_LINK = 'http://POAP.xyz/claim/'
const args = process.argv
const MAX_IN_DB = args[2] ? args[2] : 200
fs.promises
.readdir(POAPS_DIR)
.then(async (files) => {
const promises_files = files.map(async (file) => {
if (path.extname(file) == '.txt') {
const fileName = path.parse(file).name
const poapEventId = fileName.includes('#') ? fileName.split('_')[0].split('#')[1] : fileName
const insert = []
const data = await fs.promises.readFile(POAPS_DIR + '/' + file, 'utf8')
// let nb_already_in = 0
const existing_codes = await db(TABLES.poaps)
.select('code')
.where('event_id', poapEventId)
const existing_codes_array = existing_codes.map((v) => v.code)
const data_array = data.split('\n')
const [remaining_poaps] = await db(TABLES.poaps)
.count('is_claimed')
.where('is_claimed', false)
.where('event_id', poapEventId)
const nb_remaining = parseInt(remaining_poaps.count)
let nb_added = 0
let nb_left = 0
data_array
.filter((v) => v !== '')
.map((code) => {
if (code.includes(CLAIM_LINK)) {
const clean_code = code.replace(new RegExp(CLAIM_LINK, 'gi'), '')
if (existing_codes_array.includes(clean_code)) {
// nb_already_in++
} else {
// limit the number of POAPs to add
if (nb_added + nb_remaining < MAX_IN_DB) {
insert.push({
event_id: poapEventId,
code: clean_code,
})
nb_added++
} else {
nb_left++
}
}
}
return
})
// console.log(insert)
// if (nb_already_in > 0)
// console.log(`${nb_already_in} codes already in ${poapEventId}`)
console.log(`[${nb_left}] codes remaining in file for ${poapEventId}`)
await db(TABLES.poaps)
.insert(insert)
.then((res) => {
console.log(`${res.rowCount}/${nb_remaining + nb_added} new codes added to ${poapEventId}`)
})
.catch((error) => {
if (error.constraint === 'poaps_code_unique') {
console.error('code already added')
}
})
if (insert.length === 0) {
console.log(`${nb_remaining} codes remaining in DB for ${poapEventId}`)
}
console.log('----')
}
})
await Promise.all(promises_files)
process.exit()
})
.catch((err) => {
console.error(err)
})