Newer
Older
Twilight / src / main / kotlin / net / taehui / twilight / QwilightLogging.kt
@Taehui Taehui on 6 Nov 1 KB 2023-11-06 오후 7:15
package net.taehui.twilight

import jakarta.mail.*
import jakarta.mail.internet.InternetAddress
import jakarta.mail.internet.MimeMessage
import net.taehui.twilight.system.Configure
import org.slf4j.LoggerFactory
import java.util.*

class QwilightLogging(private val loggerID: String) : Logger {
    override fun logInfo(toNotify: String) {
        LoggerFactory.getLogger(javaClass).info("[{}] {}", loggerID, toNotify)
        logFuture {
            Transport.send(MimeMessage(Session.getDefaultInstance(Properties().apply {
                put("mail.smtp.host", "localhost")
            }, object : Authenticator() {
                override fun getPasswordAuthentication(): PasswordAuthentication {
                    return PasswordAuthentication(Configure.fax.avatar, Configure.fax.auth)
                }
            })).apply {
                setFrom(InternetAddress("Qwilight"))
                addRecipient(
                    Message.RecipientType.TO,
                    InternetAddress(Configure.fax.remote)
                )
                subject = loggerID
                setText(toNotify)
            })
        }
    }

    override fun logFault(e: Throwable) {
        LoggerFactory.getLogger(javaClass).error("[{}] {}", loggerID, Utility.getFault(e))
    }
}