* Don't Display IPIDs to Users via Global Chat
Slightly better variable names too while we're at it
* Ensure /changepass always has arg 1 as the password
Otherwise, the syntax is /changepass <Password> or /changepass <Moderator> <Password>, rather than /changepass <Password> 'Moderator', like how it's specified to be
* All hail the mightly clang-format check
Co-authored-by: AwesomeAim <30537683+AwesomeAim@users.noreply.github.com>
Co-authored-by: Rosemary Witchaven <32779090+in1tiate@users.noreply.github.com>
* Added command extension system
Resolve#10
* Added akashi definitions
* Updated headers to comply to the standard
* Added full definition to argument
* Clang-format pass
* Missing header for GCC
* Missing header for GCC
* Move method implementation to source file
* Changed message_floodguard logic, ...
Resolve#3
The client individual client timer was ignored in favor of the area timer as it wouldn't make a lot of sense to have 3 different timers for game messages.
* Changed message_floodguard to only affect the area in which the message was sent rather than globally. The default value is 250ms.
* Added global_message_floodguard, this restores the previous functionality of message_floodguard. The default value is 0ms.
* Add clang-format
* Multiple privatization changes
"Participation handshake" this refers to the moment that the user's client sends the `askchaa` packet.
* Server::m_clients is now private. Get a copy with Server::getClients()
* Server::m_player_count is now private. Get a copy with Server::getPlayerCount() (Additional logic was added to handle the player count.)
* AOClient::m_joined is now private. Get a copy with AOClient::hasJoined()
* Added signal AOClient::joined(); will be emitted when the client first complete the participation handshake.
* Renamed Server::updatePlayerCount to Server::playerCountUpdated
* Privatized Server
* Made Server members private: m_characters, m_areas, m_area_names
* Added Server methods: getCharacters(), getAreas(), getAreaById(f_area_id), getAreaByName(f_area_name), getAreaNames(), getAreaName(f_area_id), getMusicList
* Added Server helper methods: getCharacterCount(), getAreaCount()
- This reduce code repetition of the following example: server->getCharacters().length(), server->getAreas().size()
* Solved other merge conflicts
* Added Server methods, various fixes
* Added Server methods: getCharacterById(f_chr_id)
* Various optimizations
* More Server privatization changes
* Made Server members private: db_manager, next_message_timer, can_send_ic_messages
* Renamed Server members:
* next_message_timer -> m_message_floodguard_timer
* can_send_ic_message -> m_can_send_ic_message
Added Server methods: getDatabaseManager, isMessageAllowed, startMessageFloodguard(f_duration)
Made Server methods private: allowMessage
* Added new fields to load for AreaData
* Added fields: `area_message` (default: empty string) and `send_area_message_on_join` (default: false)
* Added Server::clearAreaMessage
* Cleaned up headers include (AOPacket excluded)
* Removed most project file includes, moved to source file (cpp)
* AOPacket was excluded because some methods modify the copy
* Fix compile error when using MingW compiler
* Appease clang by using proper or and putting it in parentheses
* Remove extra semicolon
* Set default properly
If this slight hack is not done, Akashi may load an empty color code, causing Discord to reject the Webhook due to an empty value.
Otherwise, the syntax is /changepass <Password> or /changepass <Moderator> <Password>, rather than /changepass <Password> 'Moderator', like how it's specified to be
* Minr change to DB code, not fixed or tested yet
* Fix user deletion for good.
* Typo
* Add scoping
Code shamelessly stolen from Cerapter. Thanks for telling me how to scope.
Co-Authored-By: Cerapter <43446478+Cerapter@users.noreply.github.com>
Co-authored-by: Cerapter <43446478+Cerapter@users.noreply.github.com>
* Add SDESC packet
This packet allows servers to overwrite the server description, allowing them to display them even in the favourites menu.
* Un-Add SDESC and hijack PN to supply description