Skip to content

HOLD - feat(rooms): add granular visibility & access control modes (replacing private & locked)

lera requested to merge lera/Bondage-College:feat/visibility-access-mode into master
  • 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 and Locked 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) and ChatRoomIsLocked() (has any form of access control, i.e. not public)
    • The additional functionality of ChatRoom*CanSeeRoom() and ChatRoom*CanAccessRoom() are added to check whether the Player, CurrentCharacter, or a given Character meets the conditions of the visibility/access roles respectively
  • This will break mods that rely on this property being available for whatever reason
  • Consideration was made to retain the Private and Locked properties, pulling from and saving to the Visibility and Locked 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 and Access variables from the room data to be present, and does not utilize Private and Locked (ignores them), if they are present.
  • Backwards compatability for the transition period is handled server-side, by ensuring Visibility, Private, Access, and Locked are cross-populated, and sending all 4 to the client.
  • More details on backward-compatability is present in the server PR.

Futureproofing

  • The Visibility and Access 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

Merge request reports

Loading