mirror of
				https://github.com/dani-garcia/vaultwarden.git
				synced 2025-10-25 02:41:13 +00:00 
			
		
		
		
	Show latest active device as last active on admin page
This commit is contained in:
		
					parent
					
						
							
								9824d94a1c
							
						
					
				
			
			
				commit
				
					
						1eb5495802
					
				
			
		
					 4 changed files with 25 additions and 0 deletions
				
			
		|  | @ -297,6 +297,11 @@ fn users_overview(_token: AdminToken, conn: DbConn) -> ApiResult<Html<String>> { | |||
|             usr["cipher_count"] = json!(Cipher::count_owned_by_user(&u.uuid, &conn)); | ||||
|             usr["attachment_count"] = json!(Attachment::count_by_user(&u.uuid, &conn)); | ||||
|             usr["attachment_size"] = json!(get_display_size(Attachment::size_by_user(&u.uuid, &conn) as i32)); | ||||
|             usr["created_at"] = json!(&u.created_at.format("%Y-%m-%d %H:%M:%S").to_string()); | ||||
|             usr["last_active"] = match u.last_active(&conn) { | ||||
|                 Some(timestamp) => json!(timestamp.format("%Y-%m-%d %H:%M:%S").to_string()), | ||||
|                 None => json!("Never") | ||||
|             }; | ||||
|             usr | ||||
|     }).collect(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -178,4 +178,15 @@ impl Device { | |||
|                 .from_db() | ||||
|         }} | ||||
|     } | ||||
| 
 | ||||
|     pub fn find_latest_active_by_user(user_uuid: &str, conn: &DbConn) -> Option<Self> { | ||||
|         db_run! { conn: { | ||||
|             devices::table | ||||
|                 .filter(devices::user_uuid.eq(user_uuid)) | ||||
|                 .order(devices::updated_at.desc()) | ||||
|                 .first::<DeviceDb>(conn) | ||||
|                 .ok() | ||||
|                 .from_db() | ||||
|         }} | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -288,6 +288,13 @@ impl User { | |||
|             users::table.load::<UserDb>(conn).expect("Error loading users").from_db() | ||||
|         }} | ||||
|     } | ||||
| 
 | ||||
|     pub fn last_active(&self, conn: &DbConn) -> Option<NaiveDateTime> { | ||||
|         match Device::find_latest_active_by_user(&self.uuid, conn) { | ||||
|             Some(device) => Some(device.updated_at), | ||||
|             None => None | ||||
|         }        
 | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| impl Invitation { | ||||
|  |  | |||
|  | @ -21,6 +21,8 @@ | |||
|                             <div class="float-left"> | ||||
|                                 <strong>{{Name}}</strong> | ||||
|                                 <span class="d-block">{{Email}}</span> | ||||
|                                 <span class="d-block">Created at: {{created_at}}</span> | ||||
|                                 <span class="d-block">Last active: {{last_active}}</span> | ||||
|                                 <span class="d-block"> | ||||
|                                     {{#if TwoFactorEnabled}} | ||||
|                                         <span class="badge badge-success mr-2" title="2FA is enabled">2FA</span> | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue