Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

MSC4151: Reporting rooms (Client-Server API) #4151

Merged
merged 5 commits into from
Jun 24, 2024
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
117 changes: 117 additions & 0 deletions proposals/4151-report-room.md
Copy link
Member Author

@turt2live turt2live Jun 5, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Implementation requirements:

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Out of curiosity, why is a client using this endpoint not deemed as a requirement?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Typically it would be. Client implementation is meant to show two things:

  1. Clients want the feature being described.
  2. Clients can incorporate the feature into their project.

The first is satisfied outside of any client's control: legal requirements for some app stores and geographic regions require such an endpoint. This isn't really described in the MSC, but probably should be. Essentially, users must be given a way to report all kinds of content, including rooms.

The second is not a perceived risk for this MSC, so is not a strong implementation requirement.

Copy link
Contributor

@Gnuxie Gnuxie Jun 5, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There might not be a perceived risk that a client cannot implement the MSC, but there is a risk that implementation leads to the discovery of issues. This is kind of exacerbated for this MSC though, because receiving a report (for events too) is not specified and that is UX that critically would need to be considered alongside this MSC (and already has been in part by the discussion on how to handle reason). I do not think this particular MSC should be held back though as it already is late, but something probably should be done to follow up.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yea, for clarity: everything surrounding handling reports, including informing the reporter of action taken and estimates for resolution, are being handled in a different MSC series. It's expected that those MSCs will be opened soon, though are still being drafted as we speak.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

(the above is noted by 7aafad3 ftr)

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I agree the endpoint's similarity to event ID reporting means requiring a client impl is probably overkill here, but for future reference, I definitely think we need to call out explicitly where and why we're skipping it. We can't just arbitrarily decide to ignore our own rules.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Original file line number Diff line number Diff line change
@@ -0,0 +1,117 @@
# MSC4151: Reporting rooms (Client-Server API)

The specification [already contains](https://spec.matrix.org/v1.10/client-server-api/#reporting-content)
a module for being able to report events, though this functionality does not extend to rooms. Being
able to report rooms is important for user safety: clients have room directories, invite lists,
links to rooms, etc which all don't have an event ID to reference. If the client has *any* event ID
for the room, it can use the existing 'report event' API to report the room instead. However, this
only works if the user has visibility on the event ID being reported too.

These constraints are in addition to the legal obligations of clients to provide a safe user experience.
In some countries, such as the UK, it is required that users be able to report *any* kind of content
they see, and some app stores require similar reporting functionality for mobile apps. These obligations
impose further obligations not discussed in this proposal. For example, actually handling the reports
and informing the reporter how long it will take to process their request. These obligations are
expected to be discussed in a future, larger, MSC series which revamps reporting in Matrix.

This proposal introduces an endpoint for reporting rooms, expanding the capabilities of the reporting
module. The scope of this proposal is intentionally narrow to ensure quick traversal of the MSC process.
Other, future, MSCs may further expand the suite of endpoints available to clients (like reporting
users, media, etc).

## Proposal

Taking inspiration from [`POST /rooms/:roomId/report/:eventId`](https://spec.matrix.org/v1.10/client-server-api/#post_matrixclientv3roomsroomidreporteventid),
a new endpoint is introduced:

```
POST /_matrix/client/v3/rooms/:roomId/report
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't want to bikeshed too much, but should this be v1? Could be a bit hard since it is a subpath of a previous path.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I debated this while writing the MSC, and could be easily convinced either way. The only rationale I have for using v3 is that the endpoint it is modeled on is v3, so it'd indeed be confusing to have this be v1.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't have a strong opinion. I think we've defaulted to v1 in the past but don't have an example.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The media /create API is probably the closest example for a new endpoint within an existing module - it used v1 while the existing endpoints were v3.

I'm fine either way - if folks +1 (or +0.1) this thread, I'll move it to v1.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think I'd lean towards v3 as an extension of an existing endpoint. If others feel strongly, speak up!

{
"reason": "<user-supplied, optional>"
}
```

`reason` is a human-readable string describing the reason for the report. The string may be blank,
but *must* be provided (to align with `/report/:eventId`).

**Note**: `score` is not carried over from `/report/:eventId` because it has not proven useful. A
future MSC may introduce it.

There are no restictions on who can report a room: knowing the room ID is sufficient. This is to
ensure that results from the room directory, invites, links, etc can all be reported. If the room
does not exist on the server, the endpoint returns `404 M_NOT_FOUND`. Otherwise, `200` with `{}` as
turt2live marked this conversation as resolved.
Show resolved Hide resolved
a response body.

Like `/report/:eventId`, handling of the report is left as a deliberate implementation detail.

## Safety considerations

* Server admins may be exposed to harmful content through `reason`. This is an existing issue with
the reporting module, and difficult to fix. Applications which expose report reasons of any kind
are encouraged to place disclosures in the user experience path. For example, a page explaining
that the tool may contain harmful content before allowing the user temporary access, or the use of
spoiler tags on report reasons/content.

* Clients should hide rooms the user reports by default to both discourage duplicate reports and to
turt2live marked this conversation as resolved.
Show resolved Hide resolved
remove the harmful content from the user's view, where possible. This may require filtering room
directory responses and room lists for the user, or an "ignore room API" like [MSC3840](https://github.com/matrix-org/matrix-doc/pull/3840).

If the user is joined to a room, the client may wish to offer the user an option to leave the room.

* Users may report whole rooms instead of events in that room, particularly during a harmful content
spam wave. Administrators and safety teams should be cautious to avoid shutting down or banning
whole rooms, as the room may be legitimate otherwise. Automated decision making is not suggested
for a similar reason.

* 'Report flooding' is more easily possible with this new endpoint, where many users report a room
with the hope of getting it shut down/banned. Mentioned a few times in this proposal, automated
decision making is not recommended for this endpoint to prevent consequences like this from
happening.

## Potential issues

* Within the Trust & Safety environment, it is well known that `reason` alone is insufficient for an
informed report. Self-triage categories and mandatory `reason` for some of those categories help
improve a safety team's ability to handle a report. These features are not included in this proposal
as they require further thought and consideration - a future MSC may expand (or even deprecate) the
report endpoints to support this added information.

* Reports are not federated. This is considered an issue for another MSC, like [MSC3843](https://github.com/matrix-org/matrix-spec-proposals/pull/3843).

* Whether the local server is participating in a room is revealed through the new endpoint. The endpoint
is only available to local users however, and other ways of finding out the same information may
already be possible in Matrix (not verified). It is not immediately clear that disclosing this
information to local clients would cause harm to the server or its users. A future reporting over
federation proposal may wish to consider hiding the server's participation state, however.

## Alternatives

* Mentioned in the introduction, if a client has an event ID for something in the room, it can typically
use the existing event report endpoint to report the room. For example, using the creation event,
the user's own join event, or the most recent message in the room. This only works if the user is
able to see that event in the room, and further only if the client even has an event ID. Areas of
the client like the room directory do not expose an event ID the client could use. If they did, the
user may not have sufficient visibility on the event to be able to report it.

* The event report API could be relaxed to support an empty string for the event ID, though this feels
effectively like a new endpoint anyways. This MSC introduces such an endpoint.

* The event report API's history visibility check could also be removed, though, as per
[MSC2249](https://github.com/matrix-org/matrix-spec-proposals/blob/main/proposals/2249-report-require-joined.md),
this is intentional behaviour.

## Security considerations

* Rate limiting is strongly recommended for this new endpoint.
turt2live marked this conversation as resolved.
Show resolved Hide resolved

* Authentication is required for this new endpoint.

## Unstable prefix

While this proposal is not considered stable, implementations should use `/_matrix/client/unstable/org.matrix.msc4151/rooms/:roomId/report`
instead. Clients should note the [`M_UNRECOGNIZED` behaviour](https://spec.matrix.org/v1.10/client-server-api/#common-error-codes)
for servers which do not support the (un)stable endpoint.

## Dependencies

This MSC has no direct dependencies.