//  OpenVPN 3 Linux client -- Next generation OpenVPN client
//
//  SPDX-License-Identifier: AGPL-3.0-only
//
//  Copyright (C) 2017 - 2023  OpenVPN Inc <sales@openvpn.net>
//  Copyright (C) 2017 - 2023  David Sommerseth <davids@openvpn.net>
//

/**
 * @file   getlastlogevent.cpp
 *
 * @brief  Simple unit test, testing OpenVPN3SessionProxy::GetLastLogEvent()
 */

#include <iostream>

#include "sessionmgr/proxy-sessionmgr.hpp"



int main(int argc, char **argv)
{
    if (argc != 2)
    {
        std::cout << "Usage: " << argv[0] << " <session object path>" << std::endl;
        return 1;
    }

    try
    {
        std::string session_path(argv[1]);
        OpenVPN3SessionProxy session(G_BUS_TYPE_SYSTEM, session_path);
        LogEvent log = session.GetLastLogEvent();

        std::cout << "LogEvent: " << log << std::endl;
        std::cout << "     Log Group: ["
                  << std::to_string((unsigned int)log.group)
                  << "] " << std::endl;
        std::cout << "  Log Category: ["
                  << std::to_string((unsigned int)log.category)
                  << "] " << std::endl;
        std::cout << "   Log message: "
                  << "[len: " << log.message.size()
                  << "] " << log.message
                  << std::endl;
        return 0;
    }
    catch (std::exception &err)
    {
        std::cout << "** ERROR ** " << err.what() << std::endl;
        return 2;
    }
}
