aboutsummaryrefslogtreecommitdiff
path: root/src/server/game/Server/Protocol/PacketLog.h
blob: 585609a46acd68b597aa79a73e1ff9acbad87fdb (plain)
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
/*
 * This file is part of the TrinityCore Project. See AUTHORS file for Copyright information
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License as published by the
 * Free Software Foundation; either version 2 of the License, or (at your
 * option) any later version.
 *
 * This program is distributed in the hope that 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/>.
 */

#ifndef TRINITY_PACKETLOG_H
#define TRINITY_PACKETLOG_H

#include "Common.h"
#include <mutex>

enum Direction
{
    CLIENT_TO_SERVER,
    SERVER_TO_CLIENT
};

class WorldPacket;
enum ConnectionType : int8;

namespace boost
{
    namespace asio
    {
        namespace ip
        {
            class address;
        }
    }
}

class TC_GAME_API PacketLog
{
    private:
        PacketLog();
        ~PacketLog();
        std::mutex _logPacketLock;
        std::once_flag _initializeFlag;

    public:
        PacketLog(PacketLog const&) = delete;
        PacketLog(PacketLog&&) = delete;
        PacketLog& operator=(PacketLog const&) = delete;
        PacketLog& operator=(PacketLog&&) = delete;

        static PacketLog* instance();

        void Initialize();
        bool CanLogPacket() const { return (_file != nullptr); }
        void LogPacket(WorldPacket const& packet, Direction direction, boost::asio::ip::address const& addr, uint16 port, ConnectionType connectionType);

    private:
        FILE* _file;
};

#define sPacketLog PacketLog::instance()
#endif