mirror of
https://github.com/simple-login/app.git
synced 2024-09-20 17:01:29 +02:00
make sure only verified mailbox can be used as default
This commit is contained in:
parent
19ac657c1c
commit
4b6368b378
@ -112,6 +112,13 @@ def update_mailbox(mailbox_id):
|
|||||||
if "default" in data:
|
if "default" in data:
|
||||||
is_default = data.get("default")
|
is_default = data.get("default")
|
||||||
if is_default:
|
if is_default:
|
||||||
|
if not mailbox.verified:
|
||||||
|
return (
|
||||||
|
jsonify(
|
||||||
|
error="Unverified mailbox cannot be used as default mailbox"
|
||||||
|
),
|
||||||
|
400,
|
||||||
|
)
|
||||||
user.default_mailbox_id = mailbox.id
|
user.default_mailbox_id = mailbox.id
|
||||||
changed = True
|
changed = True
|
||||||
|
|
||||||
|
@ -73,31 +73,33 @@ def test_delete_default_mailbox(flask_client):
|
|||||||
|
|
||||||
|
|
||||||
def test_set_mailbox_as_default(flask_client):
|
def test_set_mailbox_as_default(flask_client):
|
||||||
user = User.create(
|
user = login(flask_client)
|
||||||
email="a@b.c", password="password", name="Test User", activated=True
|
|
||||||
|
mb = Mailbox.create(
|
||||||
|
user_id=user.id, email="mb@gmail.com", verified=True, commit=True
|
||||||
)
|
)
|
||||||
db.session.commit()
|
|
||||||
|
|
||||||
# create api_key
|
|
||||||
api_key = ApiKey.create(user.id, "for test")
|
|
||||||
db.session.commit()
|
|
||||||
|
|
||||||
# create a mailbox
|
|
||||||
mb = Mailbox.create(user_id=user.id, email="mb@gmail.com")
|
|
||||||
db.session.commit()
|
|
||||||
assert user.default_mailbox_id != mb.id
|
assert user.default_mailbox_id != mb.id
|
||||||
|
|
||||||
r = flask_client.put(
|
r = flask_client.put(
|
||||||
f"/api/mailboxes/{mb.id}",
|
f"/api/mailboxes/{mb.id}",
|
||||||
headers={"Authentication": api_key.code},
|
|
||||||
json={"default": True},
|
json={"default": True},
|
||||||
)
|
)
|
||||||
|
|
||||||
assert r.status_code == 200
|
assert r.status_code == 200
|
||||||
|
|
||||||
mb = Mailbox.get(mb.id)
|
|
||||||
assert user.default_mailbox_id == mb.id
|
assert user.default_mailbox_id == mb.id
|
||||||
|
|
||||||
|
# <<< Cannot set an unverified mailbox as default >>>
|
||||||
|
mb.verified = False
|
||||||
|
db.session.commit()
|
||||||
|
|
||||||
|
r = flask_client.put(
|
||||||
|
f"/api/mailboxes/{mb.id}",
|
||||||
|
json={"default": True},
|
||||||
|
)
|
||||||
|
|
||||||
|
assert r.status_code == 400
|
||||||
|
assert r.json == {"error": "Unverified mailbox cannot be used as default mailbox"}
|
||||||
|
|
||||||
|
|
||||||
def test_update_mailbox_email(flask_client):
|
def test_update_mailbox_email(flask_client):
|
||||||
user = User.create(
|
user = User.create(
|
||||||
|
Loading…
Reference in New Issue
Block a user