@ -748,8 +748,6 @@ struct GetOrgUserData {
include_groups : Option < bool > ,
include_groups : Option < bool > ,
}
}
// includeCollections
// includeGroups
#[ get( " /organizations/<org_id>/users?<data..> " ) ]
#[ get( " /organizations/<org_id>/users?<data..> " ) ]
async fn get_org_users (
async fn get_org_users (
data : GetOrgUserData ,
data : GetOrgUserData ,
@ -1229,14 +1227,25 @@ async fn _confirm_invite(
save_result
save_result
}
}
#[ get( " /organizations/<org_id>/users/<org_user_id> " ) ]
#[ get( " /organizations/<org_id>/users/<org_user_id>?<data..> " ) ]
async fn get_user ( org_id : String , org_user_id : String , _headers : AdminHeaders , mut conn : DbConn ) -> JsonResult {
async fn get_user (
org_id : String ,
org_user_id : String ,
data : GetOrgUserData ,
_headers : AdminHeaders ,
mut conn : DbConn ,
) -> JsonResult {
let user = match UserOrganization ::find_by_uuid_and_org ( & org_user_id , & org_id , & mut conn ) . await {
let user = match UserOrganization ::find_by_uuid_and_org ( & org_user_id , & org_id , & mut conn ) . await {
Some ( user ) = > user ,
Some ( user ) = > user ,
None = > err ! ( "The specified user isn't a member of the organization" ) ,
None = > err ! ( "The specified user isn't a member of the organization" ) ,
} ;
} ;
Ok ( Json ( user . to_json_details ( & mut conn ) . await ) )
// In this case, when groups are requested we also need to include collections.
// Else these will not be shown in the interface, and could lead to missing collections when saved.
let include_groups = data . include_groups . unwrap_or ( false ) ;
Ok ( Json (
user . to_json_user_details ( data . include_collections . unwrap_or ( include_groups ) , include_groups , & mut conn ) . await ,
) )
}
}
#[ derive(Deserialize) ]
#[ derive(Deserialize) ]
@ -1244,6 +1253,7 @@ async fn get_user(org_id: String, org_user_id: String, _headers: AdminHeaders, m
struct EditUserData {
struct EditUserData {
Type : NumberOrString ,
Type : NumberOrString ,
Collections : Option < Vec < CollectionData > > ,
Collections : Option < Vec < CollectionData > > ,
Groups : Option < Vec < String > > ,
AccessAll : bool ,
AccessAll : bool ,
}
}
@ -1342,6 +1352,13 @@ async fn edit_user(
}
}
}
}
GroupUser ::delete_all_by_user ( & user_to_edit . uuid , & mut conn ) . await ? ;
for group in data . Groups . iter ( ) . flatten ( ) {
let mut group_entry = GroupUser ::new ( String ::from ( group ) , user_to_edit . uuid . clone ( ) ) ;
group_entry . save ( & mut conn ) . await ? ;
}
log_event (
log_event (
EventType ::OrganizationUserUpdated as i32 ,
EventType ::OrganizationUserUpdated as i32 ,
& user_to_edit . uuid ,
& user_to_edit . uuid ,