mirror of
				https://github.com/dani-garcia/vaultwarden.git
				synced 2025-10-26 07:50:02 +02:00 
			
		
		
		
	Updated Organizations overview
- Changed HTML to match users overview - Added User count - Added Org cipher amount - Added Attachment count and size
This commit is contained in:
		| @@ -15,6 +15,7 @@ use crate::config::ConfigBuilder; | ||||
| use crate::db::{backup_database, models::*, DbConn}; | ||||
| use crate::error::Error; | ||||
| use crate::mail; | ||||
| use crate::util::get_display_size; | ||||
| use crate::CONFIG; | ||||
|  | ||||
| pub fn routes() -> Vec<Route> { | ||||
| @@ -253,8 +254,6 @@ fn get_users_json(_token: AdminToken, conn: DbConn) -> JsonResult { | ||||
|  | ||||
| #[get("/users/overview")] | ||||
| fn users_overview(_token: AdminToken, conn: DbConn) -> ApiResult<Html<String>> { | ||||
|     use crate::util::get_display_size; | ||||
|  | ||||
|     let users = User::get_all(&conn); | ||||
|     let users_json: Vec<Value> = users.iter() | ||||
|     .map(|u| { | ||||
| @@ -312,7 +311,14 @@ fn update_revision_users(_token: AdminToken, conn: DbConn) -> EmptyResult { | ||||
| #[get("/organizations/overview")] | ||||
| fn organizations_overview(_token: AdminToken, conn: DbConn) -> ApiResult<Html<String>> { | ||||
|     let organizations = Organization::get_all(&conn); | ||||
|     let organizations_json: Vec<Value> = organizations.iter().map(|o| o.to_json()).collect(); | ||||
|     let organizations_json: Vec<Value> = organizations.iter().map(|o| { | ||||
|         let mut org = o.to_json(); | ||||
|         org["user_count"] = json!(UserOrganization::count_by_org(&o.uuid, &conn)); | ||||
|         org["cipher_count"] = json!(Cipher::count_by_org(&o.uuid, &conn)); | ||||
|         org["attachment_count"] = json!(Attachment::count_by_org(&o.uuid, &conn)); | ||||
|         org["attachment_size"] = json!(get_display_size(Attachment::size_by_org(&o.uuid, &conn) as i32)); | ||||
|         org | ||||
|     }).collect(); | ||||
|  | ||||
|     let text = AdminTemplateData::organizations(organizations_json).render()?; | ||||
|     Ok(Html(text)) | ||||
|   | ||||
| @@ -150,4 +150,14 @@ impl Attachment { | ||||
|  | ||||
|         result.unwrap_or(0) | ||||
|     } | ||||
|  | ||||
|     pub fn count_by_org(org_uuid: &str, conn: &DbConn) -> i64 { | ||||
|         attachments::table | ||||
|             .left_join(ciphers::table.on(ciphers::uuid.eq(attachments::cipher_uuid))) | ||||
|             .filter(ciphers::organization_uuid.eq(org_uuid)) | ||||
|             .count() | ||||
|             .first(&**conn) | ||||
|             .ok() | ||||
|             .unwrap_or(0) | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -370,6 +370,15 @@ impl Cipher { | ||||
|             .load::<Self>(&**conn).expect("Error loading ciphers") | ||||
|     } | ||||
|  | ||||
|     pub fn count_by_org(org_uuid: &str, conn: &DbConn) -> i64 { | ||||
|         ciphers::table | ||||
|             .filter(ciphers::organization_uuid.eq(org_uuid)) | ||||
|             .count() | ||||
|             .first::<i64>(&**conn) | ||||
|             .ok() | ||||
|             .unwrap_or(0) | ||||
|     } | ||||
|  | ||||
|     pub fn find_by_folder(folder_uuid: &str, conn: &DbConn) -> Vec<Self> { | ||||
|         folders_ciphers::table.inner_join(ciphers::table) | ||||
|             .filter(folders_ciphers::folder_uuid.eq(folder_uuid)) | ||||
|   | ||||
| @@ -437,6 +437,15 @@ impl UserOrganization { | ||||
|             .expect("Error loading user organizations") | ||||
|     } | ||||
|  | ||||
|     pub fn count_by_org(org_uuid: &str, conn: &DbConn) -> i64 { | ||||
|         users_organizations::table | ||||
|             .filter(users_organizations::org_uuid.eq(org_uuid)) | ||||
|             .count() | ||||
|             .first::<i64>(&**conn) | ||||
|             .ok() | ||||
|             .unwrap_or(0) | ||||
|     } | ||||
|  | ||||
|     pub fn find_by_org_and_type(org_uuid: &str, atype: i32, conn: &DbConn) -> Vec<Self> { | ||||
|         users_organizations::table | ||||
|             .filter(users_organizations::org_uuid.eq(org_uuid)) | ||||
|   | ||||
| @@ -2,24 +2,45 @@ | ||||
|     <div id="organizations-block" class="my-3 p-3 bg-white rounded shadow"> | ||||
|         <h6 class="border-bottom pb-2 mb-0">Organizations</h6> | ||||
|  | ||||
|         <div id="organizations-list"> | ||||
|         <div class="table-responsive-xl small"> | ||||
|             <table class="table table-sm table-striped table-hover"> | ||||
|                 <thead> | ||||
|                     <tr> | ||||
|                         <th style="width: 24px;" colspan="2">Organization</th> | ||||
|                         <th>Users</th> | ||||
|                         <th>Items</th> | ||||
|                         <th>Attachments</th> | ||||
|                     </tr> | ||||
|                 </thead> | ||||
|                 <tbody> | ||||
|                     {{#each organizations}} | ||||
|             <div class="media pt-3"> | ||||
|                 <img class="mr-2 rounded identicon" data-src="{{Name}}_{{BillingEmail}}"> | ||||
|                 <div class="media-body pb-3 mb-0 small border-bottom"> | ||||
|                     <div class="row justify-content-between"> | ||||
|                         <div class="col"> | ||||
|                     <tr> | ||||
|                         <td><img class="rounded identicon" data-src="{{Id}}"></td> | ||||
|                         <td> | ||||
|                             <strong>{{Name}}</strong> | ||||
|                             {{#if Id}} | ||||
|                             <span class="badge badge-success ml-2">{{Id}}</span> | ||||
|                             <span class="mr-2">({{BillingEmail}})</span> | ||||
|                             <span class="d-block"> | ||||
|                                 <span class="badge badge-success">{{Id}}</span> | ||||
|                             </span> | ||||
|                         </td> | ||||
|                         <td> | ||||
|                             <span class="d-block">{{user_count}}</span> | ||||
|                         </td> | ||||
|                         <td> | ||||
|                             <span class="d-block">{{cipher_count}}</span> | ||||
|                         </td> | ||||
|                         <td> | ||||
|                             <span class="d-block"><strong>Amount:</strong> {{attachment_count}}</span> | ||||
|                             {{#if attachment_count}} | ||||
|                             <span class="d-block"><strong>Size:</strong> {{attachment_size}}</span> | ||||
|                             {{/if}} | ||||
|                             <span class="d-block">{{BillingEmail}}</span> | ||||
|                         </div> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             </div> | ||||
|                         </td> | ||||
|                     </tr> | ||||
|                     {{/each}} | ||||
|                 </tbody> | ||||
|             </table> | ||||
|         </div> | ||||
|          | ||||
|     </div> | ||||
| </main> | ||||
|  | ||||
|   | ||||
| @@ -2,8 +2,6 @@ | ||||
|     <div id="users-block" class="my-3 p-3 bg-white rounded shadow"> | ||||
|         <h6 class="border-bottom pb-2 mb-0">Registered Users</h6> | ||||
|  | ||||
|  | ||||
|  | ||||
|         <div class="table-responsive-xl small"> | ||||
|             <table class="table table-sm table-striped table-hover"> | ||||
|                 <thead> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user