/* * This file is part of the AzerothCore 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 Affero General Public License as published by the * Free Software Foundation; either version 3 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 Affero 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 . */ #ifndef Azeroth_AES_h__ #define Azeroth_AES_h__ #include "Define.h" #include #include namespace Acore::Crypto { class AC_COMMON_API AES { public: static constexpr std::size_t IV_SIZE_BYTES = 12; static constexpr std::size_t KEY_SIZE_BYTES = 16; static constexpr std::size_t TAG_SIZE_BYTES = 12; using IV = std::array; using Key = std::array; using Tag = uint8[TAG_SIZE_BYTES]; explicit AES(bool encrypting); ~AES(); void Init(Key const& key); bool Process(IV const& iv, uint8* data, std::size_t length, Tag& tag); private: EVP_CIPHER_CTX* _ctx; bool _encrypting; }; } #endif // Azeroth_AES_h__