mirror of
https://gitlab.archlinux.org/archlinux/aurweb.git
synced 2025-02-03 10:43:03 +01:00
add authenticated User LangPreference tracking
+ Use User.LangPreference when there is no set AURSID if request.user.is_authenticated is true. + Updated post /language to update LangPreference when request.user.is_authenticated. + Restore language during test where we change it. + Added the user attribute to aurweb.testing.requests.Request. Signed-off-by: Kevin Morris <kevr@0cost.org>
This commit is contained in:
parent
a33d076d8b
commit
9fdbe3f775
5 changed files with 59 additions and 14 deletions
|
@ -64,8 +64,10 @@ translator = Translator()
|
|||
|
||||
|
||||
def get_request_language(request: Request):
|
||||
return request.cookies.get("AURLANG",
|
||||
aurweb.config.get("options", "default_lang"))
|
||||
if request.user.is_authenticated():
|
||||
return request.user.LangPreference
|
||||
default_lang = aurweb.config.get("options", "default_lang")
|
||||
return request.cookies.get("AURLANG", default_lang)
|
||||
|
||||
|
||||
def get_raw_translator_for_request(request: Request):
|
||||
|
@ -77,12 +79,6 @@ def get_translator_for_request(request: Request):
|
|||
"""
|
||||
Determine the preferred language from a FastAPI request object and build a
|
||||
translator function for it.
|
||||
|
||||
Example:
|
||||
```python
|
||||
_ = get_translator_for_request(request)
|
||||
print(_("Hello"))
|
||||
```
|
||||
"""
|
||||
lang = get_request_language(request)
|
||||
|
||||
|
|
|
@ -24,12 +24,14 @@ async def language(request: Request,
|
|||
set_lang: str = Form(...),
|
||||
next: str = Form(...),
|
||||
q: str = Form(default=None)):
|
||||
""" A POST route used to set a session's language.
|
||||
"""
|
||||
A POST route used to set a session's language.
|
||||
|
||||
Return a 303 See Other redirect to {next}?next={next}. If we are
|
||||
setting the language on any page, we want to preserve query
|
||||
parameters across the redirect.
|
||||
"""
|
||||
from aurweb.db import session
|
||||
from aurweb.asgi import routes
|
||||
if unquote(next) not in routes:
|
||||
return HTMLResponse(
|
||||
|
@ -37,6 +39,13 @@ async def language(request: Request,
|
|||
status_code=400)
|
||||
|
||||
query_string = "?" + q if q else str()
|
||||
|
||||
# If the user is authenticated, update the user's LangPreference.
|
||||
if request.user.is_authenticated():
|
||||
request.user.LangPreference = set_lang
|
||||
session.commit()
|
||||
|
||||
# In any case, set the response's AURLANG cookie that never expires.
|
||||
response = RedirectResponse(url=f"{next}{query_string}",
|
||||
status_code=int(HTTPStatus.SEE_OTHER))
|
||||
response.set_cookie("AURLANG", set_lang)
|
||||
|
|
|
@ -1,8 +1,27 @@
|
|||
import aurweb.config
|
||||
|
||||
|
||||
class User:
|
||||
""" A fake User model. """
|
||||
# Fake columns.
|
||||
LangPreference = aurweb.config.get("options", "default_lang")
|
||||
|
||||
# A fake authenticated flag.
|
||||
authenticated = False
|
||||
|
||||
def is_authenticated(self):
|
||||
return self.authenticated
|
||||
|
||||
|
||||
class Client:
|
||||
""" A fake FastAPI Request.client object. """
|
||||
# A fake host.
|
||||
host = "127.0.0.1"
|
||||
|
||||
|
||||
class Request:
|
||||
""" A fake Request object which mimics a FastAPI Request for tests. """
|
||||
client = Client()
|
||||
cookies = dict()
|
||||
headers = dict()
|
||||
user = User()
|
||||
|
|
|
@ -54,7 +54,7 @@ def test_get_passreset():
|
|||
|
||||
|
||||
def test_get_passreset_translation():
|
||||
# Test that translation works.
|
||||
# Test that translation works; set it to de.
|
||||
with client as request:
|
||||
response = request.get("/passreset", cookies={"AURLANG": "de"})
|
||||
|
||||
|
@ -68,6 +68,10 @@ def test_get_passreset_translation():
|
|||
# And the button.
|
||||
assert "Weiter".encode("utf-8") in response.content
|
||||
|
||||
# Restore english.
|
||||
with client as request:
|
||||
response = request.get("/passreset", cookies={"AURLANG": "en"})
|
||||
|
||||
|
||||
def test_get_passreset_with_resetkey():
|
||||
with client as request:
|
||||
|
|
|
@ -10,13 +10,14 @@ from aurweb.asgi import app
|
|||
from aurweb.db import query
|
||||
from aurweb.models.account_type import AccountType
|
||||
from aurweb.testing import setup_test_db
|
||||
from aurweb.testing.models import make_user
|
||||
from aurweb.testing.requests import Request
|
||||
|
||||
client = TestClient(app)
|
||||
|
||||
user = None
|
||||
|
||||
|
||||
@pytest.fixture
|
||||
@pytest.fixture(autouse=True)
|
||||
def setup():
|
||||
global user
|
||||
|
||||
|
@ -46,7 +47,7 @@ def test_favicon():
|
|||
|
||||
|
||||
def test_language():
|
||||
""" Test the language post route at '/language'. """
|
||||
""" Test the language post route as a guest user. """
|
||||
post_data = {
|
||||
"set_lang": "de",
|
||||
"next": "/"
|
||||
|
@ -67,6 +68,23 @@ def test_language_invalid_next():
|
|||
assert response.status_code == int(HTTPStatus.BAD_REQUEST)
|
||||
|
||||
|
||||
def test_user_language():
|
||||
""" Test the language post route as an authenticated user. """
|
||||
post_data = {
|
||||
"set_lang": "de",
|
||||
"next": "/"
|
||||
}
|
||||
|
||||
sid = user.login(Request(), "testPassword")
|
||||
assert sid is not None
|
||||
|
||||
with client as req:
|
||||
response = req.post("/language", data=post_data,
|
||||
cookies={"AURSID": sid})
|
||||
assert response.status_code == int(HTTPStatus.SEE_OTHER)
|
||||
assert user.LangPreference == "de"
|
||||
|
||||
|
||||
def test_language_query_params():
|
||||
""" Test the language post route with query params. """
|
||||
next = urllib.parse.quote_plus("/")
|
||||
|
@ -87,4 +105,3 @@ def test_error_messages():
|
|||
response2 = client.get("/raisefivethree")
|
||||
assert response1.status_code == int(HTTPStatus.NOT_FOUND)
|
||||
assert response2.status_code == int(HTTPStatus.SERVICE_UNAVAILABLE)
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue