Commit Graph

912 Commits

Author SHA1 Message Date
scatterflower
27e4bd8acc Add new tests 2022-07-07 11:08:52 -05:00
scatterflower
ca84b54597
Replace packet handler with templates (#300)
* Replace packet handler with templates

* Move all packet functions into classes

* Liberal use of Q_UNSUED

* Add correct argument count to packets

* Fix windows build issues

* Partially implement argument type validation
* Where applicable.
* Checking if we can convert from a string to a string would be useless

* Fix unit tests for AOPacket

Co-authored-by: scatterflower <marisa@scatterflower.online>
Co-authored-by: Salanto <62221668+Salanto@users.noreply.github.com>
2022-07-07 10:33:41 -05:00
scatterflower
66b58b77bf
Update README.md 2022-07-07 09:50:27 -05:00
scatterflower
f4fd19f02d
Add coverage build and CI (#311)
* add coverage build and CI

* fix project files

* upload to codecov

Co-authored-by: scatterflower <marisa@scatterflower.online>
2022-07-07 09:48:42 -05:00
cow-face
03ee9337d2
Help command aliases (#306)
* changes to help info loading

* updated sample help command config file

* updated test config file
2022-07-06 13:53:12 -05:00
scatterflower
9232b59e26 gitignore update 2022-07-06 13:40:39 -05:00
cow-face
9bba94fc93
Added dice notation to help command (#308)
* added dice notation to roll and rollp commands
2022-07-06 10:59:07 -05:00
Rosemary Witchaven
035ebd1a9f
Merge pull request #294 from AttorneyOnline/unittest-ConfigManager
[WIP] Unit test ConfigManager
2022-07-03 04:18:23 -05:00
Salanto
45b37e3fc8
Merge branch 'master' into unittest-ConfigManager 2022-06-30 13:18:01 -07:00
Salanto
ce629a3103 This may look stupid
* But you feel even more stupid when it could've been avoided by good config loading.
2022-06-30 22:17:31 +02:00
scatterflower
aece875362
Add more secure password hashing support (#293)
* Separate crypto operations into new class

* Implement PBKDF2 backend

* Add auto-update to stronger hashes

* clang-format pass

* documentation and cleanup

* Add unit tests for CryptoHelper

Co-authored-by: scatterflower <marisa@scatterflower.online>
2022-06-30 22:13:22 +02:00
Salanto
2953c7e2f5 Start testing ConfigManager 2022-06-29 19:57:36 +02:00
AwesomeAim
0234588007
Remove excessive spacing with /notecardreveal (#291) 2022-06-29 15:07:53 +02:00
AwesomeAim
6dfffe76f1 Improve feedback and behaviour from /uncm
allow multiple arguments (discarding the rest and using the first)
give the moderator feedback that they successfully unCMed someone rather than only telling the target
tell those without permission they lack it rather than saying the command is invalid, as that implied /uncm didn't exist
2022-06-29 05:43:55 -05:00
Salanto
22cfee962b
Add regression test to ACL ini handler (#281)
* Add QTest for issue validation

* Add file-existence check for test

* Update acl_roles_handler.cpp

* Appease clang

* Only look for unittest files

* Where art thou?

* Change root directory when running test

* Fix pathing on Windows CI

* Windows please just accept this path

* Too many CDs

* Bash is evil.

* Wildcard moment

* I swear to god Bill Gates why does your OS suck so much?

* Add cache, use working-directory

* Maybe? Maybe not? Who the fuck cares at this point

* Fix library path

Holy shit these tests almost work on Windows.

* FUCKING HELL

* Where art thou? 2nd Edition

* Edited wrong one

* Re-add execution code

* Remove Linux stuff

* Do it in batch

Bash is evil.

* Set to CMD

* I am now expected

* Missing libs

Should be good enough 🤷

* Powershell my beloved, save me

* Adjust pathing (again)

* Add some debug info

* Powershell syntax shenanigans

* I distrust Github Actions now

* I swear my windows is licensed, please work

* More debug info

* More debug

* For the love of all that is holy why the fuck do you not work

* Cheap path hack

* Upload test folder for debug

* Set Execution Policy<

Apparently tests on the Windows CI never worked???

* Remove debug information

* Does this even work? If not, fuck

* Try older Windows runner

* Comment out non-functional Windows QTest action

* Note that Linux is still functional, so QTest for Windows has to be conducted trough QtCreator till a solution is found.

* Unbreak-test

* Use latest runner version

Co-authored-by: TrickyLeifa <date.epoch@gmail.com>
2022-06-27 17:00:45 -05:00
Rosemary Witchaven
c559c8d205
Merge pull request #278 from AttorneyOnline/salanto-whyyyyyy
Fix new connected client not being a spectator
2022-06-23 15:44:46 -05:00
Salanto
cf009718c2 Fix new connected client not being a spectator 2022-06-23 18:52:21 +02:00
Salanto
1f23c1fdb8 Version bump to 1.7 2022-06-19 00:27:10 +02:00
Salanto
777132e698 Disable chat deskmod 2022-06-18 10:01:47 -05:00
Salanto
97528e641c Expand kick_other to consider the hwid 2022-06-17 22:49:24 -05:00
Salanto
c79cdf3a4c Don't run the disconnect routine twice, Salanto
I should not be allowed to code this late
2022-06-15 17:52:27 -05:00
Salanto
883ac90511 Fix segfault due to insufficient jukebox state validation. 2022-06-15 17:52:27 -05:00
Salanto
5e6bc5c87b Run disconnection routine when client is being destroyed 2022-06-15 17:52:27 -05:00
Salanto
5cea6674c9 Add jukebox skip command
* Prevents the jukebox being locked up by long playing songs without any way to skip it
2022-06-15 17:52:27 -05:00
Salanto
e80f452352 Fix empty IP on TCP connections
Dangerous oversight!
2022-06-15 17:52:27 -05:00
Salanto
6d848682f6 Remove unused include in AOClient 2022-06-15 17:52:27 -05:00
Salanto
164a1789d0 Add /kick_other command
* closes #239
2022-06-15 17:52:27 -05:00
Salanto
20be237daf Mark UserID free on regular disconnect
* Fixes userID inflation bug where it would incorrectly mark freed IDs as still used.
2022-06-15 17:52:27 -05:00
Salanto
d39f93926f Enable websocket port overwrite in advertiser
*Advertises port 80 if the AO Server is behind a reverse proxy, like cloudflare tunnels.
2022-06-15 17:52:27 -05:00
Salanto
bbd55263df Update configuration DB
This prevents a lockout scenario where the root user may be left without permissions if the DB was created prior to this PR.
2022-06-15 17:52:27 -05:00
Salanto
a2c769f173 Finish desturctor, fix localhost lookup 2022-06-15 17:52:27 -05:00
Salanto
a47e120ff4 Resolve parenting issues
This should FINALLY resolve the QIODevice errors as closing the socket now lets Qt handle all the network and socket state management.
2022-06-15 17:52:27 -05:00
Salanto
16955e9c16 Apply suggestion
* Put QSettings check in helper function
* Removed stray QDebug()
* Fixed wording on command message.
*Update commandhelp
2022-06-15 17:52:27 -05:00
Salanto
75472c6fad Consistent key/argument
* layout in command_extensions.ini
2022-06-15 17:52:27 -05:00
Salanto
d0c22ee879 Missed one
Co-authored-by: Rosemary Witchaven <32779090+in1tiate@users.noreply.github.com>
2022-06-15 17:52:27 -05:00
Salanto
9090d150b0 Batch commit spelling corrections
Co-authored-by: Rosemary Witchaven <32779090+in1tiate@users.noreply.github.com>
2022-06-15 17:52:27 -05:00
stonedDiscord
630776d5ba Delete userslennartappdatalocaltemptmpcdtybt 2022-06-15 17:52:27 -05:00
Salanto
c9818a137f Websockets refactor (#26)
* Implement NetworkSocket Thin-Proxy

Removes the need for the overengineered WS-Proxy
2022-06-15 17:52:27 -05:00
Salanto
c26319701e Rework AOPacket (#24) 2022-06-15 17:52:27 -05:00
Salanto
0d41a1e8bd Prevent double or invalid HWID/ID packet (#23) 2022-06-15 17:52:27 -05:00
Salanto
70b5212640 Add per area wtce and shout disable options (#22) 2022-06-15 17:52:27 -05:00
Salanto
d82e6b8e59 Disable music change for spectator (#21)
* Disable music change for spectator

* Appease clang-format

* Properly handle this bullshit.
2022-06-15 17:52:27 -05:00
Salanto
2073371d08 Merge upstream (#15)
* 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>
2022-06-15 17:52:27 -05:00
Salanto
97d9c1253b Add some visual flair to readme(#14)
* Visual update to readme

* Add all contributors to repo readme

* Minor formatting

* Use the right repo for "maintained"
2022-06-15 17:52:27 -05:00
Leifa♥
f307f728c9 Added command extension system (#12)
* 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
2022-06-15 17:52:27 -05:00
Salanto
ec44039816 Update CI with clang-format condition (#11)
* Update CI with clang-format condition

* Only run CI on either push to master or pull to master, not both
2022-06-15 17:52:27 -05:00
Leifa♥
e01f0e1c57 Changed message_floodguard logic and introduced global_message_floodguard (#8)
* 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.
2022-06-15 17:52:27 -05:00
Leifa♥
657a47b029 Added flexible ACL roles (#7)
Resolve #4
2022-06-15 17:52:27 -05:00
Leifa♥
b0555207d6 Privatization rework (#2)
* 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
2022-06-15 17:52:27 -05:00
Rosemary Witchaven
2e7ad02bc3
Merge pull request #269 from AttorneyOnline/remove-cross-area-pair
Fix paired player check behaviour
2022-05-29 13:02:56 -05:00