0
0
Fork 1
mirror of https://mau.dev/maunium/synapse.git synced 2025-01-02 08:33:53 +01:00
synapse/docs/admin_api/event_reports.md
Dirk Klimpel 93f7955eba
Admin API endpoint to delete a reported event (#15116)
* Admin api to delete event report

* lint +  tests

* newsfile

* Apply suggestions from code review

Co-authored-by: David Robertson <david.m.robertson1@gmail.com>

* revert changes - move to WorkerStore

* update unit test

* Note that timestamp is in millseconds

---------

Co-authored-by: David Robertson <david.m.robertson1@gmail.com>
2023-02-28 12:09:10 +00:00

6.5 KiB

Show reported events

This API returns information about reported events.

To use it, you will need to authenticate by providing an access_token for a server admin: see Admin API.

The api is:

GET /_synapse/admin/v1/event_reports?from=0&limit=10

It returns a JSON body like the following:

{
    "event_reports": [
        {
            "event_id": "$bNUFCwGzWca1meCGkjp-zwslF-GfVcXukvRLI1_FaVY",
            "id": 2,
            "reason": "foo",
            "score": -100,
            "received_ts": 1570897107409,
            "canonical_alias": "#alias1:matrix.org",
            "room_id": "!ERAgBpSOcCCuTJqQPk:matrix.org",
            "name": "Matrix HQ",
            "sender": "@foobar:matrix.org",
            "user_id": "@foo:matrix.org"
        },
        {
            "event_id": "$3IcdZsDaN_En-S1DF4EMCy3v4gNRKeOJs8W5qTOKj4I",
            "id": 3,
            "reason": "bar",
            "score": -100,
            "received_ts": 1598889612059,
            "canonical_alias": "#alias2:matrix.org",
            "room_id": "!eGvUQuTCkHGVwNMOjv:matrix.org",
            "name": "Your room name here",
            "sender": "@foobar:matrix.org",
            "user_id": "@bar:matrix.org"
        }
    ],
    "next_token": 2,
    "total": 4
}

To paginate, check for next_token and if present, call the endpoint again with from set to the value of next_token. This will return a new page.

If the endpoint does not return a next_token then there are no more reports to paginate through.

URL parameters:

  • limit: integer - Is optional but is used for pagination, denoting the maximum number of items to return in this call. Defaults to 100.
  • from: integer - Is optional but used for pagination, denoting the offset in the returned results. This should be treated as an opaque value and not explicitly set to anything other than the return value of next_token from a previous call. Defaults to 0.
  • dir: string - Direction of event report order. Whether to fetch the most recent first (b) or the oldest first (f). Defaults to b.
  • user_id: string - Is optional and filters to only return users with user IDs that contain this value. This is the user who reported the event and wrote the reason.
  • room_id: string - Is optional and filters to only return rooms with room IDs that contain this value.

Response

The following fields are returned in the JSON response body:

  • id: integer - ID of event report.
  • received_ts: integer - The timestamp (in milliseconds since the unix epoch) when this report was sent.
  • room_id: string - The ID of the room in which the event being reported is located.
  • name: string - The name of the room.
  • event_id: string - The ID of the reported event.
  • user_id: string - This is the user who reported the event and wrote the reason.
  • reason: string - Comment made by the user_id in this report. May be blank or null.
  • score: integer - Content is reported based upon a negative score, where -100 is "most offensive" and 0 is "inoffensive". May be null.
  • sender: string - This is the ID of the user who sent the original message/event that was reported.
  • canonical_alias: string - The canonical alias of the room. null if the room does not have a canonical alias set.
  • next_token: integer - Indication for pagination. See above.
  • total: integer - Total number of event reports related to the query (user_id and room_id).

Show details of a specific event report

This API returns information about a specific event report.

The api is:

GET /_synapse/admin/v1/event_reports/<report_id>

It returns a JSON body like the following:

{
    "event_id": "$bNUFCwGzWca1meCGkjp-zwslF-GfVcXukvRLI1_FaVY",
    "event_json": {
        "auth_events": [
            "$YK4arsKKcc0LRoe700pS8DSjOvUT4NDv0HfInlMFw2M",
            "$oggsNXxzPFRE3y53SUNd7nsj69-QzKv03a1RucHu-ws"
        ],
        "content": {
            "body": "matrix.org: This Week in Matrix",
            "format": "org.matrix.custom.html",
            "formatted_body": "<strong>matrix.org</strong>:<br><a href=\"https://matrix.org/blog/\"><strong>This Week in Matrix</strong></a>",
            "msgtype": "m.notice"
        },
        "depth": 546,
        "hashes": {
            "sha256": "xK1//xnmvHJIOvbgXlkI8eEqdvoMmihVDJ9J4SNlsAw"
        },
        "origin": "matrix.org",
        "origin_server_ts": 1592291711430,
        "prev_events": [
            "$YK4arsKKcc0LRoe700pS8DSjOvUT4NDv0HfInlMFw2M"
        ],
        "prev_state": [],
        "room_id": "!ERAgBpSOcCCuTJqQPk:matrix.org",
        "sender": "@foobar:matrix.org",
        "signatures": {
            "matrix.org": {
                "ed25519:a_JaEG": "cs+OUKW/iHx5pEidbWxh0UiNNHwe46Ai9LwNz+Ah16aWDNszVIe2gaAcVZfvNsBhakQTew51tlKmL2kspXk/Dg"
            }
        },
        "type": "m.room.message",
        "unsigned": {
            "age_ts": 1592291711430
        }
    },
    "id": <report_id>,
    "reason": "foo",
    "score": -100,
    "received_ts": 1570897107409,
    "canonical_alias": "#alias1:matrix.org",
    "room_id": "!ERAgBpSOcCCuTJqQPk:matrix.org",
    "name": "Matrix HQ",
    "sender": "@foobar:matrix.org",
    "user_id": "@foo:matrix.org"
}

URL parameters:

  • report_id: string - The ID of the event report.

Response

The following fields are returned in the JSON response body:

  • id: integer - ID of event report.
  • received_ts: integer - The timestamp (in milliseconds since the unix epoch) when this report was sent.
  • room_id: string - The ID of the room in which the event being reported is located.
  • name: string - The name of the room.
  • event_id: string - The ID of the reported event.
  • user_id: string - This is the user who reported the event and wrote the reason.
  • reason: string - Comment made by the user_id in this report. May be blank.
  • score: integer - Content is reported based upon a negative score, where -100 is "most offensive" and 0 is "inoffensive".
  • sender: string - This is the ID of the user who sent the original message/event that was reported.
  • canonical_alias: string - The canonical alias of the room. null if the room does not have a canonical alias set.
  • event_json: object - Details of the original event that was reported.

Delete a specific event report

This API deletes a specific event report. If the request is successful, the response body will be an empty JSON object.

The api is:

DELETE /_synapse/admin/v1/event_reports/<report_id>

URL parameters:

  • report_id: string - The ID of the event report.