File size: 1,006 Bytes
a85305f |
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 |
import { promises as fs } from "node:fs"
type GoodWordsDB = Record<string, Record<string, string[]>>
// import ngrams from "talisman/tokenizers/ngrams"
let db: GoodWordsDB = {}
export let goodWords: Set<string> = new Set()
export let goodWordsList: string[] = []
export const getGoodWords = async () => {
if (!Object.entries(db)) {
const dbFileContent = await fs.readFile("./data/good_words.json", "utf8")
db = JSON.parse(dbFileContent) as GoodWordsDB
// we don't want those categories to be part of the acceptable, fair use words
const unwantedCategories = {
celeb: true
} as Record<string, boolean>
for (const [category, words] of Object.entries(db)) {
if (unwantedCategories[category]) {
continue
}
for (const word in words) {
const normalizedWord = word.trim().toLowerCase()
goodWords.add(normalizedWord)
goodWordsList.push(normalizedWord)
}
}
}
return { db, goodWords, goodWordsList }
} |