2019-09-09 12:56:33 +00:00
|
|
|
|
|
|
|
|
|
using System;
|
2019-05-27 09:46:04 +00:00
|
|
|
|
using System.Collections.Generic;
|
2019-07-17 08:55:08 +00:00
|
|
|
|
using System.Drawing;
|
|
|
|
|
using System.Drawing.Imaging;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
using System.IO;
|
2019-05-27 09:46:04 +00:00
|
|
|
|
using System.Linq;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
using System.Net;
|
|
|
|
|
using System.Net.Mail;
|
2019-06-17 11:57:07 +00:00
|
|
|
|
using System.Security;
|
2021-04-16 15:32:31 +00:00
|
|
|
|
using System.ServiceModel.Security;
|
2021-04-15 11:34:22 +00:00
|
|
|
|
using System.Threading;
|
2021-04-25 08:46:44 +00:00
|
|
|
|
using System.Web;
|
2019-12-23 14:57:21 +00:00
|
|
|
|
|
2019-06-14 08:15:28 +00:00
|
|
|
|
using ASC.Api.Core;
|
2021-09-17 14:32:37 +00:00
|
|
|
|
using ASC.Api.Utils;
|
2020-02-17 08:58:14 +00:00
|
|
|
|
using ASC.Common;
|
2019-10-17 15:55:35 +00:00
|
|
|
|
using ASC.Common.Logging;
|
2019-10-09 15:04:46 +00:00
|
|
|
|
using ASC.Common.Utils;
|
2019-06-13 15:01:29 +00:00
|
|
|
|
using ASC.Common.Web;
|
2019-05-27 09:46:04 +00:00
|
|
|
|
using ASC.Core;
|
2019-10-31 13:54:43 +00:00
|
|
|
|
using ASC.Core.Common.Settings;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
using ASC.Core.Tenants;
|
2019-05-27 09:46:04 +00:00
|
|
|
|
using ASC.Core.Users;
|
2019-06-21 10:42:16 +00:00
|
|
|
|
using ASC.Data.Reassigns;
|
2019-06-17 11:57:07 +00:00
|
|
|
|
using ASC.FederatedLogin;
|
2021-04-25 08:46:44 +00:00
|
|
|
|
using ASC.FederatedLogin.LoginProviders;
|
2019-06-17 11:57:07 +00:00
|
|
|
|
using ASC.FederatedLogin.Profile;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
using ASC.MessagingSystem;
|
2019-07-05 13:58:04 +00:00
|
|
|
|
using ASC.People;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
using ASC.People.Models;
|
2019-08-13 13:05:36 +00:00
|
|
|
|
using ASC.People.Resources;
|
2019-10-09 15:04:46 +00:00
|
|
|
|
using ASC.Security.Cryptography;
|
2019-05-22 09:28:34 +00:00
|
|
|
|
using ASC.Web.Api.Models;
|
2019-05-27 12:49:48 +00:00
|
|
|
|
using ASC.Web.Api.Routing;
|
2019-06-14 08:15:28 +00:00
|
|
|
|
using ASC.Web.Core;
|
2021-04-25 08:46:44 +00:00
|
|
|
|
using ASC.Web.Core.Mobile;
|
2019-06-17 11:57:07 +00:00
|
|
|
|
using ASC.Web.Core.PublicResources;
|
2019-06-14 08:15:28 +00:00
|
|
|
|
using ASC.Web.Core.Users;
|
2019-07-17 08:55:08 +00:00
|
|
|
|
using ASC.Web.Studio.Core;
|
2019-06-17 11:57:07 +00:00
|
|
|
|
using ASC.Web.Studio.Core.Notify;
|
|
|
|
|
using ASC.Web.Studio.UserControls.Statistics;
|
|
|
|
|
using ASC.Web.Studio.Utility;
|
2019-07-19 08:38:31 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
using Microsoft.AspNetCore.Authorization;
|
2019-07-02 15:30:31 +00:00
|
|
|
|
using Microsoft.AspNetCore.Http;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
using Microsoft.AspNetCore.Http.Extensions;
|
2019-05-17 08:32:23 +00:00
|
|
|
|
using Microsoft.AspNetCore.Mvc;
|
2019-10-17 15:55:35 +00:00
|
|
|
|
using Microsoft.Extensions.Options;
|
2019-12-23 14:57:21 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
using SecurityContext = ASC.Core.SecurityContext;
|
2019-05-17 08:32:23 +00:00
|
|
|
|
|
|
|
|
|
namespace ASC.Employee.Core.Controllers
|
|
|
|
|
{
|
2021-04-26 18:42:39 +00:00
|
|
|
|
[Scope(Additional = typeof(BaseLoginProviderExtension))]
|
2019-05-27 12:49:48 +00:00
|
|
|
|
[DefaultRoute]
|
2019-05-17 08:32:23 +00:00
|
|
|
|
[ApiController]
|
|
|
|
|
public class PeopleController : ControllerBase
|
|
|
|
|
{
|
2019-08-09 12:28:19 +00:00
|
|
|
|
public Tenant Tenant { get { return ApiContext.Tenant; } }
|
2020-08-12 09:58:08 +00:00
|
|
|
|
private ApiContext ApiContext { get; }
|
|
|
|
|
private MessageService MessageService { get; }
|
|
|
|
|
private QueueWorkerReassign QueueWorkerReassign { get; }
|
|
|
|
|
private QueueWorkerRemove QueueWorkerRemove { get; }
|
|
|
|
|
private StudioNotifyService StudioNotifyService { get; }
|
|
|
|
|
private UserManagerWrapper UserManagerWrapper { get; }
|
|
|
|
|
private UserManager UserManager { get; }
|
|
|
|
|
private TenantExtra TenantExtra { get; }
|
|
|
|
|
private TenantStatisticsProvider TenantStatisticsProvider { get; }
|
|
|
|
|
private UserPhotoManager UserPhotoManager { get; }
|
|
|
|
|
private SecurityContext SecurityContext { get; }
|
|
|
|
|
private CookiesManager CookiesManager { get; }
|
|
|
|
|
private WebItemSecurity WebItemSecurity { get; }
|
|
|
|
|
private PermissionContext PermissionContext { get; }
|
|
|
|
|
private AuthContext AuthContext { get; }
|
|
|
|
|
private WebItemManager WebItemManager { get; }
|
|
|
|
|
private CustomNamingPeople CustomNamingPeople { get; }
|
|
|
|
|
private TenantUtil TenantUtil { get; }
|
|
|
|
|
private CoreBaseSettings CoreBaseSettings { get; }
|
|
|
|
|
private SetupInfo SetupInfo { get; }
|
|
|
|
|
private FileSizeComment FileSizeComment { get; }
|
|
|
|
|
private DisplayUserSettingsHelper DisplayUserSettingsHelper { get; }
|
|
|
|
|
private Signature Signature { get; }
|
|
|
|
|
private InstanceCrypto InstanceCrypto { get; }
|
|
|
|
|
private WebItemSecurityCache WebItemSecurityCache { get; }
|
|
|
|
|
private MessageTarget MessageTarget { get; }
|
|
|
|
|
private SettingsManager SettingsManager { get; }
|
|
|
|
|
private IOptionsSnapshot<AccountLinker> AccountLinker { get; }
|
|
|
|
|
private EmployeeWraperFullHelper EmployeeWraperFullHelper { get; }
|
|
|
|
|
private EmployeeWraperHelper EmployeeWraperHelper { get; }
|
|
|
|
|
private UserFormatter UserFormatter { get; }
|
2021-04-15 11:34:22 +00:00
|
|
|
|
private PasswordHasher PasswordHasher { get; }
|
|
|
|
|
private UserHelpTourHelper UserHelpTourHelper { get; }
|
|
|
|
|
private PersonalSettingsHelper PersonalSettingsHelper { get; }
|
2021-04-25 08:46:44 +00:00
|
|
|
|
private CommonLinkUtility CommonLinkUtility { get; }
|
|
|
|
|
private MobileDetector MobileDetector { get; }
|
|
|
|
|
private ProviderManager ProviderManager { get; }
|
2021-05-23 16:11:25 +00:00
|
|
|
|
private Constants Constants { get; }
|
2021-09-17 14:32:37 +00:00
|
|
|
|
private Recaptcha Recaptcha { get; }
|
2021-04-15 11:34:22 +00:00
|
|
|
|
private ILog Log { get; }
|
2019-08-01 08:47:15 +00:00
|
|
|
|
|
2019-10-17 15:55:35 +00:00
|
|
|
|
public PeopleController(
|
2019-08-01 08:47:15 +00:00
|
|
|
|
MessageService messageService,
|
|
|
|
|
QueueWorkerReassign queueWorkerReassign,
|
|
|
|
|
QueueWorkerRemove queueWorkerRemove,
|
|
|
|
|
StudioNotifyService studioNotifyService,
|
|
|
|
|
UserManagerWrapper userManagerWrapper,
|
2019-09-09 12:56:33 +00:00
|
|
|
|
ApiContext apiContext,
|
|
|
|
|
UserManager userManager,
|
|
|
|
|
TenantExtra tenantExtra,
|
|
|
|
|
TenantStatisticsProvider tenantStatisticsProvider,
|
|
|
|
|
UserPhotoManager userPhotoManager,
|
|
|
|
|
SecurityContext securityContext,
|
|
|
|
|
CookiesManager cookiesManager,
|
|
|
|
|
WebItemSecurity webItemSecurity,
|
|
|
|
|
PermissionContext permissionContext,
|
2019-09-11 10:42:52 +00:00
|
|
|
|
AuthContext authContext,
|
2019-09-13 11:18:27 +00:00
|
|
|
|
WebItemManager webItemManager,
|
2019-09-17 12:42:32 +00:00
|
|
|
|
CustomNamingPeople customNamingPeople,
|
2019-09-17 15:38:06 +00:00
|
|
|
|
TenantUtil tenantUtil,
|
2019-10-09 15:04:46 +00:00
|
|
|
|
CoreBaseSettings coreBaseSettings,
|
2019-09-23 12:20:08 +00:00
|
|
|
|
SetupInfo setupInfo,
|
2019-09-24 10:32:12 +00:00
|
|
|
|
FileSizeComment fileSizeComment,
|
2019-11-08 12:21:51 +00:00
|
|
|
|
DisplayUserSettingsHelper displayUserSettingsHelper,
|
2019-10-09 15:04:46 +00:00
|
|
|
|
Signature signature,
|
2019-10-10 08:52:21 +00:00
|
|
|
|
InstanceCrypto instanceCrypto,
|
2019-10-17 15:55:35 +00:00
|
|
|
|
WebItemSecurityCache webItemSecurityCache,
|
2019-10-22 11:21:44 +00:00
|
|
|
|
MessageTarget messageTarget,
|
2019-11-08 12:21:51 +00:00
|
|
|
|
SettingsManager settingsManager,
|
2019-11-11 15:42:07 +00:00
|
|
|
|
IOptionsMonitor<ILog> option,
|
2019-12-04 10:39:18 +00:00
|
|
|
|
IOptionsSnapshot<AccountLinker> accountLinker,
|
2019-11-11 15:42:07 +00:00
|
|
|
|
EmployeeWraperFullHelper employeeWraperFullHelper,
|
2020-01-17 13:58:26 +00:00
|
|
|
|
EmployeeWraperHelper employeeWraperHelper,
|
2020-09-17 12:04:28 +00:00
|
|
|
|
UserFormatter userFormatter,
|
2021-04-15 11:34:22 +00:00
|
|
|
|
PasswordHasher passwordHasher,
|
|
|
|
|
UserHelpTourHelper userHelpTourHelper,
|
2021-04-16 15:32:31 +00:00
|
|
|
|
PersonalSettingsHelper personalSettingsHelper,
|
2021-04-25 08:46:44 +00:00
|
|
|
|
CommonLinkUtility commonLinkUtility,
|
|
|
|
|
MobileDetector mobileDetector,
|
2021-05-23 16:11:25 +00:00
|
|
|
|
ProviderManager providerManager,
|
2021-09-17 14:32:37 +00:00
|
|
|
|
Constants constants,
|
|
|
|
|
Recaptcha recaptcha
|
2021-04-25 08:46:44 +00:00
|
|
|
|
)
|
2019-06-13 15:01:29 +00:00
|
|
|
|
{
|
2019-10-17 15:55:35 +00:00
|
|
|
|
Log = option.Get("ASC.Api");
|
2019-06-17 13:53:10 +00:00
|
|
|
|
MessageService = messageService;
|
2019-06-21 12:42:27 +00:00
|
|
|
|
QueueWorkerReassign = queueWorkerReassign;
|
|
|
|
|
QueueWorkerRemove = queueWorkerRemove;
|
2019-08-01 08:47:15 +00:00
|
|
|
|
StudioNotifyService = studioNotifyService;
|
|
|
|
|
UserManagerWrapper = userManagerWrapper;
|
2019-07-29 10:51:14 +00:00
|
|
|
|
ApiContext = apiContext;
|
2019-09-09 12:56:33 +00:00
|
|
|
|
UserManager = userManager;
|
|
|
|
|
TenantExtra = tenantExtra;
|
|
|
|
|
TenantStatisticsProvider = tenantStatisticsProvider;
|
|
|
|
|
UserPhotoManager = userPhotoManager;
|
|
|
|
|
SecurityContext = securityContext;
|
|
|
|
|
CookiesManager = cookiesManager;
|
|
|
|
|
WebItemSecurity = webItemSecurity;
|
|
|
|
|
PermissionContext = permissionContext;
|
|
|
|
|
AuthContext = authContext;
|
2019-09-11 10:42:52 +00:00
|
|
|
|
WebItemManager = webItemManager;
|
2019-09-16 12:35:44 +00:00
|
|
|
|
CustomNamingPeople = customNamingPeople;
|
2019-09-17 12:42:32 +00:00
|
|
|
|
TenantUtil = tenantUtil;
|
2019-09-18 15:19:30 +00:00
|
|
|
|
CoreBaseSettings = coreBaseSettings;
|
2019-09-23 12:20:08 +00:00
|
|
|
|
SetupInfo = setupInfo;
|
|
|
|
|
FileSizeComment = fileSizeComment;
|
2019-11-08 12:21:51 +00:00
|
|
|
|
DisplayUserSettingsHelper = displayUserSettingsHelper;
|
2019-10-09 15:04:46 +00:00
|
|
|
|
Signature = signature;
|
|
|
|
|
InstanceCrypto = instanceCrypto;
|
2019-10-11 15:03:03 +00:00
|
|
|
|
WebItemSecurityCache = webItemSecurityCache;
|
2019-10-22 11:21:44 +00:00
|
|
|
|
MessageTarget = messageTarget;
|
2019-11-08 12:21:51 +00:00
|
|
|
|
SettingsManager = settingsManager;
|
2019-12-04 10:39:18 +00:00
|
|
|
|
AccountLinker = accountLinker;
|
2019-11-11 15:42:07 +00:00
|
|
|
|
EmployeeWraperFullHelper = employeeWraperFullHelper;
|
|
|
|
|
EmployeeWraperHelper = employeeWraperHelper;
|
2020-01-17 13:58:26 +00:00
|
|
|
|
UserFormatter = userFormatter;
|
2020-09-17 12:04:28 +00:00
|
|
|
|
PasswordHasher = passwordHasher;
|
2021-04-15 11:34:22 +00:00
|
|
|
|
UserHelpTourHelper = userHelpTourHelper;
|
|
|
|
|
PersonalSettingsHelper = personalSettingsHelper;
|
2021-04-16 15:32:31 +00:00
|
|
|
|
CommonLinkUtility = commonLinkUtility;
|
2021-04-25 08:46:44 +00:00
|
|
|
|
MobileDetector = mobileDetector;
|
|
|
|
|
ProviderManager = providerManager;
|
2021-05-23 16:11:25 +00:00
|
|
|
|
Constants = constants;
|
2021-09-17 14:32:37 +00:00
|
|
|
|
Recaptcha = recaptcha;
|
2019-06-13 15:01:29 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-07-05 13:58:04 +00:00
|
|
|
|
[Read("info")]
|
|
|
|
|
public Module GetModule()
|
|
|
|
|
{
|
|
|
|
|
var product = new PeopleProduct();
|
|
|
|
|
product.Init();
|
2021-01-25 14:37:26 +00:00
|
|
|
|
return new Module(product);
|
2019-07-05 13:58:04 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Read]
|
2019-11-29 09:22:20 +00:00
|
|
|
|
public IQueryable<EmployeeWraper> GetAll()
|
2019-05-27 09:46:04 +00:00
|
|
|
|
{
|
|
|
|
|
return GetByStatus(EmployeeStatus.Active);
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-14 08:15:28 +00:00
|
|
|
|
[Read("status/{status}")]
|
2019-11-29 09:22:20 +00:00
|
|
|
|
public IQueryable<EmployeeWraper> GetByStatus(EmployeeStatus status)
|
2019-05-27 09:46:04 +00:00
|
|
|
|
{
|
2019-09-18 15:19:30 +00:00
|
|
|
|
if (CoreBaseSettings.Personal) throw new Exception("Method not available");
|
2019-11-12 12:24:59 +00:00
|
|
|
|
Guid? groupId = null;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
if ("group".Equals(ApiContext.FilterBy, StringComparison.OrdinalIgnoreCase) && !string.IsNullOrEmpty(ApiContext.FilterValue))
|
|
|
|
|
{
|
2019-11-12 12:24:59 +00:00
|
|
|
|
groupId = new Guid(ApiContext.FilterValue);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
ApiContext.SetDataFiltered();
|
|
|
|
|
}
|
2019-11-12 12:24:59 +00:00
|
|
|
|
return GetFullByFilter(status, groupId, null, null, null);
|
2019-05-27 09:46:04 +00:00
|
|
|
|
}
|
2019-05-27 12:49:48 +00:00
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Read("@self")]
|
2019-05-27 12:49:48 +00:00
|
|
|
|
public EmployeeWraper Self()
|
|
|
|
|
{
|
2020-02-25 08:02:13 +00:00
|
|
|
|
return EmployeeWraperFullHelper.GetFull(UserManager.GetUser(SecurityContext.CurrentAccount.ID, EmployeeWraperFullHelper.GetExpression(ApiContext)));
|
2019-05-27 12:49:48 +00:00
|
|
|
|
}
|
2019-06-13 15:01:29 +00:00
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Read("email")]
|
2020-09-17 12:04:28 +00:00
|
|
|
|
public EmployeeWraperFull GetByEmail([FromQuery] string email)
|
2019-06-14 08:15:28 +00:00
|
|
|
|
{
|
2019-09-18 15:19:30 +00:00
|
|
|
|
if (CoreBaseSettings.Personal && !UserManager.GetUsers(SecurityContext.CurrentAccount.ID).IsOwner(Tenant))
|
2019-06-14 08:15:28 +00:00
|
|
|
|
throw new MethodAccessException("Method not available");
|
2019-09-12 11:34:58 +00:00
|
|
|
|
var user = UserManager.GetUserByEmail(email);
|
2019-06-14 08:15:28 +00:00
|
|
|
|
if (user.ID == Constants.LostUser.ID)
|
|
|
|
|
{
|
|
|
|
|
throw new ItemNotFoundException("User not found");
|
|
|
|
|
}
|
|
|
|
|
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return EmployeeWraperFullHelper.GetFull(user);
|
2019-06-14 08:15:28 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Read("{username}", order: int.MaxValue)]
|
2019-06-13 15:01:29 +00:00
|
|
|
|
public EmployeeWraperFull GetById(string username)
|
|
|
|
|
{
|
2019-09-18 15:19:30 +00:00
|
|
|
|
if (CoreBaseSettings.Personal) throw new MethodAccessException("Method not available");
|
2019-09-12 11:34:58 +00:00
|
|
|
|
var user = UserManager.GetUserByUserName(username);
|
2019-06-13 15:01:29 +00:00
|
|
|
|
if (user.ID == Constants.LostUser.ID)
|
|
|
|
|
{
|
2019-06-14 08:15:28 +00:00
|
|
|
|
if (Guid.TryParse(username, out var userId))
|
2019-06-13 15:01:29 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
user = UserManager.GetUsers(userId);
|
2019-06-13 15:01:29 +00:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2019-10-17 15:55:35 +00:00
|
|
|
|
Log.Error(string.Format("Account {0} сould not get user by name {1}", SecurityContext.CurrentAccount.ID, username));
|
2019-06-13 15:01:29 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (user.ID == Constants.LostUser.ID)
|
|
|
|
|
{
|
|
|
|
|
throw new ItemNotFoundException("User not found");
|
|
|
|
|
}
|
|
|
|
|
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return EmployeeWraperFullHelper.GetFull(user);
|
2019-06-13 15:01:29 +00:00
|
|
|
|
}
|
2019-06-14 08:15:28 +00:00
|
|
|
|
|
|
|
|
|
[Read("@search/{query}")]
|
|
|
|
|
public IEnumerable<EmployeeWraperFull> GetSearch(string query)
|
|
|
|
|
{
|
2019-09-18 15:19:30 +00:00
|
|
|
|
if (CoreBaseSettings.Personal) throw new MethodAccessException("Method not available");
|
2019-06-14 08:15:28 +00:00
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
var groupId = Guid.Empty;
|
|
|
|
|
if ("group".Equals(ApiContext.FilterBy, StringComparison.OrdinalIgnoreCase) && !string.IsNullOrEmpty(ApiContext.FilterValue))
|
|
|
|
|
{
|
|
|
|
|
groupId = new Guid(ApiContext.FilterValue);
|
|
|
|
|
}
|
|
|
|
|
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return UserManager.Search(query, EmployeeStatus.Active, groupId).Select(EmployeeWraperFullHelper.GetFull);
|
2019-06-14 08:15:28 +00:00
|
|
|
|
}
|
|
|
|
|
catch (Exception error)
|
|
|
|
|
{
|
2019-10-17 15:55:35 +00:00
|
|
|
|
Log.Error(error);
|
2019-06-14 08:15:28 +00:00
|
|
|
|
}
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Read("search")]
|
2020-09-17 12:04:28 +00:00
|
|
|
|
public IEnumerable<EmployeeWraperFull> GetPeopleSearch([FromQuery] string query)
|
2019-06-14 08:15:28 +00:00
|
|
|
|
{
|
|
|
|
|
return GetSearch(query);
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Read("status/{status}/search")]
|
2020-09-17 12:04:28 +00:00
|
|
|
|
public IEnumerable<EmployeeWraperFull> GetAdvanced(EmployeeStatus status, [FromQuery] string query)
|
2019-06-14 08:15:28 +00:00
|
|
|
|
{
|
2019-09-18 15:19:30 +00:00
|
|
|
|
if (CoreBaseSettings.Personal) throw new MethodAccessException("Method not available");
|
2019-06-14 08:15:28 +00:00
|
|
|
|
try
|
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
var list = UserManager.GetUsers(status).AsEnumerable();
|
2019-06-14 08:15:28 +00:00
|
|
|
|
|
|
|
|
|
if ("group".Equals(ApiContext.FilterBy, StringComparison.OrdinalIgnoreCase) && !string.IsNullOrEmpty(ApiContext.FilterValue))
|
|
|
|
|
{
|
|
|
|
|
var groupId = new Guid(ApiContext.FilterValue);
|
|
|
|
|
//Filter by group
|
2019-09-12 11:34:58 +00:00
|
|
|
|
list = list.Where(x => UserManager.IsUserInGroup(x.ID, groupId));
|
2019-06-14 08:15:28 +00:00
|
|
|
|
ApiContext.SetDataFiltered();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
list = list.Where(x => x.FirstName != null && x.FirstName.IndexOf(query, StringComparison.OrdinalIgnoreCase) > -1 || (x.LastName != null && x.LastName.IndexOf(query, StringComparison.OrdinalIgnoreCase) != -1) ||
|
2019-11-25 09:49:12 +00:00
|
|
|
|
(x.UserName != null && x.UserName.IndexOf(query, StringComparison.OrdinalIgnoreCase) != -1) || (x.Email != null && x.Email.IndexOf(query, StringComparison.OrdinalIgnoreCase) != -1) || (x.ContactsList != null && x.ContactsList.Any(y => y.IndexOf(query, StringComparison.OrdinalIgnoreCase) != -1)));
|
2019-06-14 08:15:28 +00:00
|
|
|
|
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return list.Select(EmployeeWraperFullHelper.GetFull);
|
2019-06-14 08:15:28 +00:00
|
|
|
|
}
|
|
|
|
|
catch (Exception error)
|
|
|
|
|
{
|
2019-10-17 15:55:35 +00:00
|
|
|
|
Log.Error(error);
|
2019-06-14 08:15:28 +00:00
|
|
|
|
}
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
///// <summary>
|
|
|
|
|
///// Adds a new portal user from import with the first and last name, email address
|
|
|
|
|
///// </summary>
|
|
|
|
|
///// <short>
|
|
|
|
|
///// Add new import user
|
|
|
|
|
///// </short>
|
|
|
|
|
///// <param name="userList">The list of users to add</param>
|
|
|
|
|
///// <param name="importUsersAsCollaborators" optional="true">Add users as guests (bool type: false|true)</param>
|
|
|
|
|
///// <returns>Newly created users</returns>
|
|
|
|
|
//[Create("import/save")]
|
|
|
|
|
//public void SaveUsers(string userList, bool importUsersAsCollaborators)
|
|
|
|
|
//{
|
|
|
|
|
// lock (progressQueue.SynchRoot)
|
|
|
|
|
// {
|
|
|
|
|
// var task = progressQueue.GetItems().OfType<ImportUsersTask>().FirstOrDefault(t => (int)t.Id == TenantProvider.CurrentTenantID);
|
|
|
|
|
// if (task != null && task.IsCompleted)
|
|
|
|
|
// {
|
|
|
|
|
// progressQueue.Remove(task);
|
|
|
|
|
// task = null;
|
|
|
|
|
// }
|
|
|
|
|
// if (task == null)
|
|
|
|
|
// {
|
|
|
|
|
// progressQueue.Add(new ImportUsersTask(userList, importUsersAsCollaborators, GetHttpHeaders(HttpContext.Current.Request))
|
|
|
|
|
// {
|
|
|
|
|
// Id = TenantProvider.CurrentTenantID,
|
|
|
|
|
// UserId = SecurityContext.CurrentAccount.ID,
|
|
|
|
|
// Percentage = 0
|
|
|
|
|
// });
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
//}
|
|
|
|
|
|
|
|
|
|
//[Read("import/status")]
|
|
|
|
|
//public object GetStatus()
|
|
|
|
|
//{
|
|
|
|
|
// lock (progressQueue.SynchRoot)
|
|
|
|
|
// {
|
|
|
|
|
// var task = progressQueue.GetItems().OfType<ImportUsersTask>().FirstOrDefault(t => (int)t.Id == TenantProvider.CurrentTenantID);
|
|
|
|
|
// if (task == null) return null;
|
|
|
|
|
|
|
|
|
|
// return new
|
|
|
|
|
// {
|
|
|
|
|
// Completed = task.IsCompleted,
|
|
|
|
|
// Percents = (int)task.Percentage,
|
|
|
|
|
// UserCounter = task.GetUserCounter,
|
|
|
|
|
// Status = (int)task.Status,
|
|
|
|
|
// Error = (string)task.Error,
|
|
|
|
|
// task.Data
|
|
|
|
|
// };
|
|
|
|
|
// }
|
|
|
|
|
//}
|
|
|
|
|
|
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Read("filter")]
|
2019-11-29 09:22:20 +00:00
|
|
|
|
public IQueryable<EmployeeWraperFull> GetFullByFilter(EmployeeStatus? employeeStatus, Guid? groupId, EmployeeActivationStatus? activationStatus, EmployeeType? employeeType, bool? isAdministrator)
|
2019-06-14 08:15:28 +00:00
|
|
|
|
{
|
|
|
|
|
var users = GetByFilter(employeeStatus, groupId, activationStatus, employeeType, isAdministrator);
|
2019-11-29 09:22:20 +00:00
|
|
|
|
return users.Select(r => EmployeeWraperFullHelper.GetFull(r));
|
2019-06-14 08:15:28 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Read("simple/filter")]
|
2019-06-14 08:15:28 +00:00
|
|
|
|
public IEnumerable<EmployeeWraper> GetSimpleByFilter(EmployeeStatus? employeeStatus, Guid? groupId, EmployeeActivationStatus? activationStatus, EmployeeType? employeeType, bool? isAdministrator)
|
|
|
|
|
{
|
|
|
|
|
var users = GetByFilter(employeeStatus, groupId, activationStatus, employeeType, isAdministrator);
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return users.Select(EmployeeWraperHelper.Get);
|
2019-06-14 08:15:28 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-11-25 09:49:12 +00:00
|
|
|
|
private IQueryable<UserInfo> GetByFilter(EmployeeStatus? employeeStatus, Guid? groupId, EmployeeActivationStatus? activationStatus, EmployeeType? employeeType, bool? isAdministrator)
|
2019-06-14 08:15:28 +00:00
|
|
|
|
{
|
2019-09-18 15:19:30 +00:00
|
|
|
|
if (CoreBaseSettings.Personal) throw new MethodAccessException("Method not available");
|
2019-09-12 11:34:58 +00:00
|
|
|
|
var isAdmin = UserManager.GetUsers(SecurityContext.CurrentAccount.ID).IsAdmin(UserManager) ||
|
|
|
|
|
WebItemSecurity.IsProductAdministrator(WebItemManager.PeopleProductID, SecurityContext.CurrentAccount.ID);
|
2019-06-14 08:15:28 +00:00
|
|
|
|
|
2019-08-08 14:42:29 +00:00
|
|
|
|
var includeGroups = new List<List<Guid>>();
|
2019-08-05 13:45:33 +00:00
|
|
|
|
if (groupId.HasValue)
|
2019-06-14 08:15:28 +00:00
|
|
|
|
{
|
2019-08-08 14:42:29 +00:00
|
|
|
|
includeGroups.Add(new List<Guid> { groupId.Value });
|
2019-06-14 08:15:28 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-08-05 13:45:33 +00:00
|
|
|
|
var excludeGroups = new List<Guid>();
|
2019-06-14 08:15:28 +00:00
|
|
|
|
|
|
|
|
|
if (employeeType != null)
|
|
|
|
|
{
|
|
|
|
|
switch (employeeType)
|
|
|
|
|
{
|
|
|
|
|
case EmployeeType.User:
|
2019-08-05 13:45:33 +00:00
|
|
|
|
excludeGroups.Add(Constants.GroupVisitor.ID);
|
2019-06-14 08:15:28 +00:00
|
|
|
|
break;
|
|
|
|
|
case EmployeeType.Visitor:
|
2019-08-08 14:42:29 +00:00
|
|
|
|
includeGroups.Add(new List<Guid> { Constants.GroupVisitor.ID });
|
2019-06-14 08:15:28 +00:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (isAdministrator.HasValue && isAdministrator.Value)
|
|
|
|
|
{
|
2019-08-08 14:42:29 +00:00
|
|
|
|
var adminGroups = new List<Guid>
|
|
|
|
|
{
|
|
|
|
|
Constants.GroupAdmin.ID
|
|
|
|
|
};
|
2019-06-14 08:15:28 +00:00
|
|
|
|
|
2019-09-11 10:42:52 +00:00
|
|
|
|
var products = WebItemManager.GetItemsAll().Where(i => i is IProduct || i.ID == WebItemManager.MailProductID);
|
2019-08-15 12:04:42 +00:00
|
|
|
|
adminGroups.AddRange(products.Select(r => r.ID));
|
2019-06-14 08:15:28 +00:00
|
|
|
|
|
2019-08-08 14:42:29 +00:00
|
|
|
|
includeGroups.Add(adminGroups);
|
2019-06-14 08:15:28 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-11-25 09:49:12 +00:00
|
|
|
|
var users = UserManager.GetUsers(isAdmin, employeeStatus, includeGroups, excludeGroups, activationStatus, ApiContext.FilterValue, ApiContext.SortBy, !ApiContext.SortDescending, ApiContext.Count, ApiContext.StartIndex, out var total, out var count);
|
2019-06-14 08:15:28 +00:00
|
|
|
|
|
2019-11-25 09:49:12 +00:00
|
|
|
|
ApiContext.SetTotalCount(total).SetCount(count);
|
2019-06-14 08:15:28 +00:00
|
|
|
|
|
|
|
|
|
return users;
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2021-09-17 14:32:37 +00:00
|
|
|
|
[AllowAnonymous]
|
|
|
|
|
[Create(@"register")]
|
|
|
|
|
public string RegisterUserOnPersonal(RegisterPersonalUserModel model)
|
|
|
|
|
{
|
|
|
|
|
if (!CoreBaseSettings.Personal) throw new MethodAccessException("Method is only available on personal.onlyoffice.com");
|
|
|
|
|
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
if (CoreBaseSettings.CustomMode) model.Lang = "ru-RU";
|
|
|
|
|
|
|
|
|
|
var cultureInfo = SetupInfo.GetPersonalCulture(model.Lang).Value;
|
|
|
|
|
|
|
|
|
|
if (cultureInfo != null)
|
|
|
|
|
{
|
|
|
|
|
Thread.CurrentThread.CurrentUICulture = cultureInfo;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
model.Email.ThrowIfNull(new ArgumentException(Resource.ErrorEmailEmpty, "email"));
|
|
|
|
|
|
|
|
|
|
if (!model.Email.TestEmailRegex()) throw new ArgumentException(Resource.ErrorNotCorrectEmail, "email");
|
|
|
|
|
|
|
|
|
|
if (!SetupInfo.IsSecretEmail(model.Email)
|
|
|
|
|
&& !string.IsNullOrEmpty(SetupInfo.RecaptchaPublicKey) && !string.IsNullOrEmpty(SetupInfo.RecaptchaPrivateKey))
|
|
|
|
|
{
|
|
|
|
|
var ip = Request.Headers["X-Forwarded-For"].ToString() ?? Request.GetUserHostAddress();
|
|
|
|
|
|
|
|
|
|
if (string.IsNullOrEmpty(model.RecaptchaResponse)
|
|
|
|
|
|| !Recaptcha.ValidateRecaptcha(model.RecaptchaResponse, ip))
|
|
|
|
|
{
|
|
|
|
|
throw new RecaptchaException(Resource.RecaptchaInvalid);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var newUserInfo = UserManager.GetUserByEmail(model.Email);
|
|
|
|
|
|
|
|
|
|
if (UserManager.UserExists(newUserInfo.ID))
|
|
|
|
|
{
|
|
|
|
|
if (!SetupInfo.IsSecretEmail(model.Email) || SecurityContext.IsAuthenticated)
|
|
|
|
|
{
|
|
|
|
|
throw new Exception(CustomNamingPeople.Substitute<Resource>("ErrorEmailAlreadyExists"));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
SecurityContext.AuthenticateMe(ASC.Core.Configuration.Constants.CoreSystem);
|
|
|
|
|
UserManager.DeleteUser(newUserInfo.ID);
|
|
|
|
|
}
|
|
|
|
|
finally
|
|
|
|
|
{
|
|
|
|
|
SecurityContext.Logout();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (!model.Spam)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
//TODO
|
|
|
|
|
//const string _databaseID = "com";
|
|
|
|
|
//using (var db = DbManager.FromHttpContext(_databaseID))
|
|
|
|
|
//{
|
|
|
|
|
// db.ExecuteNonQuery(new SqlInsert("template_unsubscribe", false)
|
|
|
|
|
// .InColumnValue("email", email.ToLowerInvariant())
|
|
|
|
|
// .InColumnValue("reason", "personal")
|
|
|
|
|
// );
|
|
|
|
|
// Log.Debug(String.Format("Write to template_unsubscribe {0}", email.ToLowerInvariant()));
|
|
|
|
|
//}
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
Log.Debug(String.Format("ERROR write to template_unsubscribe {0}, email:{1}", ex.Message, model.Email.ToLowerInvariant()));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
StudioNotifyService.SendInvitePersonal(model.Email);
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
return ex.Message;
|
|
|
|
|
}
|
|
|
|
|
return string.Empty;
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Create]
|
2021-05-05 08:45:13 +00:00
|
|
|
|
[Authorize(AuthenticationSchemes = "confirm", Roles = "LinkInvite,Everyone")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public EmployeeWraperFull AddMemberFromBody([FromBody] MemberModel memberModel)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return AddMember(memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Create]
|
2021-05-05 08:45:13 +00:00
|
|
|
|
[Authorize(AuthenticationSchemes = "confirm", Roles = "LinkInvite,Everyone")]
|
2020-11-06 09:03:49 +00:00
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public EmployeeWraperFull AddMemberFromForm([FromForm] MemberModel memberModel)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return AddMember(memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private EmployeeWraperFull AddMember(MemberModel memberModel)
|
2019-06-14 16:14:24 +00:00
|
|
|
|
{
|
2019-09-16 09:21:10 +00:00
|
|
|
|
ApiContext.AuthByClaim();
|
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(Constants.Action_AddRemoveUser);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2020-09-17 12:04:28 +00:00
|
|
|
|
memberModel.PasswordHash = (memberModel.PasswordHash ?? "").Trim();
|
|
|
|
|
if (string.IsNullOrEmpty(memberModel.PasswordHash))
|
|
|
|
|
{
|
|
|
|
|
memberModel.Password = (memberModel.Password ?? "").Trim();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2020-09-17 12:04:28 +00:00
|
|
|
|
if (string.IsNullOrEmpty(memberModel.Password))
|
|
|
|
|
{
|
|
|
|
|
memberModel.Password = UserManagerWrapper.GeneratePassword();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
UserManagerWrapper.CheckPasswordPolicy(memberModel.Password);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
memberModel.PasswordHash = PasswordHasher.GetClientPassword(memberModel.Password);
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
|
|
|
|
var user = new UserInfo();
|
|
|
|
|
|
|
|
|
|
//Validate email
|
|
|
|
|
var address = new MailAddress(memberModel.Email);
|
|
|
|
|
user.Email = address.Address;
|
|
|
|
|
//Set common fields
|
|
|
|
|
user.FirstName = memberModel.Firstname;
|
|
|
|
|
user.LastName = memberModel.Lastname;
|
|
|
|
|
user.Title = memberModel.Title;
|
|
|
|
|
user.Location = memberModel.Location;
|
|
|
|
|
user.Notes = memberModel.Comment;
|
|
|
|
|
user.Sex = "male".Equals(memberModel.Sex, StringComparison.OrdinalIgnoreCase)
|
|
|
|
|
? true
|
|
|
|
|
: ("female".Equals(memberModel.Sex, StringComparison.OrdinalIgnoreCase) ? (bool?)false : null);
|
|
|
|
|
|
2021-04-15 11:34:22 +00:00
|
|
|
|
user.BirthDate = memberModel.Birthday != null && memberModel.Birthday != DateTime.MinValue ? TenantUtil.DateTimeFromUtc(Convert.ToDateTime(memberModel.Birthday)) : null;
|
2019-09-20 11:07:57 +00:00
|
|
|
|
user.WorkFromDate = memberModel.Worksfrom != null && memberModel.Worksfrom != DateTime.MinValue ? TenantUtil.DateTimeFromUtc(Convert.ToDateTime(memberModel.Worksfrom)) : DateTime.UtcNow.Date;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
|
|
|
|
UpdateContacts(memberModel.Contacts, user);
|
|
|
|
|
|
2020-12-22 14:19:58 +00:00
|
|
|
|
user = UserManagerWrapper.AddUser(user, memberModel.PasswordHash, memberModel.FromInviteLink, true, memberModel.IsVisitor, memberModel.FromInviteLink);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
|
|
|
|
var messageAction = memberModel.IsVisitor ? MessageAction.GuestCreated : MessageAction.UserCreated;
|
2019-11-08 12:21:51 +00:00
|
|
|
|
MessageService.Send(messageAction, MessageTarget.Create(user.ID), user.DisplayUserName(false, DisplayUserSettingsHelper));
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
|
|
|
|
UpdateDepartments(memberModel.Department, user);
|
|
|
|
|
|
|
|
|
|
if (memberModel.Files != UserPhotoManager.GetDefaultPhotoAbsoluteWebPath())
|
|
|
|
|
{
|
|
|
|
|
UpdatePhotoUrl(memberModel.Files, user);
|
|
|
|
|
}
|
|
|
|
|
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return EmployeeWraperFullHelper.GetFull(user);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Create("active")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public EmployeeWraperFull AddMemberAsActivatedFromBody([FromBody] MemberModel memberModel)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return AddMemberAsActivated(memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Create("active")]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
|
|
|
|
public EmployeeWraperFull AddMemberAsActivatedFromForm([FromForm] MemberModel memberModel)
|
|
|
|
|
{
|
|
|
|
|
return AddMemberAsActivated(memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private EmployeeWraperFull AddMemberAsActivated(MemberModel memberModel)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(Constants.Action_AddRemoveUser);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
var user = new UserInfo();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2020-09-30 14:16:48 +00:00
|
|
|
|
memberModel.PasswordHash = (memberModel.PasswordHash ?? "").Trim();
|
|
|
|
|
if (string.IsNullOrEmpty(memberModel.PasswordHash))
|
2020-09-17 12:04:28 +00:00
|
|
|
|
{
|
2020-09-30 14:16:48 +00:00
|
|
|
|
memberModel.Password = (memberModel.Password ?? "").Trim();
|
2020-09-17 12:04:28 +00:00
|
|
|
|
|
2020-09-30 14:16:48 +00:00
|
|
|
|
if (string.IsNullOrEmpty(memberModel.Password))
|
|
|
|
|
{
|
|
|
|
|
memberModel.Password = UserManagerWrapper.GeneratePassword();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
UserManagerWrapper.CheckPasswordPolicy(memberModel.Password);
|
|
|
|
|
}
|
2020-09-17 12:04:28 +00:00
|
|
|
|
|
2020-09-30 14:16:48 +00:00
|
|
|
|
memberModel.PasswordHash = PasswordHasher.GetClientPassword(memberModel.Password);
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
//Validate email
|
|
|
|
|
var address = new MailAddress(memberModel.Email);
|
|
|
|
|
user.Email = address.Address;
|
|
|
|
|
//Set common fields
|
|
|
|
|
user.FirstName = memberModel.Firstname;
|
|
|
|
|
user.LastName = memberModel.Lastname;
|
|
|
|
|
user.Title = memberModel.Title;
|
|
|
|
|
user.Location = memberModel.Location;
|
|
|
|
|
user.Notes = memberModel.Comment;
|
|
|
|
|
user.Sex = "male".Equals(memberModel.Sex, StringComparison.OrdinalIgnoreCase)
|
|
|
|
|
? true
|
|
|
|
|
: ("female".Equals(memberModel.Sex, StringComparison.OrdinalIgnoreCase) ? (bool?)false : null);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2021-04-15 11:34:22 +00:00
|
|
|
|
user.BirthDate = memberModel.Birthday != null ? TenantUtil.DateTimeFromUtc(Convert.ToDateTime(memberModel.Birthday)) : null;
|
2019-06-17 11:57:07 +00:00
|
|
|
|
user.WorkFromDate = memberModel.Worksfrom != null ? TenantUtil.DateTimeFromUtc(Convert.ToDateTime(memberModel.Worksfrom)) : DateTime.UtcNow.Date;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
UpdateContacts(memberModel.Contacts, user);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2020-09-30 14:16:48 +00:00
|
|
|
|
user = UserManagerWrapper.AddUser(user, memberModel.PasswordHash, false, false, memberModel.IsVisitor);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
user.ActivationStatus = EmployeeActivationStatus.Activated;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
UpdateDepartments(memberModel.Department, user);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (memberModel.Files != UserPhotoManager.GetDefaultPhotoAbsoluteWebPath())
|
2019-06-14 16:14:24 +00:00
|
|
|
|
{
|
2019-06-17 11:57:07 +00:00
|
|
|
|
UpdatePhotoUrl(memberModel.Files, user);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return EmployeeWraperFullHelper.GetFull(user);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-09-29 10:50:18 +00:00
|
|
|
|
[Update("{userid}/culture")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public EmployeeWraperFull UpdateMemberCultureFromBody(string userid, [FromBody] UpdateMemberModel memberModel)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return UpdateMemberCulture(userid, memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Update("{userid}/culture")]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
|
|
|
|
public EmployeeWraperFull UpdateMemberCultureFromForm(string userid, [FromForm] UpdateMemberModel memberModel)
|
|
|
|
|
{
|
|
|
|
|
return UpdateMemberCulture(userid, memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private EmployeeWraperFull UpdateMemberCulture(string userid, UpdateMemberModel memberModel)
|
2019-09-29 10:50:18 +00:00
|
|
|
|
{
|
|
|
|
|
var user = GetUserInfo(userid);
|
|
|
|
|
|
2019-10-30 08:45:55 +00:00
|
|
|
|
if (UserManager.IsSystemUser(user.ID))
|
2019-09-29 10:50:18 +00:00
|
|
|
|
throw new SecurityException();
|
|
|
|
|
|
2019-10-30 08:45:55 +00:00
|
|
|
|
PermissionContext.DemandPermissions(new UserSecurityProvider(user.ID), Constants.Action_EditUser);
|
2019-09-29 10:50:18 +00:00
|
|
|
|
|
|
|
|
|
var curLng = user.CultureName;
|
|
|
|
|
|
|
|
|
|
if (SetupInfo.EnabledCultures.Find(c => string.Equals(c.Name, memberModel.CultureName, StringComparison.InvariantCultureIgnoreCase)) != null)
|
|
|
|
|
{
|
|
|
|
|
if (curLng != memberModel.CultureName)
|
|
|
|
|
{
|
|
|
|
|
user.CultureName = memberModel.CultureName;
|
|
|
|
|
|
|
|
|
|
try
|
|
|
|
|
{
|
2019-10-30 08:45:55 +00:00
|
|
|
|
UserManager.SaveUserInfo(user);
|
2019-09-29 10:50:18 +00:00
|
|
|
|
}
|
2020-11-17 10:47:17 +00:00
|
|
|
|
catch
|
2019-09-29 10:50:18 +00:00
|
|
|
|
{
|
|
|
|
|
user.CultureName = curLng;
|
2020-11-17 10:47:17 +00:00
|
|
|
|
throw;
|
2019-09-29 10:50:18 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-11-08 12:21:51 +00:00
|
|
|
|
MessageService.Send(MessageAction.UserUpdatedLanguage, MessageTarget.Create(user.ID), user.DisplayUserName(false, DisplayUserSettingsHelper));
|
2019-09-29 10:50:18 +00:00
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return EmployeeWraperFullHelper.GetFull(user);
|
2019-09-29 10:50:18 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
[Update("{userid}")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public EmployeeWraperFull UpdateMemberFromBody(string userid, [FromBody] UpdateMemberModel memberModel)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return UpdateMember(userid, memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Update("{userid}")]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
|
|
|
|
public EmployeeWraperFull UpdateMemberFromForm(string userid, [FromForm] UpdateMemberModel memberModel)
|
|
|
|
|
{
|
|
|
|
|
return UpdateMember(userid, memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private EmployeeWraperFull UpdateMember(string userid, UpdateMemberModel memberModel)
|
2019-06-14 16:14:24 +00:00
|
|
|
|
{
|
2019-07-26 11:37:50 +00:00
|
|
|
|
var user = GetUserInfo(userid);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-09 12:56:33 +00:00
|
|
|
|
if (UserManager.IsSystemUser(user.ID))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
throw new SecurityException();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(new UserSecurityProvider(user.ID), Constants.Action_EditUser);
|
2019-07-26 11:37:50 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
var self = SecurityContext.CurrentAccount.ID.Equals(user.ID);
|
|
|
|
|
var resetDate = new DateTime(1900, 01, 01);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
//Update it
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
var isLdap = user.IsLDAP();
|
|
|
|
|
var isSso = user.IsSSO();
|
2019-09-12 11:34:58 +00:00
|
|
|
|
var isAdmin = WebItemSecurity.IsProductAdministrator(WebItemManager.PeopleProductID, SecurityContext.CurrentAccount.ID);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (!isLdap && !isSso)
|
|
|
|
|
{
|
|
|
|
|
//Set common fields
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
user.FirstName = memberModel.Firstname ?? user.FirstName;
|
|
|
|
|
user.LastName = memberModel.Lastname ?? user.LastName;
|
|
|
|
|
user.Location = memberModel.Location ?? user.Location;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (isAdmin)
|
|
|
|
|
{
|
|
|
|
|
user.Title = memberModel.Title ?? user.Title;
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (!UserFormatter.IsValidUserName(user.FirstName, user.LastName))
|
|
|
|
|
throw new Exception(Resource.ErrorIncorrectUserName);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
user.Notes = memberModel.Comment ?? user.Notes;
|
|
|
|
|
user.Sex = ("male".Equals(memberModel.Sex, StringComparison.OrdinalIgnoreCase)
|
|
|
|
|
? true
|
|
|
|
|
: ("female".Equals(memberModel.Sex, StringComparison.OrdinalIgnoreCase) ? (bool?)false : null)) ?? user.Sex;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
user.BirthDate = memberModel.Birthday != null ? TenantUtil.DateTimeFromUtc(Convert.ToDateTime(memberModel.Birthday)) : user.BirthDate;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (user.BirthDate == resetDate)
|
|
|
|
|
{
|
|
|
|
|
user.BirthDate = null;
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
user.WorkFromDate = memberModel.Worksfrom != null ? TenantUtil.DateTimeFromUtc(Convert.ToDateTime(memberModel.Worksfrom)) : user.WorkFromDate;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (user.WorkFromDate == resetDate)
|
|
|
|
|
{
|
|
|
|
|
user.WorkFromDate = null;
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
//Update contacts
|
|
|
|
|
UpdateContacts(memberModel.Contacts, user);
|
|
|
|
|
UpdateDepartments(memberModel.Department, user);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
if (memberModel.Files != UserPhotoManager.GetPhotoAbsoluteWebPath(user.ID))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
|
|
|
|
UpdatePhotoUrl(memberModel.Files, user);
|
|
|
|
|
}
|
|
|
|
|
if (memberModel.Disable.HasValue)
|
|
|
|
|
{
|
|
|
|
|
user.Status = memberModel.Disable.Value ? EmployeeStatus.Terminated : EmployeeStatus.Active;
|
2021-04-15 11:34:22 +00:00
|
|
|
|
user.TerminatedDate = memberModel.Disable.Value ? DateTime.UtcNow : null;
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (self && !isAdmin)
|
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
StudioNotifyService.SendMsgToAdminAboutProfileUpdated();
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
// change user type
|
2019-09-12 11:34:58 +00:00
|
|
|
|
var canBeGuestFlag = !user.IsOwner(Tenant) && !user.IsAdmin(UserManager) && !user.GetListAdminModules(WebItemSecurity).Any() && !user.IsMe(AuthContext);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
if (memberModel.IsVisitor && !user.IsVisitor(UserManager) && canBeGuestFlag)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.AddUserIntoGroup(user.ID, Constants.GroupVisitor.ID);
|
2019-10-11 15:03:03 +00:00
|
|
|
|
WebItemSecurityCache.ClearCache(Tenant.TenantId);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
if (!self && !memberModel.IsVisitor && user.IsVisitor(UserManager))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
|
|
|
|
var usersQuota = TenantExtra.GetTenantQuota().ActiveUsers;
|
2019-09-12 11:34:58 +00:00
|
|
|
|
if (TenantStatisticsProvider.GetUsersCount() < usersQuota)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.RemoveUserFromGroup(user.ID, Constants.GroupVisitor.ID);
|
2019-10-11 15:03:03 +00:00
|
|
|
|
WebItemSecurityCache.ClearCache(Tenant.TenantId);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
throw new TenantQuotaException(string.Format("Exceeds the maximum active users ({0})", usersQuota));
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2020-10-12 19:39:23 +00:00
|
|
|
|
UserManager.SaveUserInfo(user);
|
2019-11-08 12:21:51 +00:00
|
|
|
|
MessageService.Send(MessageAction.UserUpdated, MessageTarget.Create(user.ID), user.DisplayUserName(false, DisplayUserSettingsHelper));
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (memberModel.Disable.HasValue && memberModel.Disable.Value)
|
|
|
|
|
{
|
2019-09-20 15:53:27 +00:00
|
|
|
|
CookiesManager.ResetUserCookie(user.ID);
|
2019-06-17 13:53:10 +00:00
|
|
|
|
MessageService.Send(MessageAction.CookieSettingsUpdated);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return EmployeeWraperFullHelper.GetFull(user);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
[Delete("{userid}")]
|
|
|
|
|
public EmployeeWraperFull DeleteMember(string userid)
|
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(Constants.Action_AddRemoveUser);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
var user = GetUserInfo(userid);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-09 12:56:33 +00:00
|
|
|
|
if (UserManager.IsSystemUser(user.ID) || user.IsLDAP())
|
2019-06-17 11:57:07 +00:00
|
|
|
|
throw new SecurityException();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (user.Status != EmployeeStatus.Terminated)
|
|
|
|
|
throw new Exception("The user is not suspended");
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-21 10:42:16 +00:00
|
|
|
|
CheckReassignProccess(new[] { user.ID });
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-11-08 12:21:51 +00:00
|
|
|
|
var userName = user.DisplayUserName(false, DisplayUserSettingsHelper);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserPhotoManager.RemovePhoto(user.ID);
|
|
|
|
|
UserManager.DeleteUser(user.ID);
|
2019-08-12 10:53:12 +00:00
|
|
|
|
QueueWorkerRemove.Start(Tenant.TenantId, user, SecurityContext.CurrentAccount.ID, false);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 13:53:10 +00:00
|
|
|
|
MessageService.Send(MessageAction.UserDeleted, MessageTarget.Create(user.ID), userName);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return EmployeeWraperFullHelper.GetFull(user);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-10-04 04:58:38 +00:00
|
|
|
|
[Delete("@self")]
|
|
|
|
|
[Authorize(AuthenticationSchemes = "confirm", Roles = "ProfileRemove")]
|
|
|
|
|
public EmployeeWraperFull DeleteProfile()
|
|
|
|
|
{
|
|
|
|
|
ApiContext.AuthByClaim();
|
|
|
|
|
|
2019-10-30 08:45:55 +00:00
|
|
|
|
if (UserManager.IsSystemUser(SecurityContext.CurrentAccount.ID))
|
2019-10-04 04:58:38 +00:00
|
|
|
|
throw new SecurityException();
|
|
|
|
|
|
|
|
|
|
var user = GetUserInfo(SecurityContext.CurrentAccount.ID.ToString());
|
|
|
|
|
|
2019-10-30 08:45:55 +00:00
|
|
|
|
if (!UserManager.UserExists(user))
|
|
|
|
|
throw new Exception(Resource.ErrorUserNotFound);
|
|
|
|
|
|
|
|
|
|
if (user.IsLDAP())
|
2019-10-04 04:58:38 +00:00
|
|
|
|
throw new SecurityException();
|
|
|
|
|
|
2021-08-18 14:04:16 +00:00
|
|
|
|
SecurityContext.AuthenticateMeWithoutCookie(ASC.Core.Configuration.Constants.CoreSystem);
|
2019-10-04 04:58:38 +00:00
|
|
|
|
|
|
|
|
|
user.Status = EmployeeStatus.Terminated;
|
|
|
|
|
|
2019-10-30 08:45:55 +00:00
|
|
|
|
UserManager.SaveUserInfo(user);
|
2019-10-04 04:58:38 +00:00
|
|
|
|
|
2019-11-08 12:21:51 +00:00
|
|
|
|
var userName = user.DisplayUserName(false, DisplayUserSettingsHelper);
|
2019-10-04 04:58:38 +00:00
|
|
|
|
MessageService.Send(MessageAction.UsersUpdatedStatus, MessageTarget.Create(user.ID), userName);
|
|
|
|
|
|
2019-10-30 08:45:55 +00:00
|
|
|
|
CookiesManager.ResetUserCookie(user.ID);
|
2019-10-04 04:58:38 +00:00
|
|
|
|
MessageService.Send(MessageAction.CookieSettingsUpdated);
|
|
|
|
|
|
2019-10-30 08:45:55 +00:00
|
|
|
|
if (CoreBaseSettings.Personal)
|
2019-10-04 04:58:38 +00:00
|
|
|
|
{
|
2019-10-30 08:45:55 +00:00
|
|
|
|
UserPhotoManager.RemovePhoto(user.ID);
|
|
|
|
|
UserManager.DeleteUser(user.ID);
|
2019-10-04 04:58:38 +00:00
|
|
|
|
MessageService.Send(MessageAction.UserDeleted, MessageTarget.Create(user.ID), userName);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
//StudioNotifyService.Instance.SendMsgProfileHasDeletedItself(user);
|
|
|
|
|
//StudioNotifyService.SendMsgProfileDeletion(Tenant.TenantId, user);
|
|
|
|
|
}
|
|
|
|
|
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return EmployeeWraperFullHelper.GetFull(user);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Update("{userid}/contacts")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public EmployeeWraperFull UpdateMemberContactsFromBody(string userid, [FromBody] UpdateMemberModel memberModel)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return UpdateMemberContacts(userid, memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Update("{userid}/contacts")]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
|
|
|
|
public EmployeeWraperFull UpdateMemberContactsFromForm(string userid, [FromForm] UpdateMemberModel memberModel)
|
|
|
|
|
{
|
|
|
|
|
return UpdateMemberContacts(userid, memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private EmployeeWraperFull UpdateMemberContacts(string userid, UpdateMemberModel memberModel)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
|
|
|
|
var user = GetUserInfo(userid);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-09 12:56:33 +00:00
|
|
|
|
if (UserManager.IsSystemUser(user.ID))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
throw new SecurityException();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
UpdateContacts(memberModel.Contacts, user);
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.SaveUserInfo(user);
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return EmployeeWraperFullHelper.GetFull(user);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Create("{userid}/contacts")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public EmployeeWraperFull SetMemberContactsFromBody(string userid, [FromBody] UpdateMemberModel memberModel)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return SetMemberContacts(userid, memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Create("{userid}/contacts")]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
|
|
|
|
public EmployeeWraperFull SetMemberContactsFromForm(string userid, [FromForm] UpdateMemberModel memberModel)
|
|
|
|
|
{
|
|
|
|
|
return SetMemberContacts(userid, memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
2021-09-17 14:32:37 +00:00
|
|
|
|
private EmployeeWraperFull SetMemberContacts(string userid, UpdateMemberModel memberModel)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
|
|
|
|
var user = GetUserInfo(userid);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-09 12:56:33 +00:00
|
|
|
|
if (UserManager.IsSystemUser(user.ID))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
throw new SecurityException();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
UpdateContacts(memberModel.Contacts, user);
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.SaveUserInfo(user);
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return EmployeeWraperFullHelper.GetFull(user);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Delete("{userid}/contacts")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public EmployeeWraperFull DeleteMemberContactsFromBody(string userid, [FromBody] UpdateMemberModel memberModel)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return DeleteMemberContacts(userid, memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Delete("{userid}/contacts")]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public EmployeeWraperFull DeleteMemberContactsFromForm(string userid, [FromForm] UpdateMemberModel memberModel)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return DeleteMemberContacts(userid, memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private EmployeeWraperFull DeleteMemberContacts(string userid, UpdateMemberModel memberModel)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
|
|
|
|
var user = GetUserInfo(userid);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-09 12:56:33 +00:00
|
|
|
|
if (UserManager.IsSystemUser(user.ID))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
throw new SecurityException();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
DeleteContacts(memberModel.Contacts, user);
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.SaveUserInfo(user);
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return EmployeeWraperFullHelper.GetFull(user);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Read("{userid}/photo")]
|
2019-06-17 11:57:07 +00:00
|
|
|
|
public ThumbnailsDataWrapper GetMemberPhoto(string userid)
|
|
|
|
|
{
|
|
|
|
|
var user = GetUserInfo(userid);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-09 12:56:33 +00:00
|
|
|
|
if (UserManager.IsSystemUser(user.ID))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
throw new SecurityException();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
return new ThumbnailsDataWrapper(user.ID, UserPhotoManager);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-09-24 12:27:13 +00:00
|
|
|
|
|
2020-11-06 09:03:49 +00:00
|
|
|
|
[Create("{userid}/photo")]
|
2020-11-17 15:01:34 +00:00
|
|
|
|
public FileUploadResult UploadMemberPhoto(string userid, IFormCollection model)
|
2019-07-17 08:55:08 +00:00
|
|
|
|
{
|
2019-09-16 12:35:44 +00:00
|
|
|
|
var result = new People.Models.FileUploadResult();
|
2020-05-17 13:08:20 +00:00
|
|
|
|
var autosave = bool.Parse(model["Autosave"]);
|
2019-09-24 14:07:24 +00:00
|
|
|
|
|
2019-07-17 08:55:08 +00:00
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
if (model.Files.Count != 0)
|
|
|
|
|
{
|
|
|
|
|
Guid userId;
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
userId = new Guid(userid);
|
|
|
|
|
}
|
|
|
|
|
catch
|
|
|
|
|
{
|
|
|
|
|
userId = SecurityContext.CurrentAccount.ID;
|
|
|
|
|
}
|
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(new UserSecurityProvider(userId), Constants.Action_EditUser);
|
2019-07-17 08:55:08 +00:00
|
|
|
|
|
|
|
|
|
var userPhoto = model.Files[0];
|
|
|
|
|
|
|
|
|
|
if (userPhoto.Length > SetupInfo.MaxImageUploadSize)
|
|
|
|
|
{
|
|
|
|
|
result.Success = false;
|
|
|
|
|
result.Message = FileSizeComment.FileImageSizeExceptionString;
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var data = new byte[userPhoto.Length];
|
|
|
|
|
using var inputStream = userPhoto.OpenReadStream();
|
|
|
|
|
|
|
|
|
|
var br = new BinaryReader(inputStream);
|
|
|
|
|
br.Read(data, 0, (int)userPhoto.Length);
|
|
|
|
|
br.Close();
|
|
|
|
|
|
|
|
|
|
CheckImgFormat(data);
|
|
|
|
|
|
2019-09-24 14:07:24 +00:00
|
|
|
|
if (autosave)
|
2019-07-17 08:55:08 +00:00
|
|
|
|
{
|
|
|
|
|
if (data.Length > SetupInfo.MaxImageUploadSize)
|
|
|
|
|
throw new ImageSizeLimitException();
|
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
var mainPhoto = UserPhotoManager.SaveOrUpdatePhoto(userId, data);
|
2019-07-17 08:55:08 +00:00
|
|
|
|
|
|
|
|
|
result.Data =
|
|
|
|
|
new
|
|
|
|
|
{
|
|
|
|
|
main = mainPhoto,
|
2019-09-12 11:34:58 +00:00
|
|
|
|
retina = UserPhotoManager.GetRetinaPhotoURL(userId),
|
|
|
|
|
max = UserPhotoManager.GetMaxPhotoURL(userId),
|
|
|
|
|
big = UserPhotoManager.GetBigPhotoURL(userId),
|
|
|
|
|
medium = UserPhotoManager.GetMediumPhotoURL(userId),
|
|
|
|
|
small = UserPhotoManager.GetSmallPhotoURL(userId),
|
2019-07-17 08:55:08 +00:00
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
result.Data = UserPhotoManager.SaveTempPhoto(data, SetupInfo.MaxImageUploadSize, UserPhotoManager.OriginalFotoSize.Width, UserPhotoManager.OriginalFotoSize.Height);
|
2019-07-17 08:55:08 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
result.Success = true;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
result.Success = false;
|
|
|
|
|
result.Message = PeopleResource.ErrorEmptyUploadFileSelected;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
catch (UnknownImageFormatException)
|
|
|
|
|
{
|
|
|
|
|
result.Success = false;
|
|
|
|
|
result.Message = PeopleResource.ErrorUnknownFileImageType;
|
|
|
|
|
}
|
|
|
|
|
catch (ImageWeightLimitException)
|
|
|
|
|
{
|
|
|
|
|
result.Success = false;
|
|
|
|
|
result.Message = PeopleResource.ErrorImageWeightLimit;
|
|
|
|
|
}
|
|
|
|
|
catch (ImageSizeLimitException)
|
|
|
|
|
{
|
|
|
|
|
result.Success = false;
|
|
|
|
|
result.Message = PeopleResource.ErrorImageSizetLimit;
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
result.Success = false;
|
|
|
|
|
result.Message = ex.Message.HtmlEncode();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Update("{userid}/photo")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public ThumbnailsDataWrapper UpdateMemberPhotoFromBody(string userid, [FromBody] UpdateMemberModel model)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return UpdateMemberPhoto(userid, model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Update("{userid}/photo")]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
|
|
|
|
public ThumbnailsDataWrapper UpdateMemberPhotoFromForm(string userid, [FromForm] UpdateMemberModel model)
|
|
|
|
|
{
|
|
|
|
|
return UpdateMemberPhoto(userid, model);
|
|
|
|
|
}
|
|
|
|
|
|
2020-11-06 10:39:25 +00:00
|
|
|
|
private ThumbnailsDataWrapper UpdateMemberPhoto(string userid, UpdateMemberModel model)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
|
|
|
|
var user = GetUserInfo(userid);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-09 12:56:33 +00:00
|
|
|
|
if (UserManager.IsSystemUser(user.ID))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
throw new SecurityException();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
if (model.Files != UserPhotoManager.GetPhotoAbsoluteWebPath(user.ID))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
|
|
|
|
UpdatePhotoUrl(model.Files, user);
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.SaveUserInfo(user);
|
2019-11-08 12:21:51 +00:00
|
|
|
|
MessageService.Send(MessageAction.UserAddedAvatar, MessageTarget.Create(user.ID), user.DisplayUserName(false, DisplayUserSettingsHelper));
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
return new ThumbnailsDataWrapper(user.ID, UserPhotoManager);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Delete("{userid}/photo")]
|
2019-06-17 11:57:07 +00:00
|
|
|
|
public ThumbnailsDataWrapper DeleteMemberPhoto(string userid)
|
|
|
|
|
{
|
|
|
|
|
var user = GetUserInfo(userid);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-09 12:56:33 +00:00
|
|
|
|
if (UserManager.IsSystemUser(user.ID))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
throw new SecurityException();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(new UserSecurityProvider(user.ID), Constants.Action_EditUser);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserPhotoManager.RemovePhoto(user.ID);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.SaveUserInfo(user);
|
2019-11-08 12:21:51 +00:00
|
|
|
|
MessageService.Send(MessageAction.UserDeletedAvatar, MessageTarget.Create(user.ID), user.DisplayUserName(false, DisplayUserSettingsHelper));
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
return new ThumbnailsDataWrapper(user.ID, UserPhotoManager);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Create("{userid}/photo/thumbnails")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public ThumbnailsDataWrapper CreateMemberPhotoThumbnailsFromBody(string userid, [FromBody] ThumbnailsModel thumbnailsModel)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return CreateMemberPhotoThumbnails(userid, thumbnailsModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Create("{userid}/photo/thumbnails")]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
|
|
|
|
public ThumbnailsDataWrapper CreateMemberPhotoThumbnailsFromForm(string userid, [FromForm] ThumbnailsModel thumbnailsModel)
|
|
|
|
|
{
|
|
|
|
|
return CreateMemberPhotoThumbnails(userid, thumbnailsModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private ThumbnailsDataWrapper CreateMemberPhotoThumbnails(string userid, ThumbnailsModel thumbnailsModel)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
|
|
|
|
var user = GetUserInfo(userid);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-09 12:56:33 +00:00
|
|
|
|
if (UserManager.IsSystemUser(user.ID))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
throw new SecurityException();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(new UserSecurityProvider(user.ID), Constants.Action_EditUser);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (!string.IsNullOrEmpty(thumbnailsModel.TmpFile))
|
|
|
|
|
{
|
|
|
|
|
var fileName = Path.GetFileName(thumbnailsModel.TmpFile);
|
2019-09-12 11:34:58 +00:00
|
|
|
|
var data = UserPhotoManager.GetTempPhotoData(fileName);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
var settings = new UserPhotoThumbnailSettings(thumbnailsModel.X, thumbnailsModel.Y, thumbnailsModel.Width, thumbnailsModel.Height);
|
2019-11-08 12:21:51 +00:00
|
|
|
|
SettingsManager.SaveForUser(settings, user.ID);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-12-09 12:59:34 +00:00
|
|
|
|
UserPhotoManager.RemovePhoto(user.ID);
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserPhotoManager.SaveOrUpdatePhoto(user.ID, data);
|
|
|
|
|
UserPhotoManager.RemoveTempPhoto(fileName);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2019-11-08 12:21:51 +00:00
|
|
|
|
UserPhotoThumbnailManager.SaveThumbnails(UserPhotoManager, SettingsManager, thumbnailsModel.X, thumbnailsModel.Y, thumbnailsModel.Width, thumbnailsModel.Height, user.ID);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.SaveUserInfo(user);
|
2019-11-08 12:21:51 +00:00
|
|
|
|
MessageService.Send(MessageAction.UserUpdatedAvatarThumbnails, MessageTarget.Create(user.ID), user.DisplayUserName(false, DisplayUserSettingsHelper));
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
return new ThumbnailsDataWrapper(user.ID, UserPhotoManager);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
[AllowAnonymous]
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Create("password", false)]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public object SendUserPasswordFromBody([FromBody] MemberModel memberModel)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return SendUserPassword(memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[AllowAnonymous]
|
|
|
|
|
[Create("password", false)]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
|
|
|
|
public object SendUserPasswordFromForm([FromForm] MemberModel memberModel)
|
|
|
|
|
{
|
|
|
|
|
return SendUserPassword(memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private object SendUserPassword(MemberModel memberModel)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2020-09-17 12:04:28 +00:00
|
|
|
|
string error;
|
|
|
|
|
if (!string.IsNullOrEmpty(error = UserManagerWrapper.SendUserPassword(memberModel.Email)))
|
|
|
|
|
{
|
|
|
|
|
Log.ErrorFormat("Password recovery ({0}): {1}", memberModel.Email, error);
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2020-09-17 12:04:28 +00:00
|
|
|
|
return string.Format(Resource.MessageYourPasswordSendedToEmail, memberModel.Email);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Update("{userid}/password")]
|
2021-05-05 08:45:13 +00:00
|
|
|
|
[Authorize(AuthenticationSchemes = "confirm", Roles = "PasswordChange,EmailChange,Activation,EmailActivation,Everyone")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public EmployeeWraperFull ChangeUserPasswordFromBody(Guid userid, [FromBody] MemberModel memberModel)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return ChangeUserPassword(userid, memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Update("{userid}/password")]
|
2021-05-05 08:45:13 +00:00
|
|
|
|
[Authorize(AuthenticationSchemes = "confirm", Roles = "PasswordChange,EmailChange,Activation,EmailActivation,Everyone")]
|
2020-11-06 09:03:49 +00:00
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
|
|
|
|
public EmployeeWraperFull ChangeUserPasswordFromForm(Guid userid, [FromForm] MemberModel memberModel)
|
|
|
|
|
{
|
|
|
|
|
return ChangeUserPassword(userid, memberModel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private EmployeeWraperFull ChangeUserPassword(Guid userid, MemberModel memberModel)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2019-09-23 15:36:22 +00:00
|
|
|
|
ApiContext.AuthByClaim();
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(new UserSecurityProvider(userid), Constants.Action_EditUser);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
var user = UserManager.GetUsers(userid);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-09 12:56:33 +00:00
|
|
|
|
if (!UserManager.UserExists(user)) return null;
|
2019-08-30 12:40:57 +00:00
|
|
|
|
|
2019-09-09 12:56:33 +00:00
|
|
|
|
if (UserManager.IsSystemUser(user.ID))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
throw new SecurityException();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (!string.IsNullOrEmpty(memberModel.Email))
|
|
|
|
|
{
|
|
|
|
|
var address = new MailAddress(memberModel.Email);
|
|
|
|
|
if (!string.Equals(address.Address, user.Email, StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
{
|
|
|
|
|
user.Email = address.Address.ToLowerInvariant();
|
|
|
|
|
user.ActivationStatus = EmployeeActivationStatus.Activated;
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.SaveUserInfo(user);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2020-09-30 14:16:48 +00:00
|
|
|
|
memberModel.PasswordHash = (memberModel.PasswordHash ?? "").Trim();
|
|
|
|
|
if (string.IsNullOrEmpty(memberModel.PasswordHash))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2020-09-30 14:16:48 +00:00
|
|
|
|
memberModel.Password = (memberModel.Password ?? "").Trim();
|
|
|
|
|
|
|
|
|
|
if (!string.IsNullOrEmpty(memberModel.Password))
|
|
|
|
|
{
|
|
|
|
|
memberModel.PasswordHash = PasswordHasher.GetClientPassword(memberModel.Password);
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-09-17 12:04:28 +00:00
|
|
|
|
|
2020-09-30 14:16:48 +00:00
|
|
|
|
if (!string.IsNullOrEmpty(memberModel.PasswordHash))
|
|
|
|
|
{
|
|
|
|
|
SecurityContext.SetUserPasswordHash(userid, memberModel.PasswordHash);
|
2019-06-17 13:53:10 +00:00
|
|
|
|
MessageService.Send(MessageAction.UserUpdatedPassword);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-20 15:53:27 +00:00
|
|
|
|
CookiesManager.ResetUserCookie(userid);
|
2019-06-17 13:53:10 +00:00
|
|
|
|
MessageService.Send(MessageAction.CookieSettingsUpdated);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return EmployeeWraperFullHelper.GetFull(GetUserInfo(userid.ToString()));
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-13 14:30:24 +00:00
|
|
|
|
|
|
|
|
|
[Create("email", false)]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public object SendEmailChangeInstructionsFromBody([FromBody] UpdateMemberModel model)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return SendEmailChangeInstructions(model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Create("email", false)]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
|
|
|
|
public object SendEmailChangeInstructionsFromForm([FromForm] UpdateMemberModel model)
|
|
|
|
|
{
|
|
|
|
|
return SendEmailChangeInstructions(model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private object SendEmailChangeInstructions(UpdateMemberModel model)
|
2019-09-13 14:30:24 +00:00
|
|
|
|
{
|
2019-09-16 12:35:44 +00:00
|
|
|
|
Guid.TryParse(model.UserId, out var userid);
|
2019-09-13 14:30:24 +00:00
|
|
|
|
|
|
|
|
|
if (userid == Guid.Empty) throw new ArgumentNullException("userid");
|
|
|
|
|
|
|
|
|
|
var email = (model.Email ?? "").Trim();
|
|
|
|
|
|
|
|
|
|
if (string.IsNullOrEmpty(email)) throw new Exception(Resource.ErrorEmailEmpty);
|
|
|
|
|
|
|
|
|
|
if (!email.TestEmailRegex()) throw new Exception(Resource.ErrorNotCorrectEmail);
|
|
|
|
|
|
2019-09-16 12:35:44 +00:00
|
|
|
|
var viewer = UserManager.GetUsers(SecurityContext.CurrentAccount.ID);
|
|
|
|
|
var user = UserManager.GetUsers(userid);
|
2019-09-13 14:30:24 +00:00
|
|
|
|
|
|
|
|
|
if (user == null)
|
|
|
|
|
throw new Exception(Resource.ErrorUserNotFound);
|
|
|
|
|
|
|
|
|
|
if (viewer == null || (user.IsOwner(Tenant) && viewer.ID != user.ID))
|
|
|
|
|
throw new Exception(Resource.ErrorAccessDenied);
|
|
|
|
|
|
2019-09-16 12:35:44 +00:00
|
|
|
|
var existentUser = UserManager.GetUserByEmail(email);
|
2019-09-13 14:30:24 +00:00
|
|
|
|
|
|
|
|
|
if (existentUser.ID != Constants.LostUser.ID)
|
|
|
|
|
throw new Exception(CustomNamingPeople.Substitute<Resource>("ErrorEmailAlreadyExists"));
|
|
|
|
|
|
2019-09-16 12:35:44 +00:00
|
|
|
|
if (!viewer.IsAdmin(UserManager))
|
2019-09-13 14:30:24 +00:00
|
|
|
|
{
|
2019-09-17 12:42:32 +00:00
|
|
|
|
StudioNotifyService.SendEmailChangeInstructions(user, email);
|
2019-09-13 14:30:24 +00:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (email == user.Email)
|
|
|
|
|
throw new Exception(Resource.ErrorEmailsAreTheSame);
|
|
|
|
|
|
|
|
|
|
user.Email = email;
|
|
|
|
|
user.ActivationStatus = EmployeeActivationStatus.NotActivated;
|
2019-09-16 12:35:44 +00:00
|
|
|
|
UserManager.SaveUserInfo(user);
|
2019-09-17 12:42:32 +00:00
|
|
|
|
StudioNotifyService.SendEmailActivationInstructions(user, email);
|
2019-09-13 14:30:24 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-11-08 12:21:51 +00:00
|
|
|
|
MessageService.Send(MessageAction.UserSentEmailChangeInstructions, user.DisplayUserName(false, DisplayUserSettingsHelper));
|
2019-09-13 14:30:24 +00:00
|
|
|
|
|
|
|
|
|
return string.Format(Resource.MessageEmailChangeInstuctionsSentOnEmail, email);
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-08 09:26:58 +00:00
|
|
|
|
private UserInfo GetUserInfo(string userNameOrId)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
|
|
|
|
UserInfo user;
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
var userId = new Guid(userNameOrId);
|
2019-09-12 11:34:58 +00:00
|
|
|
|
user = UserManager.GetUsers(userId);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
|
|
|
|
catch (FormatException)
|
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
user = UserManager.GetUserByUserName(userNameOrId);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
|
|
|
|
if (user == null || user.ID == Constants.LostUser.ID)
|
|
|
|
|
throw new ItemNotFoundException("user not found");
|
|
|
|
|
return user;
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
[Update("activationstatus/{activationstatus}")]
|
2021-05-05 08:45:13 +00:00
|
|
|
|
[Authorize(AuthenticationSchemes = "confirm", Roles = "Activation,Everyone")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public IEnumerable<EmployeeWraperFull> UpdateEmployeeActivationStatusFromBody(EmployeeActivationStatus activationstatus, [FromBody] UpdateMembersModel model)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return UpdateEmployeeActivationStatus(activationstatus, model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Update("activationstatus/{activationstatus}")]
|
2021-05-05 08:45:13 +00:00
|
|
|
|
[Authorize(AuthenticationSchemes = "confirm", Roles = "Activation,Everyone")]
|
2020-11-06 09:03:49 +00:00
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
|
|
|
|
public IEnumerable<EmployeeWraperFull> UpdateEmployeeActivationStatusFromForm(EmployeeActivationStatus activationstatus, [FromForm] UpdateMembersModel model)
|
|
|
|
|
{
|
|
|
|
|
return UpdateEmployeeActivationStatus(activationstatus, model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private IEnumerable<EmployeeWraperFull> UpdateEmployeeActivationStatus(EmployeeActivationStatus activationstatus, UpdateMembersModel model)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2019-09-27 09:20:10 +00:00
|
|
|
|
ApiContext.AuthByClaim();
|
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
var retuls = new List<EmployeeWraperFull>();
|
2019-09-09 12:56:33 +00:00
|
|
|
|
foreach (var id in model.UserIds.Where(userId => !UserManager.IsSystemUser(userId)))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(new UserSecurityProvider(id), Constants.Action_EditUser);
|
|
|
|
|
var u = UserManager.GetUsers(id);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (u.ID == Constants.LostUser.ID || u.IsLDAP()) continue;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
u.ActivationStatus = activationstatus;
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.SaveUserInfo(u);
|
2019-11-11 15:42:07 +00:00
|
|
|
|
retuls.Add(EmployeeWraperFullHelper.GetFull(u));
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
return retuls;
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2020-11-06 09:03:49 +00:00
|
|
|
|
[Update("type/{type}")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public IEnumerable<EmployeeWraperFull> UpdateUserTypeFromBody(EmployeeType type, [FromBody] UpdateMembersModel model)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return UpdateUserType(type, model);
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
[Update("type/{type}")]
|
2020-11-06 09:03:49 +00:00
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
|
|
|
|
public IEnumerable<EmployeeWraperFull> UpdateUserTypeFromForm(EmployeeType type, [FromForm] UpdateMembersModel model)
|
|
|
|
|
{
|
|
|
|
|
return UpdateUserType(type, model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private IEnumerable<EmployeeWraperFull> UpdateUserType(EmployeeType type, UpdateMembersModel model)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
|
|
|
|
var users = model.UserIds
|
2019-09-09 12:56:33 +00:00
|
|
|
|
.Where(userId => !UserManager.IsSystemUser(userId))
|
2019-09-12 11:34:58 +00:00
|
|
|
|
.Select(userId => UserManager.GetUsers(userId))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
.ToList();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
foreach (var user in users)
|
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
if (user.IsOwner(Tenant) || user.IsAdmin(UserManager) || user.IsMe(AuthContext) || user.GetListAdminModules(WebItemSecurity).Any())
|
2019-06-17 11:57:07 +00:00
|
|
|
|
continue;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
switch (type)
|
|
|
|
|
{
|
|
|
|
|
case EmployeeType.User:
|
2019-09-12 11:34:58 +00:00
|
|
|
|
if (user.IsVisitor(UserManager))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
if (TenantStatisticsProvider.GetUsersCount() < TenantExtra.GetTenantQuota().ActiveUsers)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.RemoveUserFromGroup(user.ID, Constants.GroupVisitor.ID);
|
2019-10-11 15:03:03 +00:00
|
|
|
|
WebItemSecurityCache.ClearCache(Tenant.TenantId);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case EmployeeType.Visitor:
|
2021-05-23 16:11:25 +00:00
|
|
|
|
if (CoreBaseSettings.Standalone || TenantStatisticsProvider.GetVisitorsCount() < TenantExtra.GetTenantQuota().ActiveUsers * Constants.CoefficientOfVisitors)
|
|
|
|
|
{
|
|
|
|
|
UserManager.AddUserIntoGroup(user.ID, Constants.GroupVisitor.ID);
|
|
|
|
|
WebItemSecurityCache.ClearCache(Tenant.TenantId);
|
|
|
|
|
}
|
2019-06-17 11:57:07 +00:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-11-08 12:21:51 +00:00
|
|
|
|
MessageService.Send(MessageAction.UsersUpdatedType, MessageTarget.Create(users.Select(x => x.ID)), users.Select(x => x.DisplayUserName(false, DisplayUserSettingsHelper)));
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return users.Select(EmployeeWraperFullHelper.GetFull);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
[Update("status/{status}")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public IEnumerable<EmployeeWraperFull> UpdateUserStatusFromBody(EmployeeStatus status, [FromBody] UpdateMembersModel model)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return UpdateUserStatus(status, model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Update("status/{status}")]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
|
|
|
|
public IEnumerable<EmployeeWraperFull> UpdateUserStatusFromForm(EmployeeStatus status, [FromForm] UpdateMembersModel model)
|
|
|
|
|
{
|
|
|
|
|
return UpdateUserStatus(status, model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private IEnumerable<EmployeeWraperFull> UpdateUserStatus(EmployeeStatus status, UpdateMembersModel model)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(Constants.Action_EditUser);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
var users = model.UserIds.Select(userId => UserManager.GetUsers(userId))
|
2019-09-09 12:56:33 +00:00
|
|
|
|
.Where(u => !UserManager.IsSystemUser(u.ID) && !u.IsLDAP())
|
2019-06-17 11:57:07 +00:00
|
|
|
|
.ToList();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
foreach (var user in users)
|
|
|
|
|
{
|
2019-09-09 12:56:33 +00:00
|
|
|
|
if (user.IsOwner(Tenant) || user.IsMe(AuthContext))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
continue;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
switch (status)
|
|
|
|
|
{
|
|
|
|
|
case EmployeeStatus.Active:
|
|
|
|
|
if (user.Status == EmployeeStatus.Terminated)
|
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
if (TenantStatisticsProvider.GetUsersCount() < TenantExtra.GetTenantQuota().ActiveUsers || user.IsVisitor(UserManager))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
|
|
|
|
user.Status = EmployeeStatus.Active;
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.SaveUserInfo(user);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case EmployeeStatus.Terminated:
|
|
|
|
|
user.Status = EmployeeStatus.Terminated;
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.SaveUserInfo(user);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-20 15:53:27 +00:00
|
|
|
|
CookiesManager.ResetUserCookie(user.ID);
|
2019-06-17 13:53:10 +00:00
|
|
|
|
MessageService.Send(MessageAction.CookieSettingsUpdated);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-11-08 12:21:51 +00:00
|
|
|
|
MessageService.Send(MessageAction.UsersUpdatedStatus, MessageTarget.Create(users.Select(x => x.ID)), users.Select(x => x.DisplayUserName(false, DisplayUserSettingsHelper)));
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return users.Select(EmployeeWraperFullHelper.GetFull);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Update("invite")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public IEnumerable<EmployeeWraperFull> ResendUserInvitesFromBody([FromBody] UpdateMembersModel model)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return ResendUserInvites(model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Update("invite")]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
|
|
|
|
public IEnumerable<EmployeeWraperFull> ResendUserInvitesFromForm([FromForm] UpdateMembersModel model)
|
|
|
|
|
{
|
|
|
|
|
return ResendUserInvites(model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private IEnumerable<EmployeeWraperFull> ResendUserInvites(UpdateMembersModel model)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
|
|
|
|
var users = model.UserIds
|
2019-09-09 12:56:33 +00:00
|
|
|
|
.Where(userId => !UserManager.IsSystemUser(userId))
|
2019-09-12 11:34:58 +00:00
|
|
|
|
.Select(userId => UserManager.GetUsers(userId))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
.ToList();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
foreach (var user in users)
|
|
|
|
|
{
|
|
|
|
|
if (user.IsActive) continue;
|
2020-12-22 12:54:34 +00:00
|
|
|
|
var viewer = UserManager.GetUsers(SecurityContext.CurrentAccount.ID);
|
|
|
|
|
|
|
|
|
|
if (user == null) throw new Exception(Resource.ErrorUserNotFound);
|
|
|
|
|
|
|
|
|
|
if (viewer == null) throw new Exception(Resource.ErrorAccessDenied);
|
|
|
|
|
|
|
|
|
|
if (viewer.IsAdmin(UserManager) || viewer.ID == user.ID)
|
|
|
|
|
{
|
|
|
|
|
if (user.ActivationStatus == EmployeeActivationStatus.Activated)
|
|
|
|
|
{
|
|
|
|
|
user.ActivationStatus = EmployeeActivationStatus.NotActivated;
|
|
|
|
|
}
|
|
|
|
|
if (user.ActivationStatus == (EmployeeActivationStatus.AutoGenerated | EmployeeActivationStatus.Activated))
|
|
|
|
|
{
|
|
|
|
|
user.ActivationStatus = EmployeeActivationStatus.AutoGenerated;
|
|
|
|
|
}
|
|
|
|
|
UserManager.SaveUserInfo(user);
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (user.ActivationStatus == EmployeeActivationStatus.Pending)
|
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
if (user.IsVisitor(UserManager))
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2019-09-20 15:53:27 +00:00
|
|
|
|
StudioNotifyService.GuestInfoActivation(user);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2019-09-20 15:53:27 +00:00
|
|
|
|
StudioNotifyService.UserInfoActivation(user);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2019-09-17 12:42:32 +00:00
|
|
|
|
StudioNotifyService.SendEmailActivationInstructions(user, user.Email);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-11-08 12:21:51 +00:00
|
|
|
|
MessageService.Send(MessageAction.UsersSentActivationInstructions, MessageTarget.Create(users.Select(x => x.ID)), users.Select(x => x.DisplayUserName(false, DisplayUserSettingsHelper)));
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return users.Select(EmployeeWraperFullHelper.GetFull);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-03 11:10:32 +00:00
|
|
|
|
[Update("delete", Order = -1)]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public IEnumerable<EmployeeWraperFull> RemoveUsersFromBody([FromBody] UpdateMembersModel model)
|
2020-11-06 09:03:49 +00:00
|
|
|
|
{
|
|
|
|
|
return RemoveUsers(model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Update("delete", Order = -1)]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
|
|
|
|
public IEnumerable<EmployeeWraperFull> RemoveUsersFromForm([FromForm] UpdateMembersModel model)
|
|
|
|
|
{
|
|
|
|
|
return RemoveUsers(model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private IEnumerable<EmployeeWraperFull> RemoveUsers(UpdateMembersModel model)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(Constants.Action_AddRemoveUser);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-21 10:42:16 +00:00
|
|
|
|
CheckReassignProccess(model.UserIds);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
var users = model.UserIds.Select(userId => UserManager.GetUsers(userId))
|
2019-09-09 12:56:33 +00:00
|
|
|
|
.Where(u => !UserManager.IsSystemUser(u.ID) && !u.IsLDAP())
|
2019-06-17 11:57:07 +00:00
|
|
|
|
.ToList();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-11-08 12:21:51 +00:00
|
|
|
|
var userNames = users.Select(x => x.DisplayUserName(false, DisplayUserSettingsHelper)).ToList();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
foreach (var user in users)
|
|
|
|
|
{
|
|
|
|
|
if (user.Status != EmployeeStatus.Terminated) continue;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserPhotoManager.RemovePhoto(user.ID);
|
|
|
|
|
UserManager.DeleteUser(user.ID);
|
2019-08-12 10:53:12 +00:00
|
|
|
|
QueueWorkerRemove.Start(Tenant.TenantId, user, SecurityContext.CurrentAccount.ID, false);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 13:53:10 +00:00
|
|
|
|
MessageService.Send(MessageAction.UsersDeleted, MessageTarget.Create(users.Select(x => x.ID)), userNames);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-11-11 15:42:07 +00:00
|
|
|
|
return users.Select(EmployeeWraperFullHelper.GetFull);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Update("self/delete")]
|
2020-10-09 10:05:48 +00:00
|
|
|
|
public object SendInstructionsToDelete()
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
var user = UserManager.GetUsers(SecurityContext.CurrentAccount.ID);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (user.IsLDAP())
|
|
|
|
|
throw new SecurityException();
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-17 12:42:32 +00:00
|
|
|
|
StudioNotifyService.SendMsgProfileDeletion(user);
|
2019-06-17 13:53:10 +00:00
|
|
|
|
MessageService.Send(MessageAction.UserSentDeleteInstructions);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
return string.Format(Resource.SuccessfullySentNotificationDeleteUserInfoMessage, "<b>" + user.Email + "</b>");
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2021-04-25 08:46:44 +00:00
|
|
|
|
[AllowAnonymous]
|
|
|
|
|
[Read("thirdparty/providers")]
|
|
|
|
|
public ICollection<AccountInfo> GetAuthProviders(bool inviteView, bool settingsView, string clientCallback, string fromOnly)
|
|
|
|
|
{
|
|
|
|
|
ICollection<AccountInfo> infos = new List<AccountInfo>();
|
|
|
|
|
IEnumerable<LoginProfile> linkedAccounts = new List<LoginProfile>();
|
|
|
|
|
|
|
|
|
|
if (AuthContext.IsAuthenticated)
|
|
|
|
|
{
|
|
|
|
|
linkedAccounts = AccountLinker.Get("webstudio").GetLinkedProfiles(AuthContext.CurrentAccount.ID.ToString());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fromOnly = string.IsNullOrWhiteSpace(fromOnly) ? string.Empty : fromOnly.ToLower();
|
|
|
|
|
|
|
|
|
|
foreach (var provider in ProviderManager.AuthProviders.Where(provider => string.IsNullOrEmpty(fromOnly) || fromOnly == provider || (provider == "google" && fromOnly == "openid")))
|
|
|
|
|
{
|
|
|
|
|
if (inviteView && provider.ToLower() == "twitter") continue;
|
|
|
|
|
|
|
|
|
|
var loginProvider = ProviderManager.GetLoginProvider(provider);
|
|
|
|
|
if (loginProvider != null && loginProvider.IsEnabled)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
var url = VirtualPathUtility.ToAbsolute("~/login.ashx") + $"?auth={provider}";
|
|
|
|
|
var mode = (settingsView || inviteView || (!MobileDetector.IsMobile() && !Request.DesktopApp())
|
|
|
|
|
? ("&mode=popup&callback=" + clientCallback)
|
|
|
|
|
: ("&mode=Redirect&returnurl="
|
|
|
|
|
+ HttpUtility.UrlEncode(new Uri(Request.GetUrlRewriter(),
|
|
|
|
|
"Auth.aspx"
|
|
|
|
|
+ (Request.DesktopApp() ? "?desktop=true" : "")
|
|
|
|
|
).ToString())
|
|
|
|
|
));
|
|
|
|
|
|
|
|
|
|
infos.Add(new AccountInfo
|
|
|
|
|
{
|
|
|
|
|
Linked = linkedAccounts.Any(x => x.Provider == provider),
|
|
|
|
|
Provider = provider,
|
|
|
|
|
Url = url + mode
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return infos;
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Update("thirdparty/linkaccount")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public void LinkAccountFromBody([FromBody] LinkAccountModel model)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2020-11-10 10:41:32 +00:00
|
|
|
|
LinkAccount(model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Update("thirdparty/linkaccount")]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public void LinkAccountFromForm([FromForm] LinkAccountModel model)
|
2020-11-10 10:41:32 +00:00
|
|
|
|
{
|
|
|
|
|
LinkAccount(model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void LinkAccount(LinkAccountModel model)
|
|
|
|
|
{
|
|
|
|
|
var profile = new LoginProfile(Signature, InstanceCrypto, model.SerializedProfile);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2021-05-23 16:11:25 +00:00
|
|
|
|
if (!(CoreBaseSettings.Standalone || TenantExtra.GetTenantQuota().Oauth))
|
|
|
|
|
{
|
|
|
|
|
throw new Exception("ErrorNotAllowedOption");
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (string.IsNullOrEmpty(profile.AuthorizationError))
|
|
|
|
|
{
|
|
|
|
|
GetLinker().AddLink(SecurityContext.CurrentAccount.ID.ToString(), profile);
|
2019-06-17 13:53:10 +00:00
|
|
|
|
MessageService.Send(MessageAction.UserLinkedSocialAccount, GetMeaningfulProviderName(profile.Provider));
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// ignore cancellation
|
|
|
|
|
if (profile.AuthorizationError != "Canceled at provider")
|
|
|
|
|
{
|
|
|
|
|
throw new Exception(profile.AuthorizationError);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Delete("thirdparty/unlinkaccount")]
|
2019-06-17 11:57:07 +00:00
|
|
|
|
public void UnlinkAccount(string provider)
|
|
|
|
|
{
|
|
|
|
|
GetLinker().RemoveProvider(SecurityContext.CurrentAccount.ID.ToString(), provider);
|
2019-06-17 13:53:10 +00:00
|
|
|
|
MessageService.Send(MessageAction.UserUnlinkedSocialAccount, GetMeaningfulProviderName(provider));
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2021-04-15 11:34:22 +00:00
|
|
|
|
[AllowAnonymous]
|
|
|
|
|
[Create("thirdparty/signup")]
|
2021-04-16 13:33:17 +00:00
|
|
|
|
public void SignupAccountFromBody([FromBody] SignupAccountModel model)
|
2021-04-15 11:34:22 +00:00
|
|
|
|
{
|
2021-04-16 13:33:17 +00:00
|
|
|
|
SignupAccount(model);
|
2021-04-15 11:34:22 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[AllowAnonymous]
|
2021-04-16 13:33:17 +00:00
|
|
|
|
[Create("thirdparty/signup")]
|
2021-04-15 11:34:22 +00:00
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
2021-04-16 13:33:17 +00:00
|
|
|
|
public void SignupAccountFromForm([FromForm] SignupAccountModel model)
|
2021-04-15 11:34:22 +00:00
|
|
|
|
{
|
2021-04-16 13:33:17 +00:00
|
|
|
|
SignupAccount(model);
|
2021-04-15 11:34:22 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void SignupAccount(SignupAccountModel model)
|
|
|
|
|
{
|
|
|
|
|
var employeeType = model.EmplType ?? EmployeeType.User;
|
|
|
|
|
var passwordHash = model.PasswordHash;
|
|
|
|
|
var mustChangePassword = false;
|
|
|
|
|
|
|
|
|
|
if (string.IsNullOrEmpty(passwordHash))
|
|
|
|
|
{
|
|
|
|
|
passwordHash = UserManagerWrapper.GeneratePassword();
|
|
|
|
|
mustChangePassword = true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var thirdPartyProfile = new LoginProfile(Signature, InstanceCrypto, model.SerializedProfile);
|
2021-04-16 18:50:50 +00:00
|
|
|
|
if (!string.IsNullOrEmpty(thirdPartyProfile.AuthorizationError))
|
|
|
|
|
{
|
|
|
|
|
// ignore cancellation
|
|
|
|
|
if (thirdPartyProfile.AuthorizationError != "Canceled at provider")
|
|
|
|
|
throw new Exception(thirdPartyProfile.AuthorizationError);
|
2021-04-15 11:34:22 +00:00
|
|
|
|
|
2021-04-16 18:50:50 +00:00
|
|
|
|
return;
|
|
|
|
|
}
|
2021-04-15 11:34:22 +00:00
|
|
|
|
|
2021-04-16 18:50:50 +00:00
|
|
|
|
if (string.IsNullOrEmpty(thirdPartyProfile.EMail))
|
2021-04-15 11:34:22 +00:00
|
|
|
|
{
|
2021-04-16 18:50:50 +00:00
|
|
|
|
throw new Exception(Resource.ErrorNotCorrectEmail);
|
2021-04-15 11:34:22 +00:00
|
|
|
|
}
|
|
|
|
|
|
2021-04-16 18:50:50 +00:00
|
|
|
|
var userID = Guid.Empty;
|
|
|
|
|
try
|
|
|
|
|
{
|
2021-08-18 14:04:16 +00:00
|
|
|
|
SecurityContext.AuthenticateMeWithoutCookie(ASC.Core.Configuration.Constants.CoreSystem);
|
2021-04-16 18:50:50 +00:00
|
|
|
|
var newUser = CreateNewUser(GetFirstName(model, thirdPartyProfile), GetLastName(model, thirdPartyProfile), GetEmailAddress(model, thirdPartyProfile), passwordHash, employeeType, false);
|
|
|
|
|
|
|
|
|
|
var messageAction = employeeType == EmployeeType.User ? MessageAction.UserCreatedViaInvite : MessageAction.GuestCreatedViaInvite;
|
|
|
|
|
MessageService.Send(MessageInitiator.System, messageAction, MessageTarget.Create(newUser.ID), newUser.DisplayUserName(false, DisplayUserSettingsHelper));
|
|
|
|
|
|
|
|
|
|
userID = newUser.ID;
|
|
|
|
|
if (!string.IsNullOrEmpty(thirdPartyProfile.Avatar))
|
|
|
|
|
{
|
|
|
|
|
SaveContactImage(userID, thirdPartyProfile.Avatar);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
GetLinker().AddLink(userID.ToString(), thirdPartyProfile);
|
|
|
|
|
}
|
|
|
|
|
finally
|
|
|
|
|
{
|
|
|
|
|
SecurityContext.Logout();
|
|
|
|
|
}
|
2021-04-15 11:34:22 +00:00
|
|
|
|
|
|
|
|
|
var user = UserManager.GetUsers(userID);
|
|
|
|
|
var cookiesKey = SecurityContext.AuthenticateMe(user.Email, passwordHash);
|
|
|
|
|
CookiesManager.SetCookies(CookiesType.AuthKey, cookiesKey);
|
|
|
|
|
MessageService.Send(MessageAction.LoginSuccess);
|
|
|
|
|
StudioNotifyService.UserHasJoin();
|
|
|
|
|
|
|
|
|
|
if (mustChangePassword)
|
|
|
|
|
{
|
|
|
|
|
StudioNotifyService.UserPasswordChange(user);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
UserHelpTourHelper.IsNewUser = true;
|
|
|
|
|
if (CoreBaseSettings.Personal)
|
|
|
|
|
PersonalSettingsHelper.IsNewUser = true;
|
2021-04-16 18:50:50 +00:00
|
|
|
|
|
2021-04-15 11:34:22 +00:00
|
|
|
|
}
|
|
|
|
|
|
2021-04-16 15:32:31 +00:00
|
|
|
|
[Create("phone")]
|
|
|
|
|
public object SendNotificationToChangeFromBody([FromBody] UpdateMemberModel model)
|
|
|
|
|
{
|
|
|
|
|
return SendNotificationToChange(model.UserId);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Create("phone")]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
|
|
|
|
public object SendNotificationToChangeFromForm([FromForm] UpdateMemberModel model)
|
|
|
|
|
{
|
|
|
|
|
return SendNotificationToChange(model.UserId);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public object SendNotificationToChange(string userId)
|
|
|
|
|
{
|
|
|
|
|
var user = UserManager.GetUsers(
|
|
|
|
|
string.IsNullOrEmpty(userId)
|
|
|
|
|
? SecurityContext.CurrentAccount.ID
|
|
|
|
|
: new Guid(userId));
|
|
|
|
|
|
|
|
|
|
var canChange =
|
|
|
|
|
user.IsMe(AuthContext)
|
|
|
|
|
|| PermissionContext.CheckPermissions(new UserSecurityProvider(user.ID), Constants.Action_EditUser);
|
|
|
|
|
|
|
|
|
|
if (!canChange)
|
|
|
|
|
throw new SecurityAccessDeniedException(Resource.ErrorAccessDenied);
|
|
|
|
|
|
|
|
|
|
user.MobilePhoneActivationStatus = MobilePhoneActivationStatus.NotActivated;
|
|
|
|
|
UserManager.SaveUserInfo(user);
|
|
|
|
|
|
|
|
|
|
if (user.IsMe(AuthContext))
|
|
|
|
|
{
|
|
|
|
|
return CommonLinkUtility.GetConfirmationUrl(user.Email, ConfirmType.PhoneActivation);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
StudioNotifyService.SendMsgMobilePhoneChange(user);
|
|
|
|
|
return string.Empty;
|
|
|
|
|
}
|
|
|
|
|
|
2021-04-15 11:34:22 +00:00
|
|
|
|
protected string GetEmailAddress(SignupAccountModel model)
|
|
|
|
|
{
|
|
|
|
|
if (!string.IsNullOrEmpty(model.Email))
|
|
|
|
|
return model.Email.Trim();
|
|
|
|
|
|
|
|
|
|
return string.Empty;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private string GetEmailAddress(SignupAccountModel model, LoginProfile account)
|
|
|
|
|
{
|
|
|
|
|
var value = GetEmailAddress(model);
|
|
|
|
|
return string.IsNullOrEmpty(value) ? account.EMail : value;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected string GetFirstName(SignupAccountModel model)
|
|
|
|
|
{
|
|
|
|
|
var value = string.Empty;
|
|
|
|
|
if (!string.IsNullOrEmpty(model.FirstName)) value = model.FirstName.Trim();
|
|
|
|
|
return HtmlUtil.GetText(value);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private string GetFirstName(SignupAccountModel model, LoginProfile account)
|
|
|
|
|
{
|
|
|
|
|
var value = GetFirstName(model);
|
|
|
|
|
return string.IsNullOrEmpty(value) ? account.FirstName : value;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected string GetLastName(SignupAccountModel model)
|
|
|
|
|
{
|
|
|
|
|
var value = string.Empty;
|
|
|
|
|
if (!string.IsNullOrEmpty(model.LastName)) value = model.LastName.Trim();
|
|
|
|
|
return HtmlUtil.GetText(value);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private string GetLastName(SignupAccountModel model, LoginProfile account)
|
|
|
|
|
{
|
|
|
|
|
var value = GetLastName(model);
|
|
|
|
|
return string.IsNullOrEmpty(value) ? account.LastName : value;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private UserInfo CreateNewUser(string firstName, string lastName, string email, string passwordHash, EmployeeType employeeType, bool fromInviteLink)
|
|
|
|
|
{
|
|
|
|
|
var isVisitor = employeeType == EmployeeType.Visitor;
|
|
|
|
|
|
|
|
|
|
if (SetupInfo.IsSecretEmail(email))
|
|
|
|
|
{
|
|
|
|
|
fromInviteLink = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var userInfo = new UserInfo
|
|
|
|
|
{
|
|
|
|
|
FirstName = string.IsNullOrEmpty(firstName) ? UserControlsCommonResource.UnknownFirstName : firstName,
|
|
|
|
|
LastName = string.IsNullOrEmpty(lastName) ? UserControlsCommonResource.UnknownLastName : lastName,
|
|
|
|
|
Email = email,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
if (CoreBaseSettings.Personal)
|
|
|
|
|
{
|
|
|
|
|
userInfo.ActivationStatus = EmployeeActivationStatus.Activated;
|
|
|
|
|
userInfo.CultureName = CoreBaseSettings.CustomMode ? "ru-RU" : Thread.CurrentThread.CurrentUICulture.Name;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return UserManagerWrapper.AddUser(userInfo, passwordHash, true, true, isVisitor, fromInviteLink);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void SaveContactImage(Guid userID, string url)
|
|
|
|
|
{
|
|
|
|
|
using (var memstream = new MemoryStream())
|
|
|
|
|
{
|
|
|
|
|
var req = WebRequest.Create(url);
|
|
|
|
|
using (var response = req.GetResponse())
|
|
|
|
|
using (var stream = response.GetResponseStream())
|
|
|
|
|
{
|
|
|
|
|
var buffer = new byte[512];
|
|
|
|
|
int bytesRead;
|
|
|
|
|
while ((bytesRead = stream.Read(buffer, 0, buffer.Length)) > 0)
|
|
|
|
|
memstream.Write(buffer, 0, bytesRead);
|
|
|
|
|
var bytes = memstream.ToArray();
|
|
|
|
|
|
|
|
|
|
UserPhotoManager.SaveOrUpdatePhoto(userID, bytes);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-10-09 15:04:46 +00:00
|
|
|
|
private AccountLinker GetLinker()
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2019-12-04 10:39:18 +00:00
|
|
|
|
return AccountLinker.Get("webstudio");
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
private static string GetMeaningfulProviderName(string providerName)
|
|
|
|
|
{
|
|
|
|
|
switch (providerName)
|
|
|
|
|
{
|
|
|
|
|
case "google":
|
|
|
|
|
case "openid":
|
|
|
|
|
return "Google";
|
|
|
|
|
case "facebook":
|
|
|
|
|
return "Facebook";
|
|
|
|
|
case "twitter":
|
|
|
|
|
return "Twitter";
|
|
|
|
|
case "linkedin":
|
|
|
|
|
return "LinkedIn";
|
|
|
|
|
default:
|
|
|
|
|
return "Unknown Provider";
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Read(@"reassign/progress")]
|
2019-06-21 10:42:16 +00:00
|
|
|
|
public ReassignProgressItem GetReassignProgress(Guid userId)
|
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(Constants.Action_EditUser);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-08-12 10:53:12 +00:00
|
|
|
|
return QueueWorkerReassign.GetProgressItemStatus(Tenant.TenantId, userId);
|
2019-06-21 10:42:16 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Update(@"reassign/terminate")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public void TerminateReassignFromBody([FromBody] TerminateModel model)
|
2019-06-21 10:42:16 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(Constants.Action_EditUser);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2020-11-11 15:36:58 +00:00
|
|
|
|
QueueWorkerReassign.Terminate(Tenant.TenantId, model.UserId);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Update(@"reassign/terminate")]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public void TerminateReassignFromForm([FromForm] TerminateModel model)
|
2019-06-21 10:42:16 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(Constants.Action_EditUser);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2020-11-11 15:36:58 +00:00
|
|
|
|
QueueWorkerReassign.Terminate(Tenant.TenantId, model.UserId);
|
2019-06-21 10:42:16 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Create(@"reassign/start")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public ReassignProgressItem StartReassignFromBody([FromBody] StartReassignModel model)
|
2020-11-11 15:36:58 +00:00
|
|
|
|
{
|
|
|
|
|
return StartReassign(model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Create(@"reassign/start")]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public ReassignProgressItem StartReassignFromForm([FromForm] StartReassignModel model)
|
2020-11-11 15:36:58 +00:00
|
|
|
|
{
|
|
|
|
|
return StartReassign(model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private ReassignProgressItem StartReassign(StartReassignModel model)
|
2019-06-21 10:42:16 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(Constants.Action_EditUser);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2020-11-11 15:36:58 +00:00
|
|
|
|
var fromUser = UserManager.GetUsers(model.FromUserId);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-21 10:42:16 +00:00
|
|
|
|
if (fromUser == null || fromUser.ID == Constants.LostUser.ID)
|
2020-11-11 15:36:58 +00:00
|
|
|
|
throw new ArgumentException("User with id = " + model.FromUserId + " not found");
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-09 12:56:33 +00:00
|
|
|
|
if (fromUser.IsOwner(Tenant) || fromUser.IsMe(AuthContext) || fromUser.Status != EmployeeStatus.Terminated)
|
2020-11-11 15:36:58 +00:00
|
|
|
|
throw new ArgumentException("Can not delete user with id = " + model.FromUserId);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2020-11-11 15:36:58 +00:00
|
|
|
|
var toUser = UserManager.GetUsers(model.ToUserId);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-21 10:42:16 +00:00
|
|
|
|
if (toUser == null || toUser.ID == Constants.LostUser.ID)
|
2020-11-11 15:36:58 +00:00
|
|
|
|
throw new ArgumentException("User with id = " + model.ToUserId + " not found");
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
if (toUser.IsVisitor(UserManager) || toUser.Status == EmployeeStatus.Terminated)
|
2020-11-11 15:36:58 +00:00
|
|
|
|
throw new ArgumentException("Can not reassign data to user with id = " + model.ToUserId);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2020-11-11 15:36:58 +00:00
|
|
|
|
return QueueWorkerReassign.Start(Tenant.TenantId, model.FromUserId, model.ToUserId, SecurityContext.CurrentAccount.ID, model.DeleteProfile);
|
2019-06-21 10:42:16 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-21 10:42:16 +00:00
|
|
|
|
private void CheckReassignProccess(IEnumerable<Guid> userIds)
|
|
|
|
|
{
|
|
|
|
|
foreach (var userId in userIds)
|
|
|
|
|
{
|
2019-08-12 10:53:12 +00:00
|
|
|
|
var reassignStatus = QueueWorkerReassign.GetProgressItemStatus(Tenant.TenantId, userId);
|
2019-06-21 10:42:16 +00:00
|
|
|
|
if (reassignStatus == null || reassignStatus.IsCompleted)
|
|
|
|
|
continue;
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-11-08 12:21:51 +00:00
|
|
|
|
var userName = UserManager.GetUsers(userId).DisplayUserName(DisplayUserSettingsHelper);
|
2019-06-21 10:42:16 +00:00
|
|
|
|
throw new Exception(string.Format(Resource.ReassignDataRemoveUserError, userName));
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
|
|
|
|
//#endregion
|
|
|
|
|
|
2019-06-21 10:42:16 +00:00
|
|
|
|
#region Remove user data
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Read(@"remove/progress")]
|
2019-06-21 10:42:16 +00:00
|
|
|
|
public RemoveProgressItem GetRemoveProgress(Guid userId)
|
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(Constants.Action_EditUser);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-08-12 10:53:12 +00:00
|
|
|
|
return QueueWorkerRemove.GetProgressItemStatus(Tenant.TenantId, userId);
|
2019-06-21 10:42:16 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Update(@"remove/terminate")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public void TerminateRemoveFromBody([FromBody] TerminateModel model)
|
2020-11-06 09:46:57 +00:00
|
|
|
|
{
|
|
|
|
|
PermissionContext.DemandPermissions(Constants.Action_EditUser);
|
|
|
|
|
|
2020-11-11 15:36:58 +00:00
|
|
|
|
QueueWorkerRemove.Terminate(Tenant.TenantId, model.UserId);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Update(@"remove/terminate")]
|
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public void TerminateRemoveFromForm([FromForm] TerminateModel model)
|
2019-06-21 10:42:16 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(Constants.Action_EditUser);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2020-11-11 15:36:58 +00:00
|
|
|
|
QueueWorkerRemove.Terminate(Tenant.TenantId, model.UserId);
|
2020-11-06 09:46:57 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Create(@"remove/start")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public RemoveProgressItem StartRemoveFromBody([FromBody] TerminateModel model)
|
2020-11-11 15:36:58 +00:00
|
|
|
|
{
|
|
|
|
|
return StartRemove(model);
|
2019-06-21 10:42:16 +00:00
|
|
|
|
}
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-25 10:46:10 +00:00
|
|
|
|
[Create(@"remove/start")]
|
2020-11-11 15:36:58 +00:00
|
|
|
|
[Consumes("application/x-www-form-urlencoded")]
|
2021-09-17 14:32:37 +00:00
|
|
|
|
public RemoveProgressItem StartRemoveFromForm([FromForm] TerminateModel model)
|
2020-11-11 15:36:58 +00:00
|
|
|
|
{
|
|
|
|
|
return StartRemove(model);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private RemoveProgressItem StartRemove(TerminateModel model)
|
2019-06-21 10:42:16 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(Constants.Action_EditUser);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2020-11-11 15:36:58 +00:00
|
|
|
|
var user = UserManager.GetUsers(model.UserId);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-06-21 10:42:16 +00:00
|
|
|
|
if (user == null || user.ID == Constants.LostUser.ID)
|
2020-11-11 15:36:58 +00:00
|
|
|
|
throw new ArgumentException("User with id = " + model.UserId + " not found");
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-09-09 12:56:33 +00:00
|
|
|
|
if (user.IsOwner(Tenant) || user.IsMe(AuthContext) || user.Status != EmployeeStatus.Terminated)
|
2020-11-11 15:36:58 +00:00
|
|
|
|
throw new ArgumentException("Can not delete user with id = " + model.UserId);
|
2019-06-14 16:14:24 +00:00
|
|
|
|
|
2019-08-12 10:53:12 +00:00
|
|
|
|
return QueueWorkerRemove.Start(Tenant.TenantId, user, SecurityContext.CurrentAccount.ID, true);
|
2019-06-21 10:42:16 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endregion
|
2019-06-17 11:57:07 +00:00
|
|
|
|
|
2019-08-08 09:26:58 +00:00
|
|
|
|
private void UpdateDepartments(IEnumerable<Guid> department, UserInfo user)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
if (!PermissionContext.CheckPermissions(Constants.Action_EditGroups)) return;
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (department == null) return;
|
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
var groups = UserManager.GetUserGroups(user.ID);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
var managerGroups = new List<Guid>();
|
|
|
|
|
foreach (var groupInfo in groups)
|
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.RemoveUserFromGroup(user.ID, groupInfo.ID);
|
|
|
|
|
var managerId = UserManager.GetDepartmentManager(groupInfo.ID);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (managerId == user.ID)
|
|
|
|
|
{
|
|
|
|
|
managerGroups.Add(groupInfo.ID);
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.SetDepartmentManager(groupInfo.ID, Guid.Empty);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
foreach (var guid in department)
|
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
var userDepartment = UserManager.GetGroupInfo(guid);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (userDepartment != Constants.LostGroupInfo)
|
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.AddUserIntoGroup(user.ID, guid);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (managerGroups.Contains(guid))
|
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserManager.SetDepartmentManager(guid, user.ID);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-08 09:26:58 +00:00
|
|
|
|
private void UpdateContacts(IEnumerable<Contact> contacts, UserInfo user)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(new UserSecurityProvider(user.ID), Constants.Action_EditUser);
|
2019-09-02 15:09:45 +00:00
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (contacts == null) return;
|
2019-12-27 10:19:35 +00:00
|
|
|
|
var values = contacts.Where(r => !string.IsNullOrEmpty(r.Value)).Select(r => $"{r.Type}|{r.Value}");
|
|
|
|
|
user.Contacts = string.Join('|', values);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-08-08 09:26:58 +00:00
|
|
|
|
private void DeleteContacts(IEnumerable<Contact> contacts, UserInfo user)
|
2019-06-17 11:57:07 +00:00
|
|
|
|
{
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(new UserSecurityProvider(user.ID), Constants.Action_EditUser);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (contacts == null) return;
|
|
|
|
|
|
2019-11-25 09:49:12 +00:00
|
|
|
|
if (user.ContactsList == null)
|
2019-09-02 15:09:45 +00:00
|
|
|
|
{
|
2019-11-25 09:49:12 +00:00
|
|
|
|
user.ContactsList = new List<string>();
|
2019-09-02 15:09:45 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-06-17 11:57:07 +00:00
|
|
|
|
foreach (var contact in contacts)
|
|
|
|
|
{
|
2019-11-25 09:49:12 +00:00
|
|
|
|
var index = user.ContactsList.IndexOf(contact.Type);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
if (index != -1)
|
|
|
|
|
{
|
|
|
|
|
//Remove existing
|
2019-11-25 09:49:12 +00:00
|
|
|
|
user.ContactsList.RemoveRange(index, 2);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void UpdatePhotoUrl(string files, UserInfo user)
|
|
|
|
|
{
|
|
|
|
|
if (string.IsNullOrEmpty(files))
|
|
|
|
|
{
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2019-09-12 11:34:58 +00:00
|
|
|
|
PermissionContext.DemandPermissions(new UserSecurityProvider(user.ID), Constants.Action_EditUser);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
|
|
|
|
|
if (!files.StartsWith("http://") && !files.StartsWith("https://"))
|
|
|
|
|
{
|
2020-05-17 13:08:20 +00:00
|
|
|
|
files = new Uri(ApiContext.HttpContextAccessor.HttpContext.Request.GetDisplayUrl()).GetLeftPart(UriPartial.Scheme | UriPartial.Authority) + "/" + files.TrimStart('/');
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
|
|
|
|
var request = WebRequest.Create(files);
|
|
|
|
|
using var response = (HttpWebResponse)request.GetResponse();
|
|
|
|
|
using var inputStream = response.GetResponseStream();
|
|
|
|
|
using var br = new BinaryReader(inputStream);
|
|
|
|
|
var imageByteArray = br.ReadBytes((int)response.ContentLength);
|
2019-09-12 11:34:58 +00:00
|
|
|
|
UserPhotoManager.SaveOrUpdatePhoto(user.ID, imageByteArray);
|
2019-06-17 11:57:07 +00:00
|
|
|
|
}
|
2019-07-17 08:55:08 +00:00
|
|
|
|
|
|
|
|
|
private static void CheckImgFormat(byte[] data)
|
|
|
|
|
{
|
|
|
|
|
ImageFormat imgFormat;
|
|
|
|
|
|
|
|
|
|
try
|
|
|
|
|
{
|
2019-08-15 15:08:40 +00:00
|
|
|
|
using var stream = new MemoryStream(data);
|
|
|
|
|
using var img = new Bitmap(stream);
|
|
|
|
|
imgFormat = img.RawFormat;
|
2019-07-17 08:55:08 +00:00
|
|
|
|
}
|
|
|
|
|
catch (OutOfMemoryException)
|
|
|
|
|
{
|
|
|
|
|
throw new ImageSizeLimitException();
|
|
|
|
|
}
|
|
|
|
|
catch (ArgumentException error)
|
|
|
|
|
{
|
|
|
|
|
throw new UnknownImageFormatException(error);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!imgFormat.Equals(ImageFormat.Png) && !imgFormat.Equals(ImageFormat.Jpeg))
|
|
|
|
|
{
|
|
|
|
|
throw new UnknownImageFormatException();
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-05-17 08:32:23 +00:00
|
|
|
|
}
|
|
|
|
|
}
|