micro365/src/checkAndPublish.mjs

43 lines
1.3 KiB
JavaScript
Raw Normal View History

2023-08-11 15:38:02 +00:00
import getNewPrompt from "./getNewPrompt.mjs"
import createNote from "./createNote.mjs"
import makeText from "./makeText.mjs"
import insertPublished from "./insertPublished.mjs"
import logger from "./logger.mjs"
import todaysPromptAlreadyPublished from "./todaysPromptAlreadyPublished.mjs"
2023-08-12 09:43:37 +00:00
2023-08-11 15:38:02 +00:00
export default async function checkAndPublish () {
logger.trace("checkAndPublish called")
logger.trace(todaysPromptAlreadyPublished())
if(!await todaysPromptAlreadyPublished()){
try {
2023-08-12 09:43:37 +00:00
const prompt = await getNewPrompt()
2023-08-11 15:38:02 +00:00
try {
const text = makeText(prompt)
try {
const note = await createNote(text)
try {
await insertPublished(note, prompt.word)
} catch (error) {
logger.error(error, 'insertPublished failed!')
}
} catch (error) {
logger.error(error, 'createNote failed!')
}
} catch (error) {
logger.error(error, 'makeText failed!')
}
} catch (error) {
logger.error(error,'getNewPrompt failed!')
}
} else {
logger.trace("today's prompt has already been published")
}
}