mirror of
https://git.anonymousland.org/anonymousland/synapse.git
synced 2024-10-01 11:49:51 -04:00
support change_password in capabilities end-point
This commit is contained in:
parent
4eeb2fb215
commit
f03b3a7a3a
@ -12,14 +12,20 @@
|
|||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
# See the License for the specific language governing permissions and
|
# See the License for the specific language governing permissions and
|
||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
import logging
|
||||||
|
|
||||||
from twisted.internet import defer
|
from twisted.internet import defer
|
||||||
|
|
||||||
from synapse.http.servlet import RestServlet
|
from synapse.http.servlet import RestServlet
|
||||||
|
|
||||||
from ._base import client_v2_patterns
|
from ._base import client_v2_patterns
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
class CapabilitiesRestServlet(RestServlet):
|
class CapabilitiesRestServlet(RestServlet):
|
||||||
|
"""End point to expose the capabilities of the server."""
|
||||||
|
|
||||||
PATTERNS = client_v2_patterns("/capabilities$")
|
PATTERNS = client_v2_patterns("/capabilities$")
|
||||||
|
|
||||||
def __init__(self, hs):
|
def __init__(self, hs):
|
||||||
@ -30,11 +36,14 @@ class CapabilitiesRestServlet(RestServlet):
|
|||||||
super(CapabilitiesRestServlet, self).__init__()
|
super(CapabilitiesRestServlet, self).__init__()
|
||||||
self.hs = hs
|
self.hs = hs
|
||||||
self.auth = hs.get_auth()
|
self.auth = hs.get_auth()
|
||||||
|
self.store = hs.get_datastore()
|
||||||
|
|
||||||
@defer.inlineCallbacks
|
@defer.inlineCallbacks
|
||||||
def on_GET(self, request):
|
def on_GET(self, request):
|
||||||
|
requester = yield self.auth.get_user_by_req(request, allow_guest=True)
|
||||||
|
user = yield self.store.get_user_by_id(requester.user.to_string())
|
||||||
|
change_password = bool(user['password_hash'])
|
||||||
|
|
||||||
yield self.auth.get_user_by_req(request, allow_guest=True)
|
|
||||||
defer.returnValue(
|
defer.returnValue(
|
||||||
(200, {
|
(200, {
|
||||||
"capabilities": {
|
"capabilities": {
|
||||||
@ -45,7 +54,8 @@ class CapabilitiesRestServlet(RestServlet):
|
|||||||
"2": "stable",
|
"2": "stable",
|
||||||
"state-v2-test": "unstable",
|
"state-v2-test": "unstable",
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
|
"m.change_password": change_password,
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
|
@ -31,6 +31,7 @@ class CapabilitiesTestCase(unittest.HomeserverTestCase):
|
|||||||
def make_homeserver(self, reactor, clock):
|
def make_homeserver(self, reactor, clock):
|
||||||
self.url = b"/_matrix/client/r0/capabilities"
|
self.url = b"/_matrix/client/r0/capabilities"
|
||||||
hs = self.setup_test_homeserver()
|
hs = self.setup_test_homeserver()
|
||||||
|
self.store = hs.get_datastore()
|
||||||
return hs
|
return hs
|
||||||
|
|
||||||
def test_check_auth_required(self):
|
def test_check_auth_required(self):
|
||||||
@ -53,3 +54,25 @@ class CapabilitiesTestCase(unittest.HomeserverTestCase):
|
|||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
DEFAULT_ROOM_VERSION, capabilities['m.room_versions']['default']
|
DEFAULT_ROOM_VERSION, capabilities['m.room_versions']['default']
|
||||||
)
|
)
|
||||||
|
|
||||||
|
def test_get_change_password_capabilities(self):
|
||||||
|
localpart = "user"
|
||||||
|
password = "pass"
|
||||||
|
user = self.register_user(localpart, password)
|
||||||
|
access_token = self.login(user, password)
|
||||||
|
|
||||||
|
request, channel = self.make_request("GET", self.url, access_token=access_token)
|
||||||
|
self.render(request)
|
||||||
|
capabilities = channel.json_body['capabilities']
|
||||||
|
|
||||||
|
self.assertEqual(channel.code, 200)
|
||||||
|
|
||||||
|
# Test case where password is handled outside of Synapse
|
||||||
|
self.assertTrue(capabilities['m.change_password'])
|
||||||
|
self.get_success(self.store.user_set_password_hash(user, None))
|
||||||
|
request, channel = self.make_request("GET", self.url, access_token=access_token)
|
||||||
|
self.render(request)
|
||||||
|
capabilities = channel.json_body['capabilities']
|
||||||
|
|
||||||
|
self.assertEqual(channel.code, 200)
|
||||||
|
self.assertFalse(capabilities['m.change_password'])
|
||||||
|
Loading…
Reference in New Issue
Block a user