HOLD - feat(rooms): add granular visibility & access control modes (replacing private & locked)
- The corresponding server changes (server#212) are also required for this to function.
- This MR is based upon !5282 -- that MR should go in before this one
This merge request serves as both a proposal and implementation of a visibility & access control modes (lists) feature to replace the existing private/locked room functionality.
Proposal
Background
- After the whitelist change was implemented (!5281 (merged)), which involved the debated decision to allow admins & whitelisted players to view the room (bypassing private), a discussion sparked revolving around that change.
- It became clear that there were users who wanted both sets of functionality for equally valid reasons, and this is the solution that resulted from that: allowing a granular level of control of visibility & access to a room.
- Discussion primarily begins here, although there were previous short discussions around the topic.
Proposed Changes
- Replacing the existing private checkbox with a visibility mode selection, presently containing the following options:
- Public
- Admins + Whitelist
- Admins
- Unlisted
- Replacing the existing locked checkbox with an access mode selection, presently containing the following options:
- Public
- Admins + Whitelist
- Admins
Implementation Considerations
Deprecation of Private and Locked
- The
Private
andLocked
variables no longer exist on the client- The direct equivalent functionality is provided through
ChatRoomIsPrivate()
(has any form of visibility control, i.e. not public) andChatRoomIsLocked()
(has any form of access control, i.e. not public) - The additional functionality of
ChatRoom*CanSeeRoom()
andChatRoom*CanAccessRoom()
are added to check whether the Player, CurrentCharacter, or a given Character meets the conditions of the visibility/access roles respectively
- The direct equivalent functionality is provided through
- This will break mods that rely on this property being available for whatever reason
- Consideration was made to retain the
Private
andLocked
properties, pulling from and saving to theVisibility
andLocked
properties similar to how it's done in the server backward-compatability populations, but this introduces a lot of room for error and confusion, so was decided against.
Backward-Compatability
- The new client expects the
Visibility
andAccess
variables from the room data to be present, and does not utilizePrivate
andLocked
(ignores them), if they are present. - Backwards compatability for the transition period is handled server-side, by ensuring
Visibility
,Private
,Access
, andLocked
are cross-populated, and sending all 4 to the client. - More details on backward-compatability is present in the server PR.
Futureproofing
- The
Visibility
andAccess
lists are purposefully designed as a list of roles (All
,Admin
,Whitelist
currently), rather than explicit modes. - This should hopefully allow new combinations of roles with no changes to the server.
- This should hopefully allow the addition of future roles with very minimal changes to the server.
Important Notes
- The corresponding server changes (server#212) are also required for this to function.
- This MR is based upon !5282 -- that MR should go in before this one
- It is necessary that the implementation of whitelist bypassing Private be reverted ASAP, as it has caused unwanted behaviour for a subset of users. This PR would be the ideal way to do this (as it would make both sides happy), but as it's particularly large in scale, I've additionally created a simple set of PRs/MRs (!PENDING, server#212) to perform only that reversion -- the functionality in this MR should be the end goal, though.
- The pipeline fail is only for a styling issue from !5320 (merged), and is unrelated to this change.
Edited by lera