DocSpace-buildtools/products/ASC.People/Server/Api/ContactsController.cs
2022-02-28 23:25:25 +03:00

149 lines
4.5 KiB
C#

using SecurityContext = ASC.Core.SecurityContext;
namespace ASC.People.Api;
public class ContactsController : BasePeopleController
{
private readonly EmployeeFullDtoHelper _employeeFullDtoHelper;
public ContactsController(
UserManager userManager,
AuthContext authContext,
ApiContext apiContext,
PermissionContext permissionContext,
SecurityContext securityContext,
MessageService messageService,
MessageTarget messageTarget,
StudioNotifyService studioNotifyService,
UserPhotoManager userPhotoManager,
IHttpClientFactory httpClientFactory,
DisplayUserSettingsHelper displayUserSettingsHelper,
SetupInfo setupInfo,
EmployeeFullDtoHelper employeeFullDtoHelper)
: base(
userManager,
authContext,
apiContext,
permissionContext,
securityContext,
messageService,
messageTarget,
studioNotifyService,
userPhotoManager,
httpClientFactory,
displayUserSettingsHelper,
setupInfo)
{
_employeeFullDtoHelper = employeeFullDtoHelper;
}
[Delete("{userid}/contacts")]
public EmployeeFullDto DeleteMemberContactsFromBody(string userid, [FromBody] UpdateMemberRequestDto memberModel)
{
return DeleteMemberContacts(userid, memberModel);
}
[Delete("{userid}/contacts")]
[Consumes("application/x-www-form-urlencoded")]
public EmployeeFullDto DeleteMemberContactsFromForm(string userid, [FromForm] UpdateMemberRequestDto memberModel)
{
return DeleteMemberContacts(userid, memberModel);
}
[Create("{userid}/contacts")]
public EmployeeFullDto SetMemberContactsFromBody(string userid, [FromBody] UpdateMemberRequestDto memberModel)
{
return SetMemberContacts(userid, memberModel);
}
[Create("{userid}/contacts")]
[Consumes("application/x-www-form-urlencoded")]
public EmployeeFullDto SetMemberContactsFromForm(string userid, [FromForm] UpdateMemberRequestDto memberModel)
{
return SetMemberContacts(userid, memberModel);
}
[Update("{userid}/contacts")]
public EmployeeFullDto UpdateMemberContactsFromBody(string userid, [FromBody] UpdateMemberRequestDto memberModel)
{
return UpdateMemberContacts(userid, memberModel);
}
[Update("{userid}/contacts")]
[Consumes("application/x-www-form-urlencoded")]
public EmployeeFullDto UpdateMemberContactsFromForm(string userid, [FromForm] UpdateMemberRequestDto memberModel)
{
return UpdateMemberContacts(userid, memberModel);
}
private void DeleteContacts(IEnumerable<Contact> contacts, UserInfo user)
{
PermissionContext.DemandPermissions(new UserSecurityProvider(user.ID), Constants.Action_EditUser);
if (contacts == null)
{
return;
}
if (user.ContactsList == null)
{
user.ContactsList = new List<string>();
}
foreach (var contact in contacts)
{
var index = user.ContactsList.IndexOf(contact.Type);
if (index != -1)
{
//Remove existing
user.ContactsList.RemoveRange(index, 2);
}
}
}
private EmployeeFullDto DeleteMemberContacts(string userid, UpdateMemberRequestDto memberModel)
{
var user = GetUserInfo(userid);
if (UserManager.IsSystemUser(user.ID))
{
throw new SecurityException();
}
DeleteContacts(memberModel.Contacts, user);
UserManager.SaveUserInfo(user);
return _employeeFullDtoHelper.GetFull(user);
}
private EmployeeFullDto SetMemberContacts(string userid, UpdateMemberRequestDto memberModel)
{
var user = GetUserInfo(userid);
if (UserManager.IsSystemUser(user.ID))
{
throw new SecurityException();
}
user.ContactsList.Clear();
UpdateContacts(memberModel.Contacts, user);
UserManager.SaveUserInfo(user);
return _employeeFullDtoHelper.GetFull(user);
}
private EmployeeFullDto UpdateMemberContacts(string userid, UpdateMemberRequestDto memberModel)
{
var user = GetUserInfo(userid);
if (UserManager.IsSystemUser(user.ID))
{
throw new SecurityException();
}
UpdateContacts(memberModel.Contacts, user);
UserManager.SaveUserInfo(user);
return _employeeFullDtoHelper.GetFull(user);
}
}