|
18 | 18 | from typing import TYPE_CHECKING, Any, Optional, Tuple
|
19 | 19 |
|
20 | 20 | from synapse._pydantic_compat import BaseModel, StrictBool, StrictStr, root_validator
|
21 |
| -from synapse.api.errors import SynapseError |
| 21 | +from synapse.api.errors import NotFoundError, SynapseError |
22 | 22 | from synapse.http.servlet import (
|
23 | 23 | parse_and_validate_json_object_from_request,
|
24 | 24 | parse_string,
|
@@ -78,6 +78,7 @@ def __init__(self, hs: "HomeServer"):
|
78 | 78 | self.registration_handler = hs.get_registration_handler()
|
79 | 79 | self.identity_handler = hs.get_identity_handler()
|
80 | 80 | self.auth_handler = hs.get_auth_handler()
|
| 81 | + self.profile_handler = hs.get_profile_handler() |
81 | 82 | self.clock = hs.get_clock()
|
82 | 83 | self.auth = hs.get_auth()
|
83 | 84 |
|
@@ -128,10 +129,21 @@ async def _async_render_POST(
|
128 | 129 | )
|
129 | 130 | else:
|
130 | 131 | created = False
|
| 132 | + requester = create_requester(user_id=user_id) |
131 | 133 | if body.unset_displayname:
|
132 |
| - await self.store.set_profile_displayname(user_id, None) |
| 134 | + await self.profile_handler.set_displayname( |
| 135 | + target_user=user_id, |
| 136 | + requester=requester, |
| 137 | + new_displayname="", |
| 138 | + by_admin=True, |
| 139 | + ) |
133 | 140 | elif body.set_displayname is not None:
|
134 |
| - await self.store.set_profile_displayname(user_id, body.set_displayname) |
| 141 | + await self.profile_handler.set_displayname( |
| 142 | + target_user=user_id, |
| 143 | + requester=requester, |
| 144 | + new_displayname=body.set_displayname, |
| 145 | + by_admin=True, |
| 146 | + ) |
135 | 147 |
|
136 | 148 | new_email_list: Optional[set[str]] = None
|
137 | 149 | if body.unset_emails:
|
@@ -225,3 +237,113 @@ async def _async_render_POST(
|
225 | 237 | )
|
226 | 238 |
|
227 | 239 | return HTTPStatus.OK, {}
|
| 240 | + |
| 241 | + |
| 242 | +class MasReactivateUserResource(MasBaseResource): |
| 243 | + def __init__(self, hs: "HomeServer"): |
| 244 | + MasBaseResource.__init__(self, hs) |
| 245 | + |
| 246 | + self.deactivate_account_handler = hs.get_deactivate_account_handler() |
| 247 | + |
| 248 | + class PostBody(BaseModel): |
| 249 | + localpart: StrictStr |
| 250 | + |
| 251 | + async def _async_render_POST( |
| 252 | + self, request: "SynapseRequest" |
| 253 | + ) -> Tuple[int, JsonDict]: |
| 254 | + self.assert_mas_request(request) |
| 255 | + |
| 256 | + body = parse_and_validate_json_object_from_request(request, self.PostBody) |
| 257 | + user_id = UserID(body.localpart, self.hostname) |
| 258 | + |
| 259 | + await self.deactivate_account_handler.activate_account( |
| 260 | + user_id=user_id.to_string(), |
| 261 | + ) |
| 262 | + |
| 263 | + return HTTPStatus.OK, {} |
| 264 | + |
| 265 | + |
| 266 | +class MasSetDisplayNameResource(MasBaseResource): |
| 267 | + def __init__(self, hs: "HomeServer"): |
| 268 | + MasBaseResource.__init__(self, hs) |
| 269 | + |
| 270 | + self.profile_handler = hs.get_profile_handler() |
| 271 | + |
| 272 | + class PostBody(BaseModel): |
| 273 | + localpart: StrictStr |
| 274 | + displayname: StrictStr |
| 275 | + |
| 276 | + async def _async_render_POST( |
| 277 | + self, request: "SynapseRequest" |
| 278 | + ) -> Tuple[int, JsonDict]: |
| 279 | + self.assert_mas_request(request) |
| 280 | + |
| 281 | + body = parse_and_validate_json_object_from_request(request, self.PostBody) |
| 282 | + user_id = UserID(body.localpart, self.hostname) |
| 283 | + requester = create_requester(user_id=user_id) |
| 284 | + |
| 285 | + await self.profile_handler.set_displayname( |
| 286 | + target_user=user_id, |
| 287 | + requester=requester, |
| 288 | + new_displayname=body.displayname, |
| 289 | + ) |
| 290 | + |
| 291 | + return HTTPStatus.OK, {} |
| 292 | + |
| 293 | + |
| 294 | +class MasUnsetDisplayNameResource(MasBaseResource): |
| 295 | + def __init__(self, hs: "HomeServer"): |
| 296 | + MasBaseResource.__init__(self, hs) |
| 297 | + |
| 298 | + self.profile_handler = hs.get_profile_handler() |
| 299 | + |
| 300 | + class PostBody(BaseModel): |
| 301 | + localpart: StrictStr |
| 302 | + |
| 303 | + async def _async_render_POST( |
| 304 | + self, request: "SynapseRequest" |
| 305 | + ) -> Tuple[int, JsonDict]: |
| 306 | + self.assert_mas_request(request) |
| 307 | + |
| 308 | + body = parse_and_validate_json_object_from_request(request, self.PostBody) |
| 309 | + user_id = UserID(body.localpart, self.hostname) |
| 310 | + requester = create_requester(user_id=user_id) |
| 311 | + |
| 312 | + await self.profile_handler.set_displayname( |
| 313 | + target_user=user_id, |
| 314 | + requester=requester, |
| 315 | + new_displayname="", |
| 316 | + ) |
| 317 | + |
| 318 | + return HTTPStatus.OK, {} |
| 319 | + |
| 320 | + |
| 321 | +class MasAllowCrossSigningResetResource(MasBaseResource): |
| 322 | + REPLACEMENT_PERIOD_MS = 10 * 60 * 1000 # 10 minutes |
| 323 | + |
| 324 | + def __init__(self, hs: "HomeServer"): |
| 325 | + MasBaseResource.__init__(self, hs) |
| 326 | + |
| 327 | + class PostBody(BaseModel): |
| 328 | + localpart: StrictStr |
| 329 | + password: StrictStr |
| 330 | + |
| 331 | + async def _async_render_POST( |
| 332 | + self, request: "SynapseRequest" |
| 333 | + ) -> Tuple[int, JsonDict]: |
| 334 | + self.assert_mas_request(request) |
| 335 | + |
| 336 | + body = parse_and_validate_json_object_from_request(request, self.PostBody) |
| 337 | + user_id = UserID(body.localpart, self.hostname) |
| 338 | + |
| 339 | + timestamp = ( |
| 340 | + await self.store.allow_master_cross_signing_key_replacement_without_uia( |
| 341 | + user_id=str(user_id), |
| 342 | + duration_ms=self.REPLACEMENT_PERIOD_MS, |
| 343 | + ) |
| 344 | + ) |
| 345 | + |
| 346 | + if timestamp is None: |
| 347 | + raise NotFoundError("User has no master cross-signing key") |
| 348 | + |
| 349 | + return HTTPStatus.OK, {} |
0 commit comments