Browse Source
- The new web-vault v2.21.0+ has support for Master Password Reset. For this to work it generates a public/private key-pair which needs to be stored in the database. Currently the Master Password Reset is not fixed, but there are endpoints which are needed even if we do not support this feature (yet). This PR fixes those endpoints, and stores the keys already in the database. - There was an issue when you want to do a key-rotate when you change your password, it also called an Emergency Access endpoint, which we do not yet support. Because this endpoint failed to reply correctly produced some errors, and also prevent the user from being forced to logout. This resolves #1826 by adding at least that endpoint. Because of that extra endpoint check to Emergency Access is done using an old user stamp, i also modified the stamp exception to allow multiple rocket routes to be called, and added an expiration timestamp to it. During these tests i stumbled upon an issue that after my key-change was done, it triggered the websockets to try and reload my ciphers, because they were updated. This shouldn't happen when rotating they keys, since all access should be invalided. Now there will be no websocket notification for this, which also prevents error toasts. - Increased Send Size limit to 500MB (with a litle overhead) As a side note, i tested these changes on both v2.20.4 and v2.21.1 web-vault versions, all keeps working.pull/1829/head
BlackDex
4 years ago
18 changed files with 147 additions and 33 deletions
@ -0,0 +1,5 @@ |
|||
ALTER TABLE organizations |
|||
ADD COLUMN private_key TEXT; |
|||
|
|||
ALTER TABLE organizations |
|||
ADD COLUMN public_key TEXT; |
@ -0,0 +1,5 @@ |
|||
ALTER TABLE organizations |
|||
ADD COLUMN private_key TEXT; |
|||
|
|||
ALTER TABLE organizations |
|||
ADD COLUMN public_key TEXT; |
@ -0,0 +1,5 @@ |
|||
ALTER TABLE organizations |
|||
ADD COLUMN private_key TEXT; |
|||
|
|||
ALTER TABLE organizations |
|||
ADD COLUMN public_key TEXT; |
@ -0,0 +1,24 @@ |
|||
use rocket::Route; |
|||
use rocket_contrib::json::Json; |
|||
|
|||
use crate::{api::JsonResult, auth::Headers, db::DbConn}; |
|||
|
|||
pub fn routes() -> Vec<Route> { |
|||
routes![get_contacts,] |
|||
} |
|||
|
|||
/// This endpoint is expected to return at least something.
|
|||
/// If we return an error message that will trigger error toasts for the user.
|
|||
/// To prevent this we just return an empty json result with no Data.
|
|||
/// When this feature is going to be implemented it also needs to return this empty Data
|
|||
/// instead of throwing an error/4XX unless it really is an error.
|
|||
#[get("/emergency-access/trusted")] |
|||
fn get_contacts(_headers: Headers, _conn: DbConn) -> JsonResult { |
|||
debug!("Emergency access is not supported."); |
|||
|
|||
Ok(Json(json!({ |
|||
"Data": [], |
|||
"Object": "list", |
|||
"ContinuationToken": null |
|||
}))) |
|||
} |
Loading…
Reference in new issue