2024-10-21 10:57:00 +02:00
# Changelog
2024-10-21 10:25:14 +02:00
2024-10-21 10:57:00 +02:00
All notable changes to this project will be documented in this file.
2024-10-21 10:25:14 +02:00
2024-10-21 10:57:00 +02:00
The format is based on [Keep a Changelog ](https://keepachangelog.com/en/1.0.0/ ), and this project adheres to [Semantic Versioning ](https://semver.org/ ).
2024-10-21 10:25:14 +02:00
2024-10-21 10:57:00 +02:00
## [0.1.3] - 2024-10-21
2024-10-21 10:54:09 +02:00
2024-10-21 10:57:00 +02:00
### Added
2024-10-21 10:54:09 +02:00
2024-10-21 10:57:00 +02:00
- **Configurable Profanity Threshold**:
- The threshold value for determining profanity (`0.5`) is now sourced from the configuration (`profanity_threshold`) with a default value of `0.5` .
- Allows customization of the profanity filter sensitivity.
2024-10-21 10:54:09 +02:00
2024-10-21 10:57:00 +02:00
- **Configurable Regular Expression for Profanity Detection**:
- The `PROFANITY_REGEX` pattern is now sourced from the configuration (`profanity_regex`).
- The default value is set to the provided regular expression.
- Enables customization or expansion of profanity filtering rules.
2024-10-21 10:54:09 +02:00
2024-10-21 10:57:00 +02:00
### Changed
2024-10-21 10:54:09 +02:00
2024-10-21 10:57:00 +02:00
- **Updated `ProfanityChecker` and `ChatEventHandler` **:
- Modified to utilize the new configuration settings.
- Enhanced the flexibility and configurability of the mod.
2024-10-21 10:54:09 +02:00
2024-10-21 10:31:59 +02:00
## [0.1.2] - 2024-10-21
2024-10-21 10:57:00 +02:00
### Changed
2024-10-21 10:31:59 +02:00
2024-10-21 10:57:00 +02:00
- **Mod Name**:
- Renamed the mod from `Chatit` to `ChatIT` for consistency and improved branding.
2024-10-21 10:31:59 +02:00
## [0.1.1] - 2024-10-21
2024-10-21 10:25:14 +02:00
2024-10-21 10:57:00 +02:00
### Changed
2024-10-21 10:25:14 +02:00
2024-10-21 10:57:00 +02:00
- **Fixed Player Level Retrieval Method**:
- Wrapped `receiver.level()` and `sender.level()` in a `try-with-resources` block to ensure proper resource management and eliminate errors.
2024-10-21 10:25:14 +02:00
2024-10-21 10:57:00 +02:00
- **Prefix Formatting**:
- Removed bold formatting (`ChatFormatting.BOLD`) from the prefixes `[G]` , `[L]` , and `[ERROR]` . Now, the letters `G` , `L` , and `ERROR` are displayed without bold styling while retaining their color highlights.
2024-10-21 10:25:14 +02:00
2024-10-21 10:57:00 +02:00
- **Clean Code**:
- Removed all comments from the code to enhance readability and maintainability.
2024-10-21 10:25:14 +02:00
2024-10-21 10:31:59 +02:00
## [0.1.0] - 2024-10-21
2024-10-21 10:25:14 +02:00
2024-10-21 10:57:00 +02:00
### Added
- **Local and Global Chat**:
- Messages starting with `!` are broadcasted globally to all players.
- Messages without `!` are sent locally to players within a 50-block radius.
- **Message Prefixes**:
- `[G]` for global messages, where `G` is lime-colored.
- `[L]` for local messages, where `L` is yellow-colored.
- `[ERROR]` for error messages, where `ERROR` is red-colored.
- **Profanity Filtering**:
- Integrated with an external API to check messages for profanity.
- Asynchronous message checking to prevent blocking the main server thread.
- Added a `regex` setting to use regular expressions when the API is unavailable.
- **Adult Parameter for Players**:
- `/chatit adult` command to toggle the `adult` parameter for players.
- Player settings are saved to `config/chatit_player_settings.json` .
- Default `adult` value for new players is set in the configuration (`default_adult`).
- **Message Filtering Based on `adult` Parameter**:
- If the sender's `adult` is off and the message contains profanity, the message is blocked and only sent to the sender with the `[ERROR]` prefix.
- Players with `adult` off do not see profanity messages from other players.
- Players with `adult` on can send and receive profanity messages.
- **Configuration File**:
- Created `config/chatit.toml` with the following settings:
- `host_api` : URL of the API for profanity checking.
- `default_adult` : Default `adult` value for new players (true/false).
- `regex` : Use regular expressions when the API is unavailable (true/false).
- **Asynchronous Processing**:
- Interactions with the API are handled asynchronously using `CompletableFuture` .
- Prevents blocking the main server thread during message checks.
- **Error Handling**:
- When the API is unavailable and `regex=true` , regular expressions are used for profanity detection.
- On encountering errors, an error message is sent only to the sender.
- **Message Formatting**:
- Prefixes `[G]` , `[L]` , `[ERROR]` are displayed with proper formatting.
- Letters `G` , `L` , and the word `ERROR` are colored appropriately.
### Changed
- **Code Optimization**:
- Moved message handling to an asynchronous thread to improve performance.
- Enhanced code structure for better readability and maintainability.
- **Bug Fixes**:
- Removed warnings and errors related to deprecated methods.
- Fixed issues with multithreading and accessing game objects.