/*
 * Copyright (c) 2018-2020 Atmosphère-NX
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms and conditions of the GNU General Public License,
 * version 2, as published by the Free Software Foundation.
 *
 * This program is distributed in the hope it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
 * more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
#include <stratosphere.hpp>
#include "../amsmitm_fs_utils.hpp"
#include "dnsmitm_debug.hpp"

namespace ams::mitm::socket::resolver {

    namespace {

        constinit os::SdkMutex g_log_mutex;
        constinit bool     g_log_enabled;

        constinit ::FsFile g_log_file;
        constinit s64      g_log_ofs;


        constinit char g_log_buf[0x400];

    }

    void InitializeDebug(bool enable_log) {
        {
            std::scoped_lock lk(g_log_mutex);

            g_log_enabled = enable_log;

            if (g_log_enabled) {
                /* Create the logs directory. */
                mitm::fs::CreateAtmosphereSdDirectory("/logs");

                /* Create the log file. */
                mitm::fs::CreateAtmosphereSdFile("/logs/dns_mitm_debug.log", 0, ams::fs::CreateOption_None);

                /* Open the log file. */
                R_ABORT_UNLESS(mitm::fs::OpenAtmosphereSdFile(std::addressof(g_log_file), "/logs/dns_mitm_debug.log", ams::fs::OpenMode_ReadWrite | ams::fs::OpenMode_AllowAppend));

                /* Get the current log offset. */
                R_ABORT_UNLESS(::fsFileGetSize(std::addressof(g_log_file), std::addressof(g_log_ofs)));
            }
        }

        /* Start a new log. */
        LogDebug("\n---\n");
    }

    void LogDebug(const char *fmt, ...) {
        std::scoped_lock lk(g_log_mutex);

        if (g_log_enabled) {
            int len = 0;
            {
                std::va_list vl;
                va_start(vl, fmt);
                len = util::VSNPrintf(g_log_buf, sizeof(g_log_buf), fmt, vl);
                va_end(vl);
            }

            R_ABORT_UNLESS(::fsFileWrite(std::addressof(g_log_file), g_log_ofs, g_log_buf, len, FsWriteOption_Flush));
            g_log_ofs += len;
        }
    }

}