Websitepanel user account lockout and state management added
This commit is contained in:
parent
008fc296d5
commit
72348041f0
27 changed files with 1705 additions and 373 deletions
|
@ -64,6 +64,9 @@ namespace WebsitePanel.EnterpriseServer
|
|||
public const int ERROR_INVALID_USER_NAME = -111;
|
||||
public const int ERROR_USER_ACCOUNT_NOT_ENOUGH_PERMISSIONS = -112;
|
||||
public const int ERROR_USER_ACCOUNT_ROLE_NOT_ALLOWED = -113;
|
||||
|
||||
public const int ERROR_USER_ACCOUNT_DISABLED = -114;
|
||||
public const int ERROR_USER_ACCOUNT_LOCKEDOUT = -115;
|
||||
#endregion
|
||||
|
||||
#region Packages
|
||||
|
|
|
@ -33,225 +33,249 @@ using System.Xml.Linq;
|
|||
|
||||
namespace WebsitePanel.EnterpriseServer
|
||||
{
|
||||
/// <summary>
|
||||
/// User account.
|
||||
/// </summary>
|
||||
[Serializable]
|
||||
public class UserInfo
|
||||
{
|
||||
private int userId;
|
||||
private int ownerId;
|
||||
private int roleId;
|
||||
private int statusId;
|
||||
private DateTime created;
|
||||
private DateTime changed;
|
||||
private bool isPeer;
|
||||
private bool isDemo;
|
||||
private string comments;
|
||||
private string username;
|
||||
private string password;
|
||||
private string firstName;
|
||||
private string lastName;
|
||||
private string email;
|
||||
private string secondaryEmail;
|
||||
private string address;
|
||||
private string city;
|
||||
private string country;
|
||||
private string state;
|
||||
private string zip;
|
||||
private string primaryPhone;
|
||||
private string secondaryPhone;
|
||||
private string fax;
|
||||
private string instantMessenger;
|
||||
/// <summary>
|
||||
/// User account.
|
||||
/// </summary>
|
||||
[Serializable]
|
||||
public class UserInfo
|
||||
{
|
||||
private int userId;
|
||||
private int ownerId;
|
||||
private int roleId;
|
||||
private int statusId;
|
||||
private int loginStatusId;
|
||||
private int failedLogins;
|
||||
private DateTime created;
|
||||
private DateTime changed;
|
||||
private bool isPeer;
|
||||
private bool isDemo;
|
||||
private string comments;
|
||||
private string username;
|
||||
private string password;
|
||||
private string firstName;
|
||||
private string lastName;
|
||||
private string email;
|
||||
private string secondaryEmail;
|
||||
private string address;
|
||||
private string city;
|
||||
private string country;
|
||||
private string state;
|
||||
private string zip;
|
||||
private string primaryPhone;
|
||||
private string secondaryPhone;
|
||||
private string fax;
|
||||
private string instantMessenger;
|
||||
private bool htmlMail;
|
||||
private string companyName;
|
||||
private bool ecommerceEnabled;
|
||||
private string companyName;
|
||||
private bool ecommerceEnabled;
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// Creates a new instance of UserInfo class.
|
||||
/// </summary>
|
||||
public UserInfo()
|
||||
{
|
||||
}
|
||||
/// <summary>
|
||||
/// Creates a new instance of UserInfo class.
|
||||
/// </summary>
|
||||
public UserInfo()
|
||||
{
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// User role ID:
|
||||
/// Administrator = 1,
|
||||
/// Reseller = 2,
|
||||
/// User = 3
|
||||
/// </summary>
|
||||
public int RoleId
|
||||
{
|
||||
get { return roleId; }
|
||||
set { roleId = value; }
|
||||
}
|
||||
/// <summary>
|
||||
/// User role ID:
|
||||
/// Administrator = 1,
|
||||
/// Reseller = 2,
|
||||
/// User = 3
|
||||
/// </summary>
|
||||
public int RoleId
|
||||
{
|
||||
get { return roleId; }
|
||||
set { roleId = value; }
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// User role.
|
||||
/// </summary>
|
||||
public UserRole Role
|
||||
{
|
||||
get { return (UserRole)roleId; }
|
||||
set { roleId = (int)value; }
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// User account status:
|
||||
/// Active = 1,
|
||||
/// Suspended = 2,
|
||||
/// Cancelled = 3,
|
||||
/// Pending = 4
|
||||
/// </summary>
|
||||
public int StatusId
|
||||
{
|
||||
get { return statusId; }
|
||||
set { statusId = value; }
|
||||
}
|
||||
/// <summary>
|
||||
/// User role.
|
||||
/// </summary>
|
||||
public UserRole Role
|
||||
{
|
||||
get { return (UserRole)roleId; }
|
||||
set { roleId = (int)value; }
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// User account status.
|
||||
/// </summary>
|
||||
public UserStatus Status
|
||||
{
|
||||
get { return (UserStatus)statusId; }
|
||||
set { statusId = (int)value; }
|
||||
}
|
||||
/// <summary>
|
||||
/// User account status:
|
||||
/// Active = 1,
|
||||
/// Suspended = 2,
|
||||
/// Cancelled = 3,
|
||||
/// Pending = 4
|
||||
/// </summary>
|
||||
public int StatusId
|
||||
{
|
||||
get { return statusId; }
|
||||
set { statusId = value; }
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// User account unique identifier.
|
||||
/// </summary>
|
||||
public int UserId
|
||||
{
|
||||
get { return userId; }
|
||||
set { userId = value; }
|
||||
}
|
||||
/// <summary>
|
||||
/// User account status.
|
||||
/// </summary>
|
||||
public UserStatus Status
|
||||
{
|
||||
get { return (UserStatus)statusId; }
|
||||
set { statusId = (int)value; }
|
||||
}
|
||||
|
||||
public int OwnerId
|
||||
{
|
||||
get { return ownerId; }
|
||||
set { ownerId = value; }
|
||||
}
|
||||
|
||||
public bool IsPeer
|
||||
{
|
||||
get { return isPeer; }
|
||||
set { isPeer = value; }
|
||||
}
|
||||
public int LoginStatusId
|
||||
{
|
||||
get { return loginStatusId; }
|
||||
set { loginStatusId = value; }
|
||||
}
|
||||
|
||||
public DateTime Created
|
||||
{
|
||||
get { return created; }
|
||||
set { created = value; }
|
||||
}
|
||||
public UserLoginStatus LoginStatus
|
||||
{
|
||||
get { return (UserLoginStatus)loginStatusId; }
|
||||
set { loginStatusId = (int)value; }
|
||||
}
|
||||
|
||||
public DateTime Changed
|
||||
{
|
||||
get { return changed; }
|
||||
set { changed = value; }
|
||||
}
|
||||
public int FailedLogins
|
||||
{
|
||||
get { return failedLogins; }
|
||||
set { failedLogins = value; }
|
||||
}
|
||||
|
||||
public bool IsDemo
|
||||
{
|
||||
get { return isDemo; }
|
||||
set { isDemo = value; }
|
||||
}
|
||||
|
||||
public string Comments
|
||||
{
|
||||
get { return comments; }
|
||||
set { comments = value; }
|
||||
}
|
||||
|
||||
public string LastName
|
||||
{
|
||||
get { return this.lastName; }
|
||||
set { this.lastName = value; }
|
||||
}
|
||||
/// <summary>
|
||||
/// User account unique identifier.
|
||||
/// </summary>
|
||||
public int UserId
|
||||
{
|
||||
get { return userId; }
|
||||
set { userId = value; }
|
||||
}
|
||||
|
||||
public string Username
|
||||
{
|
||||
get { return this.username; }
|
||||
set { this.username = value; }
|
||||
}
|
||||
public int OwnerId
|
||||
{
|
||||
get { return ownerId; }
|
||||
set { ownerId = value; }
|
||||
}
|
||||
|
||||
public string Password
|
||||
{
|
||||
get { return this.password; }
|
||||
set { this.password = value; }
|
||||
}
|
||||
public bool IsPeer
|
||||
{
|
||||
get { return isPeer; }
|
||||
set { isPeer = value; }
|
||||
}
|
||||
|
||||
public string FirstName
|
||||
{
|
||||
get { return this.firstName; }
|
||||
set { this.firstName = value; }
|
||||
}
|
||||
public DateTime Created
|
||||
{
|
||||
get { return created; }
|
||||
set { created = value; }
|
||||
}
|
||||
|
||||
public string Email
|
||||
{
|
||||
get { return this.email; }
|
||||
set { this.email = value; }
|
||||
}
|
||||
public DateTime Changed
|
||||
{
|
||||
get { return changed; }
|
||||
set { changed = value; }
|
||||
}
|
||||
|
||||
public string PrimaryPhone
|
||||
{
|
||||
get { return this.primaryPhone; }
|
||||
set { this.primaryPhone = value; }
|
||||
}
|
||||
public bool IsDemo
|
||||
{
|
||||
get { return isDemo; }
|
||||
set { isDemo = value; }
|
||||
}
|
||||
|
||||
public string Zip
|
||||
{
|
||||
get { return this.zip; }
|
||||
set { this.zip = value; }
|
||||
}
|
||||
public string Comments
|
||||
{
|
||||
get { return comments; }
|
||||
set { comments = value; }
|
||||
}
|
||||
|
||||
public string InstantMessenger
|
||||
{
|
||||
get { return this.instantMessenger; }
|
||||
set { this.instantMessenger = value; }
|
||||
}
|
||||
public string LastName
|
||||
{
|
||||
get { return this.lastName; }
|
||||
set { this.lastName = value; }
|
||||
}
|
||||
|
||||
public string Fax
|
||||
{
|
||||
get { return this.fax; }
|
||||
set { this.fax = value; }
|
||||
}
|
||||
public string Username
|
||||
{
|
||||
get { return this.username; }
|
||||
set { this.username = value; }
|
||||
}
|
||||
|
||||
public string SecondaryPhone
|
||||
{
|
||||
get { return this.secondaryPhone; }
|
||||
set { this.secondaryPhone = value; }
|
||||
}
|
||||
public string Password
|
||||
{
|
||||
get { return this.password; }
|
||||
set { this.password = value; }
|
||||
}
|
||||
|
||||
public string SecondaryEmail
|
||||
{
|
||||
get { return this.secondaryEmail; }
|
||||
set { this.secondaryEmail = value; }
|
||||
}
|
||||
public string FirstName
|
||||
{
|
||||
get { return this.firstName; }
|
||||
set { this.firstName = value; }
|
||||
}
|
||||
|
||||
public string Country
|
||||
{
|
||||
get { return this.country; }
|
||||
set { this.country = value; }
|
||||
}
|
||||
public string Email
|
||||
{
|
||||
get { return this.email; }
|
||||
set { this.email = value; }
|
||||
}
|
||||
|
||||
public string Address
|
||||
{
|
||||
get { return this.address; }
|
||||
set { this.address = value; }
|
||||
}
|
||||
public string PrimaryPhone
|
||||
{
|
||||
get { return this.primaryPhone; }
|
||||
set { this.primaryPhone = value; }
|
||||
}
|
||||
|
||||
public string City
|
||||
{
|
||||
get { return this.city; }
|
||||
set { this.city = value; }
|
||||
}
|
||||
public string Zip
|
||||
{
|
||||
get { return this.zip; }
|
||||
set { this.zip = value; }
|
||||
}
|
||||
|
||||
public string State
|
||||
{
|
||||
get { return this.state; }
|
||||
set { this.state = value; }
|
||||
}
|
||||
public string InstantMessenger
|
||||
{
|
||||
get { return this.instantMessenger; }
|
||||
set { this.instantMessenger = value; }
|
||||
}
|
||||
|
||||
public string Fax
|
||||
{
|
||||
get { return this.fax; }
|
||||
set { this.fax = value; }
|
||||
}
|
||||
|
||||
public string SecondaryPhone
|
||||
{
|
||||
get { return this.secondaryPhone; }
|
||||
set { this.secondaryPhone = value; }
|
||||
}
|
||||
|
||||
public string SecondaryEmail
|
||||
{
|
||||
get { return this.secondaryEmail; }
|
||||
set { this.secondaryEmail = value; }
|
||||
}
|
||||
|
||||
public string Country
|
||||
{
|
||||
get { return this.country; }
|
||||
set { this.country = value; }
|
||||
}
|
||||
|
||||
public string Address
|
||||
{
|
||||
get { return this.address; }
|
||||
set { this.address = value; }
|
||||
}
|
||||
|
||||
public string City
|
||||
{
|
||||
get { return this.city; }
|
||||
set { this.city = value; }
|
||||
}
|
||||
|
||||
public string State
|
||||
{
|
||||
get { return this.state; }
|
||||
set { this.state = value; }
|
||||
}
|
||||
|
||||
public bool HtmlMail
|
||||
{
|
||||
|
@ -259,17 +283,17 @@ namespace WebsitePanel.EnterpriseServer
|
|||
set { this.htmlMail = value; }
|
||||
}
|
||||
|
||||
public string CompanyName
|
||||
{
|
||||
get { return this.companyName; }
|
||||
set { this.companyName = value; }
|
||||
}
|
||||
public string CompanyName
|
||||
{
|
||||
get { return this.companyName; }
|
||||
set { this.companyName = value; }
|
||||
}
|
||||
|
||||
public bool EcommerceEnabled
|
||||
{
|
||||
get { return this.ecommerceEnabled; }
|
||||
set { this.ecommerceEnabled = value; }
|
||||
}
|
||||
public bool EcommerceEnabled
|
||||
{
|
||||
get { return this.ecommerceEnabled; }
|
||||
set { this.ecommerceEnabled = value; }
|
||||
}
|
||||
|
||||
public string AdditionalParams { get; set; }
|
||||
|
||||
|
@ -289,10 +313,10 @@ namespace WebsitePanel.EnterpriseServer
|
|||
XElement vLansElement = doc.Root.Element("VLans");
|
||||
if (vLansElement != null)
|
||||
{
|
||||
foreach(var item in vLansElement.Elements("VLan"))
|
||||
foreach (var item in vLansElement.Elements("VLan"))
|
||||
result.Add(new UserVlan
|
||||
{
|
||||
VLanID = item.Attribute("VLanID") != null ? ushort.Parse(item.Attribute("VLanID").Value) : (ushort) 0,
|
||||
VLanID = item.Attribute("VLanID") != null ? ushort.Parse(item.Attribute("VLanID").Value) : (ushort)0,
|
||||
Comment = item.Attribute("Comment") != null ? item.Attribute("Comment").Value : null
|
||||
});
|
||||
}
|
||||
|
@ -304,7 +328,7 @@ namespace WebsitePanel.EnterpriseServer
|
|||
return result;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// User's VLans
|
||||
|
|
|
@ -0,0 +1,42 @@
|
|||
// Copyright (c) 2012, Outercurve Foundation.
|
||||
// All rights reserved.
|
||||
//
|
||||
// Redistribution and use in source and binary forms, with or without modification,
|
||||
// are permitted provided that the following conditions are met:
|
||||
//
|
||||
// - Redistributions of source code must retain the above copyright notice, this
|
||||
// list of conditions and the following disclaimer.
|
||||
//
|
||||
// - Redistributions in binary form must reproduce the above copyright notice,
|
||||
// this list of conditions and the following disclaimer in the documentation
|
||||
// and/or other materials provided with the distribution.
|
||||
//
|
||||
// - Neither the name of the Outercurve Foundation nor the names of its
|
||||
// contributors may be used to endorse or promote products derived from this
|
||||
// software without specific prior written permission.
|
||||
//
|
||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||
// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
|
||||
// ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||
// ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
using System;
|
||||
|
||||
namespace WebsitePanel.EnterpriseServer
|
||||
{
|
||||
/// <summary>
|
||||
/// Summary description for AccountLoginStatus.
|
||||
/// </summary>
|
||||
public enum UserLoginStatus
|
||||
{
|
||||
Enabled = 0,
|
||||
Disabled = 1,
|
||||
LockedOut = 2
|
||||
}
|
||||
}
|
|
@ -41,6 +41,7 @@ namespace WebsitePanel.EnterpriseServer
|
|||
public const string PACKAGE_SUMMARY_LETTER = "PackageSummaryLetter";
|
||||
public const string PASSWORD_REMINDER_LETTER = "PasswordReminderLetter";
|
||||
public const string EXCHANGE_MAILBOX_SETUP_LETTER = "ExchangeMailboxSetupLetter";
|
||||
public const string EXCHANGE_HOSTED_EDITION_ORGANIZATION_SUMMARY = "ExchangeHostedEditionOrganizationSummary";
|
||||
public const string HOSTED_SOLUTION_REPORT = "HostedSoluitonReportSummaryLetter";
|
||||
public const string ORGANIZATION_USER_SUMMARY_LETTER = "OrganizationUserSummaryLetter";
|
||||
public const string VPS_SUMMARY_LETTER = "VpsSummaryLetter";
|
||||
|
@ -51,7 +52,8 @@ namespace WebsitePanel.EnterpriseServer
|
|||
public const string MYSQL_POLICY = "MySqlPolicy";
|
||||
public const string SHAREPOINT_POLICY = "SharePointPolicy";
|
||||
public const string OS_POLICY = "OsPolicy";
|
||||
public const string EXCHANGE_POLICY = "ExchangePolicy";
|
||||
public const string EXCHANGE_POLICY = "ExchangePolicy";
|
||||
public const string EXCHANGE_HOSTED_EDITION_POLICY = "ExchangeHostedEditionPolicy";
|
||||
public const string WEBSITEPANEL_POLICY = "WebsitePanelPolicy";
|
||||
public const string VPS_POLICY = "VpsPolicy";
|
||||
public const string DISPLAY_PREFS = "DisplayPreferences";
|
||||
|
|
|
@ -30,14 +30,14 @@ using System;
|
|||
|
||||
namespace WebsitePanel.EnterpriseServer
|
||||
{
|
||||
/// <summary>
|
||||
/// Summary description for AccountStatus.
|
||||
/// </summary>
|
||||
public enum UserStatus
|
||||
{
|
||||
Active = 1,
|
||||
Suspended = 2,
|
||||
Cancelled = 3,
|
||||
Pending = 4
|
||||
}
|
||||
/// <summary>
|
||||
/// Summary description for AccountStatus.
|
||||
/// </summary>
|
||||
public enum UserStatus
|
||||
{
|
||||
Active = 1,
|
||||
Suspended = 2,
|
||||
Cancelled = 3,
|
||||
Pending = 4
|
||||
}
|
||||
}
|
||||
|
|
|
@ -156,6 +156,7 @@
|
|||
<Compile Include="Tasks\BackgroundTask.cs" />
|
||||
<Compile Include="Tasks\BackgroundTaskLogRecord.cs" />
|
||||
<Compile Include="Users\UserInfo.cs" />
|
||||
<Compile Include="Users\UserLoginStatus.cs" />
|
||||
<Compile Include="Users\UsernamePolicy.cs" />
|
||||
<Compile Include="Users\UserRole.cs" />
|
||||
<Compile Include="Users\UserSettings.cs" />
|
||||
|
|
|
@ -190,7 +190,7 @@ namespace WebsitePanel.EnterpriseServer
|
|||
new SqlParameter("@Username", username));
|
||||
}
|
||||
|
||||
public static int AddUser(int actorId, int ownerId, int roleId, int statusId, bool isDemo,
|
||||
public static int AddUser(int actorId, int ownerId, int roleId, int statusId, int loginStatusId, bool isDemo,
|
||||
bool isPeer, string comments, string username, string password,
|
||||
string firstName, string lastName, string email, string secondaryEmail,
|
||||
string address, string city, string country, string state, string zip,
|
||||
|
@ -208,6 +208,7 @@ namespace WebsitePanel.EnterpriseServer
|
|||
new SqlParameter("@OwnerID", ownerId),
|
||||
new SqlParameter("@RoleID", roleId),
|
||||
new SqlParameter("@StatusId", statusId),
|
||||
new SqlParameter("@LoginStatusId", loginStatusId),
|
||||
new SqlParameter("@IsDemo", isDemo),
|
||||
new SqlParameter("@IsPeer", isPeer),
|
||||
new SqlParameter("@Comments", comments),
|
||||
|
@ -227,13 +228,13 @@ namespace WebsitePanel.EnterpriseServer
|
|||
new SqlParameter("@fax", fax),
|
||||
new SqlParameter("@instantMessenger", instantMessenger),
|
||||
new SqlParameter("@htmlMail", htmlMail),
|
||||
new SqlParameter("@CompanyName", companyName),
|
||||
new SqlParameter("@EcommerceEnabled", ecommerceEnabled));
|
||||
new SqlParameter("@CompanyName", companyName),
|
||||
new SqlParameter("@EcommerceEnabled", ecommerceEnabled));
|
||||
|
||||
return Convert.ToInt32(prmUserId.Value);
|
||||
}
|
||||
|
||||
public static void UpdateUser(int actorId, int userId, int roleId, int statusId, bool isDemo,
|
||||
public static void UpdateUser(int actorId, int userId, int roleId, int statusId, int loginStatusId, bool isDemo,
|
||||
bool isPeer, string comments, string firstName, string lastName, string email, string secondaryEmail,
|
||||
string address, string city, string country, string state, string zip,
|
||||
string primaryPhone, string secondaryPhone, string fax, string instantMessenger, bool htmlMail,
|
||||
|
@ -245,6 +246,7 @@ namespace WebsitePanel.EnterpriseServer
|
|||
new SqlParameter("@ActorId", actorId),
|
||||
new SqlParameter("@RoleID", roleId),
|
||||
new SqlParameter("@StatusId", statusId),
|
||||
new SqlParameter("@LoginStatusId", loginStatusId),
|
||||
new SqlParameter("@UserID", userId),
|
||||
new SqlParameter("@IsDemo", isDemo),
|
||||
new SqlParameter("@IsPeer", isPeer),
|
||||
|
@ -263,11 +265,20 @@ namespace WebsitePanel.EnterpriseServer
|
|||
new SqlParameter("@fax", fax),
|
||||
new SqlParameter("@instantMessenger", instantMessenger),
|
||||
new SqlParameter("@htmlMail", htmlMail),
|
||||
new SqlParameter("@CompanyName", companyName),
|
||||
new SqlParameter("@EcommerceEnabled", ecommerceEnabled),
|
||||
new SqlParameter("@CompanyName", companyName),
|
||||
new SqlParameter("@EcommerceEnabled", ecommerceEnabled),
|
||||
new SqlParameter("@AdditionalParams", additionalParams));
|
||||
}
|
||||
|
||||
public static void UpdateUserFailedLoginAttempt(int userId, int lockOut, bool reset)
|
||||
{
|
||||
SqlHelper.ExecuteNonQuery(ConnectionString, CommandType.StoredProcedure,
|
||||
ObjectQualifier + "UpdateUserFailedLoginAttempt",
|
||||
new SqlParameter("@UserID", userId),
|
||||
new SqlParameter("@LockOut", lockOut),
|
||||
new SqlParameter("@Reset", reset));
|
||||
}
|
||||
|
||||
public static void DeleteUser(int actorId, int userId)
|
||||
{
|
||||
SqlHelper.ExecuteNonQuery(ConnectionString, CommandType.StoredProcedure,
|
||||
|
|
|
@ -49,56 +49,92 @@ namespace WebsitePanel.EnterpriseServer
|
|||
return (user != null);
|
||||
}
|
||||
|
||||
public static int AuthenticateUser(string username, string password, string ip)
|
||||
{
|
||||
// start task
|
||||
TaskManager.StartTask("USER", "AUTHENTICATE", username);
|
||||
TaskManager.WriteParameter("IP", ip);
|
||||
public static int AuthenticateUser(string username, string password, string ip)
|
||||
{
|
||||
// start task
|
||||
TaskManager.StartTask("USER", "AUTHENTICATE", username);
|
||||
TaskManager.WriteParameter("IP", ip);
|
||||
|
||||
try
|
||||
{
|
||||
// try to get user from database
|
||||
UserInfo user = GetUserInternally(username);
|
||||
try
|
||||
{
|
||||
// try to get user from database
|
||||
UserInfo user = GetUserInternally(username);
|
||||
|
||||
// check if the user exists
|
||||
if (user == null)
|
||||
{
|
||||
TaskManager.WriteWarning("Wrong username");
|
||||
return BusinessErrorCodes.ERROR_USER_WRONG_USERNAME;
|
||||
}
|
||||
// check if the user exists
|
||||
if (user == null)
|
||||
{
|
||||
TaskManager.WriteWarning("Wrong username");
|
||||
return BusinessErrorCodes.ERROR_USER_WRONG_USERNAME;
|
||||
}
|
||||
|
||||
// compare user passwords
|
||||
if (user.Password != password)
|
||||
{
|
||||
TaskManager.WriteWarning("Wrong password");
|
||||
return BusinessErrorCodes.ERROR_USER_WRONG_PASSWORD;
|
||||
}
|
||||
// check if the user is disabled
|
||||
if (user.LoginStatus == UserLoginStatus.Disabled)
|
||||
{
|
||||
TaskManager.WriteWarning("User disabled");
|
||||
return BusinessErrorCodes.ERROR_USER_ACCOUNT_DISABLED;
|
||||
}
|
||||
|
||||
// check status
|
||||
if (user.Status == UserStatus.Cancelled)
|
||||
{
|
||||
TaskManager.WriteWarning("Account cancelled");
|
||||
return BusinessErrorCodes.ERROR_USER_ACCOUNT_CANCELLED;
|
||||
}
|
||||
// check if the user is locked out
|
||||
if (user.LoginStatus == UserLoginStatus.LockedOut)
|
||||
{
|
||||
TaskManager.WriteWarning("User locked out");
|
||||
return BusinessErrorCodes.ERROR_USER_ACCOUNT_LOCKEDOUT;
|
||||
}
|
||||
|
||||
if (user.Status == UserStatus.Pending)
|
||||
{
|
||||
TaskManager.WriteWarning("Account pending");
|
||||
return BusinessErrorCodes.ERROR_USER_ACCOUNT_PENDING;
|
||||
}
|
||||
//Get the password policy
|
||||
UserSettings userSettings = UserController.GetUserSettings(user.UserId, UserSettings.WEBSITEPANEL_POLICY);
|
||||
int lockOut = -1;
|
||||
|
||||
return 0;
|
||||
if (!string.IsNullOrEmpty(userSettings["PasswordPolicy"]))
|
||||
{
|
||||
string passwordPolicy = userSettings["PasswordPolicy"];
|
||||
try
|
||||
{
|
||||
// parse settings
|
||||
string[] parts = passwordPolicy.Split(';');
|
||||
lockOut = Convert.ToInt32(parts[7]);
|
||||
}
|
||||
catch { /* skip */ }
|
||||
}
|
||||
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
throw TaskManager.WriteError(ex);
|
||||
}
|
||||
finally
|
||||
{
|
||||
TaskManager.CompleteTask();
|
||||
}
|
||||
}
|
||||
|
||||
// compare user passwords
|
||||
if (user.Password != password)
|
||||
{
|
||||
if (lockOut >= 0)
|
||||
DataProvider.UpdateUserFailedLoginAttempt(user.UserId, lockOut, false);
|
||||
|
||||
TaskManager.WriteWarning("Wrong password");
|
||||
return BusinessErrorCodes.ERROR_USER_WRONG_PASSWORD;
|
||||
}
|
||||
else
|
||||
DataProvider.UpdateUserFailedLoginAttempt(user.UserId, lockOut, true);
|
||||
|
||||
// check status
|
||||
if (user.Status == UserStatus.Cancelled)
|
||||
{
|
||||
TaskManager.WriteWarning("Account cancelled");
|
||||
return BusinessErrorCodes.ERROR_USER_ACCOUNT_CANCELLED;
|
||||
}
|
||||
|
||||
if (user.Status == UserStatus.Pending)
|
||||
{
|
||||
TaskManager.WriteWarning("Account pending");
|
||||
return BusinessErrorCodes.ERROR_USER_ACCOUNT_PENDING;
|
||||
}
|
||||
|
||||
return 0;
|
||||
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
throw TaskManager.WriteError(ex);
|
||||
}
|
||||
finally
|
||||
{
|
||||
TaskManager.CompleteTask();
|
||||
}
|
||||
}
|
||||
|
||||
public static UserInfo GetUserByUsernamePassword(string username, string password, string ip)
|
||||
{
|
||||
|
@ -382,6 +418,7 @@ namespace WebsitePanel.EnterpriseServer
|
|||
user.OwnerId,
|
||||
user.RoleId,
|
||||
user.StatusId,
|
||||
user.LoginStatusId,
|
||||
user.IsDemo,
|
||||
user.IsPeer,
|
||||
user.Comments,
|
||||
|
@ -525,6 +562,7 @@ namespace WebsitePanel.EnterpriseServer
|
|||
user.UserId,
|
||||
user.RoleId,
|
||||
user.StatusId,
|
||||
user.LoginStatusId,
|
||||
user.IsDemo,
|
||||
user.IsPeer,
|
||||
user.Comments,
|
||||
|
|
Binary file not shown.
After Width: | Height: | Size: 719 B |
|
@ -8,6 +8,11 @@
|
|||
EnableViewState="False" EmptyDataText="usersList"
|
||||
CssSelectorClass="NormalGridView">
|
||||
<Columns>
|
||||
<asp:TemplateField>
|
||||
<ItemTemplate>
|
||||
<asp:Image ID="img2" runat="server" Width="16px" Height="16px" ImageUrl='<%# GetStateImage(Eval("LoginStatusId")) %>' ImageAlign="AbsMiddle" />
|
||||
</ItemTemplate>
|
||||
</asp:TemplateField>
|
||||
<asp:TemplateField SortExpression="Username" HeaderText="usersListUsername">
|
||||
<ItemTemplate>
|
||||
<asp:hyperlink id="lnkEdit" runat="server" NavigateUrl='<%# EditUrl("PeerID", Eval("UserID").ToString(), "edit_peer", "UserID=" + PanelSecurity.SelectedUserId.ToString()) %>'>
|
||||
|
|
|
@ -86,5 +86,34 @@ namespace WebsitePanel.Portal
|
|||
return "Unknown";
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
protected string GetStateImage(object status)
|
||||
{
|
||||
string imgName = "enabled.png";
|
||||
|
||||
if (status != null)
|
||||
{
|
||||
try
|
||||
{
|
||||
switch ((int)status)
|
||||
{
|
||||
case (int)UserLoginStatus.Disabled:
|
||||
imgName = "disabled.png";
|
||||
break;
|
||||
case (int)UserLoginStatus.LockedOut:
|
||||
imgName = "locked.png";
|
||||
break;
|
||||
default:
|
||||
imgName = "enabled.png";
|
||||
break;
|
||||
}
|
||||
}
|
||||
catch (Exception) { }
|
||||
}
|
||||
|
||||
return GetThemedImage("Exchange/" + imgName);
|
||||
}
|
||||
|
||||
}
|
||||
}
|
|
@ -1,32 +1,3 @@
|
|||
// Copyright (c) 2012, Outercurve Foundation.
|
||||
// All rights reserved.
|
||||
//
|
||||
// Redistribution and use in source and binary forms, with or without modification,
|
||||
// are permitted provided that the following conditions are met:
|
||||
//
|
||||
// - Redistributions of source code must retain the above copyright notice, this
|
||||
// list of conditions and the following disclaimer.
|
||||
//
|
||||
// - Redistributions in binary form must reproduce the above copyright notice,
|
||||
// this list of conditions and the following disclaimer in the documentation
|
||||
// and/or other materials provided with the distribution.
|
||||
//
|
||||
// - Neither the name of the Outercurve Foundation nor the names of its
|
||||
// contributors may be used to endorse or promote products derived from this
|
||||
// software without specific prior written permission.
|
||||
//
|
||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||
// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
|
||||
// ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||
// ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
|
||||
//------------------------------------------------------------------------------
|
||||
// <auto-generated>
|
||||
// This code was generated by a tool.
|
||||
|
|
|
@ -101,6 +101,18 @@
|
|||
</asp:DropDownList>
|
||||
</td>
|
||||
</tr>
|
||||
<tr id="roleLoginStatus" runat="server">
|
||||
<td class="SubHead" valign="top">
|
||||
<asp:Label ID="lblLoginStatus" runat="server" meta:resourcekey="lblLoginStatus" Text="Login Status:"></asp:Label>
|
||||
</td>
|
||||
<td class="NormalBold" valign="top">
|
||||
<asp:DropDownList id="loginStatus" runat="server" resourcekey="loginStatus" CssClass="NormalTextBox">
|
||||
<asp:ListItem Value="Enabled"></asp:ListItem>
|
||||
<asp:ListItem Value="Disabled"></asp:ListItem>
|
||||
<asp:ListItem Value="Locked Out"></asp:ListItem>
|
||||
</asp:DropDownList>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td class="SubHead">
|
||||
<asp:Label ID="lblDemoAccount" runat="server" meta:resourcekey="lblDemoAccount" Text="Demo Account:"></asp:Label>
|
||||
|
|
|
@ -127,6 +127,9 @@ namespace WebsitePanel.Portal
|
|||
if (user.RoleId == (int)UserRole.Reseller) role.SelectedIndex = 2;
|
||||
if (user.RoleId == (int)UserRole.Administrator) role.SelectedIndex = 2;
|
||||
|
||||
// select loginStatus
|
||||
loginStatus.SelectedIndex = user.LoginStatusId;
|
||||
|
||||
// contact info
|
||||
contact.CompanyName = user.CompanyName;
|
||||
contact.Address = user.Address;
|
||||
|
@ -194,6 +197,8 @@ namespace WebsitePanel.Portal
|
|||
user.Username = txtUsername.Text;
|
||||
user.Password = userPassword.Password;
|
||||
user.IsDemo = chkDemo.Checked;
|
||||
|
||||
user.LoginStatusId = loginStatus.SelectedIndex;
|
||||
|
||||
// contact info
|
||||
user.CompanyName = contact.CompanyName;
|
||||
|
|
|
@ -1,32 +1,3 @@
|
|||
// Copyright (c) 2012, Outercurve Foundation.
|
||||
// All rights reserved.
|
||||
//
|
||||
// Redistribution and use in source and binary forms, with or without modification,
|
||||
// are permitted provided that the following conditions are met:
|
||||
//
|
||||
// - Redistributions of source code must retain the above copyright notice, this
|
||||
// list of conditions and the following disclaimer.
|
||||
//
|
||||
// - Redistributions in binary form must reproduce the above copyright notice,
|
||||
// this list of conditions and the following disclaimer in the documentation
|
||||
// and/or other materials provided with the distribution.
|
||||
//
|
||||
// - Neither the name of the Outercurve Foundation nor the names of its
|
||||
// contributors may be used to endorse or promote products derived from this
|
||||
// software without specific prior written permission.
|
||||
//
|
||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||
// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
|
||||
// ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||
// ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
|
||||
//------------------------------------------------------------------------------
|
||||
// <auto-generated>
|
||||
// This code was generated by a tool.
|
||||
|
@ -302,6 +273,33 @@ namespace WebsitePanel.Portal {
|
|||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.DropDownList ddlMailFormat;
|
||||
|
||||
/// <summary>
|
||||
/// roleLoginStatus control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.HtmlControls.HtmlTableRow roleLoginStatus;
|
||||
|
||||
/// <summary>
|
||||
/// lblLoginStatus control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.Label lblLoginStatus;
|
||||
|
||||
/// <summary>
|
||||
/// loginStatus control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.DropDownList loginStatus;
|
||||
|
||||
/// <summary>
|
||||
/// lblDemoAccount control.
|
||||
/// </summary>
|
||||
|
|
|
@ -88,6 +88,20 @@
|
|||
<asp:CheckBox id="chkDemo" runat="server" meta:resourcekey="chkDemo" Text="Yes"></asp:CheckBox>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr id="roleLoginStatus" runat="server">
|
||||
<td class="SubHead" valign="top">
|
||||
<asp:Label ID="lblLoginStatus" runat="server" meta:resourcekey="lblLoginStatus" Text="Login Status:"></asp:Label>
|
||||
</td>
|
||||
<td class="NormalBold" valign="top">
|
||||
<asp:DropDownList id="loginStatus" runat="server" resourcekey="loginStatus" CssClass="NormalTextBox">
|
||||
<asp:ListItem Value="Enabled"></asp:ListItem>
|
||||
<asp:ListItem Value="Disabled"></asp:ListItem>
|
||||
<asp:ListItem Value="Locked Out"></asp:ListItem>
|
||||
</asp:DropDownList>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr id="rowEcommerceEnbl" runat="server">
|
||||
<td class="SubHead"><asp:Localize runat="server" meta:resourcekey="lclEcommerceEnabled" /></td>
|
||||
<td class="Normal"><asp:CheckBox runat="server" ID="chkEcommerceEnbl" Text="Yes"/></td>
|
||||
|
|
|
@ -61,6 +61,9 @@ namespace WebsitePanel.Portal
|
|||
// select role
|
||||
Utils.SelectListItem(role, user.Role.ToString());
|
||||
|
||||
// select loginStatus
|
||||
loginStatus.SelectedIndex = user.LoginStatusId;
|
||||
|
||||
// bind ec
|
||||
chkEcommerceEnbl.Checked = user.EcommerceEnabled;
|
||||
BindEcommerceEnabled();
|
||||
|
@ -120,6 +123,8 @@ namespace WebsitePanel.Portal
|
|||
//
|
||||
user.EcommerceEnabled = chkEcommerceEnbl.Checked;
|
||||
|
||||
user.LoginStatusId = loginStatus.SelectedIndex;
|
||||
|
||||
// account info
|
||||
user.FirstName = Server.HtmlEncode(txtFirstName.Text);
|
||||
user.LastName = Server.HtmlEncode(txtLastName.Text);
|
||||
|
|
|
@ -210,6 +210,33 @@ namespace WebsitePanel.Portal {
|
|||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.CheckBox chkDemo;
|
||||
|
||||
/// <summary>
|
||||
/// roleLoginStatus control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.HtmlControls.HtmlTableRow roleLoginStatus;
|
||||
|
||||
/// <summary>
|
||||
/// lblLoginStatus control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.Label lblLoginStatus;
|
||||
|
||||
/// <summary>
|
||||
/// loginStatus control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.DropDownList loginStatus;
|
||||
|
||||
/// <summary>
|
||||
/// rowEcommerceEnbl control.
|
||||
/// </summary>
|
||||
|
|
|
@ -112,10 +112,10 @@
|
|||
<value>2.0</value>
|
||||
</resheader>
|
||||
<resheader name="reader">
|
||||
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||
</resheader>
|
||||
<resheader name="writer">
|
||||
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||
</resheader>
|
||||
<data name="chkEnabled.Text" xml:space="preserve">
|
||||
<value>Enable Policy</value>
|
||||
|
@ -123,6 +123,9 @@
|
|||
<data name="chkNotEqualUsername.Text" xml:space="preserve">
|
||||
<value>Should not be equal to username</value>
|
||||
</data>
|
||||
<data name="lblLockedOut.Text" xml:space="preserve">
|
||||
<value>Lock out after # attempts:</value>
|
||||
</data>
|
||||
<data name="lblMaximumLength.Text" xml:space="preserve">
|
||||
<value>Maximum length:</value>
|
||||
</data>
|
||||
|
@ -141,6 +144,9 @@
|
|||
<data name="lblShouldContain.Text" xml:space="preserve">
|
||||
<value>Password should contain at least:</value>
|
||||
</data>
|
||||
<data name="valCorrectLockedOut.Text" xml:space="preserve">
|
||||
<value>*</value>
|
||||
</data>
|
||||
<data name="valCorrectMaxLength.Text" xml:space="preserve">
|
||||
<value>*</value>
|
||||
</data>
|
||||
|
|
|
@ -72,6 +72,18 @@
|
|||
<asp:CheckBox id="chkNotEqualUsername" runat="server" meta:resourcekey="chkNotEqualUsername" Text="Should not be equal to username" />
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td class="Normal">
|
||||
<asp:Label ID="lblLockedOut" runat="server"
|
||||
meta:resourcekey="lblLockedOut" Text="Lock out after :"></asp:Label>
|
||||
</td>
|
||||
<td class="Normal"><asp:TextBox ID="txtLockedOut" runat="server" CssClass="NormalTextBox" Width="40px"></asp:TextBox>
|
||||
<asp:RegularExpressionValidator ID="valCorrectLockedOut" runat="server" ControlToValidate="txtLockedOut" meta:resourcekey="valCorrectLockedOut"
|
||||
Display="Dynamic" ErrorMessage="*" ValidationExpression="\d{1,10}" ValidationGroup="SettingsEditor"></asp:RegularExpressionValidator>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
</table>
|
||||
|
||||
</ContentTemplate>
|
||||
|
|
|
@ -53,7 +53,9 @@ namespace WebsitePanel.Portal
|
|||
sb.Append(txtMinimumUppercase.Text).Append(";");
|
||||
sb.Append(txtMinimumNumbers.Text).Append(";");
|
||||
sb.Append(txtMinimumSymbols.Text).Append(";");
|
||||
sb.Append(chkNotEqualUsername.Checked.ToString());
|
||||
sb.Append(chkNotEqualUsername.Checked.ToString()).Append(";");
|
||||
sb.Append(txtLockedOut.Text).Append(";");
|
||||
|
||||
return sb.ToString();
|
||||
}
|
||||
set
|
||||
|
@ -67,6 +69,7 @@ namespace WebsitePanel.Portal
|
|||
txtMinimumUppercase.Text = "0";
|
||||
txtMinimumNumbers.Text = "0";
|
||||
txtMinimumSymbols.Text = "0";
|
||||
txtLockedOut.Text = "3";
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -81,10 +84,11 @@ namespace WebsitePanel.Portal
|
|||
txtMinimumNumbers.Text = parts[4];
|
||||
txtMinimumSymbols.Text = parts[5];
|
||||
chkNotEqualUsername.Checked = Utils.ParseBool(parts[6], false);
|
||||
txtLockedOut.Text = parts[7];
|
||||
}
|
||||
catch { /* skip */ }
|
||||
}
|
||||
ToggleControls();
|
||||
ToggleControls();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -92,14 +96,14 @@ namespace WebsitePanel.Portal
|
|||
{
|
||||
}
|
||||
|
||||
private void ToggleControls()
|
||||
{
|
||||
PolicyTable.Visible = chkEnabled.Checked;
|
||||
}
|
||||
private void ToggleControls()
|
||||
{
|
||||
PolicyTable.Visible = chkEnabled.Checked;
|
||||
}
|
||||
|
||||
protected void chkEnabled_CheckedChanged(object sender, EventArgs e)
|
||||
{
|
||||
ToggleControls();
|
||||
}
|
||||
protected void chkEnabled_CheckedChanged(object sender, EventArgs e)
|
||||
{
|
||||
ToggleControls();
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,41 +1,276 @@
|
|||
//------------------------------------------------------------------------------
|
||||
// <auto-generated>
|
||||
// This code was generated by a tool.
|
||||
// Runtime Version:2.0.50727.42
|
||||
//
|
||||
// Changes to this file may cause incorrect behavior and will be lost if
|
||||
// the code is regenerated.
|
||||
// the code is regenerated.
|
||||
// </auto-generated>
|
||||
//------------------------------------------------------------------------------
|
||||
|
||||
namespace WebsitePanel.Portal {
|
||||
|
||||
|
||||
public partial class PasswordPolicyEditor {
|
||||
protected System.Web.UI.UpdatePanel PasswordPolicyPanel;
|
||||
protected System.Web.UI.WebControls.CheckBox chkEnabled;
|
||||
protected System.Web.UI.HtmlControls.HtmlTable PolicyTable;
|
||||
protected System.Web.UI.WebControls.Label lblMinimumLength;
|
||||
protected System.Web.UI.WebControls.TextBox txtMinimumLength;
|
||||
protected System.Web.UI.WebControls.RequiredFieldValidator valRequireMinLength;
|
||||
protected System.Web.UI.WebControls.RegularExpressionValidator valCorrectMinLength;
|
||||
protected System.Web.UI.WebControls.Label lblMaximumLength;
|
||||
protected System.Web.UI.WebControls.TextBox txtMaximumLength;
|
||||
protected System.Web.UI.WebControls.RequiredFieldValidator valRequireMaxLength;
|
||||
protected System.Web.UI.WebControls.RegularExpressionValidator valCorrectMaxLength;
|
||||
protected System.Web.UI.WebControls.Label lblShouldContain;
|
||||
protected System.Web.UI.WebControls.Label lblMinimumUppercase;
|
||||
protected System.Web.UI.WebControls.TextBox txtMinimumUppercase;
|
||||
protected System.Web.UI.WebControls.RequiredFieldValidator valRequireUppercase;
|
||||
protected System.Web.UI.WebControls.RegularExpressionValidator valCorrectUppercase;
|
||||
protected System.Web.UI.WebControls.Label lblMinimumNumbers;
|
||||
protected System.Web.UI.WebControls.TextBox txtMinimumNumbers;
|
||||
protected System.Web.UI.WebControls.RequiredFieldValidator valRequireNumbers;
|
||||
protected System.Web.UI.WebControls.RegularExpressionValidator valCorrectNumbers;
|
||||
protected System.Web.UI.WebControls.Label lblMinimumSymbols;
|
||||
protected System.Web.UI.WebControls.TextBox txtMinimumSymbols;
|
||||
protected System.Web.UI.WebControls.RequiredFieldValidator valRequireSymbols;
|
||||
protected System.Web.UI.WebControls.RegularExpressionValidator valCorrectSymbols;
|
||||
protected System.Web.UI.HtmlControls.HtmlTableRow rowEqualUsername;
|
||||
protected System.Web.UI.WebControls.CheckBox chkNotEqualUsername;
|
||||
|
||||
/// <summary>
|
||||
/// PasswordPolicyPanel control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.UpdatePanel PasswordPolicyPanel;
|
||||
|
||||
/// <summary>
|
||||
/// chkEnabled control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.CheckBox chkEnabled;
|
||||
|
||||
/// <summary>
|
||||
/// PolicyTable control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.HtmlControls.HtmlTable PolicyTable;
|
||||
|
||||
/// <summary>
|
||||
/// lblMinimumLength control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.Label lblMinimumLength;
|
||||
|
||||
/// <summary>
|
||||
/// txtMinimumLength control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.TextBox txtMinimumLength;
|
||||
|
||||
/// <summary>
|
||||
/// valRequireMinLength control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.RequiredFieldValidator valRequireMinLength;
|
||||
|
||||
/// <summary>
|
||||
/// valCorrectMinLength control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.RegularExpressionValidator valCorrectMinLength;
|
||||
|
||||
/// <summary>
|
||||
/// lblMaximumLength control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.Label lblMaximumLength;
|
||||
|
||||
/// <summary>
|
||||
/// txtMaximumLength control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.TextBox txtMaximumLength;
|
||||
|
||||
/// <summary>
|
||||
/// valRequireMaxLength control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.RequiredFieldValidator valRequireMaxLength;
|
||||
|
||||
/// <summary>
|
||||
/// valCorrectMaxLength control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.RegularExpressionValidator valCorrectMaxLength;
|
||||
|
||||
/// <summary>
|
||||
/// lblShouldContain control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.Label lblShouldContain;
|
||||
|
||||
/// <summary>
|
||||
/// lblMinimumUppercase control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.Label lblMinimumUppercase;
|
||||
|
||||
/// <summary>
|
||||
/// txtMinimumUppercase control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.TextBox txtMinimumUppercase;
|
||||
|
||||
/// <summary>
|
||||
/// valRequireUppercase control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.RequiredFieldValidator valRequireUppercase;
|
||||
|
||||
/// <summary>
|
||||
/// valCorrectUppercase control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.RegularExpressionValidator valCorrectUppercase;
|
||||
|
||||
/// <summary>
|
||||
/// lblMinimumNumbers control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.Label lblMinimumNumbers;
|
||||
|
||||
/// <summary>
|
||||
/// txtMinimumNumbers control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.TextBox txtMinimumNumbers;
|
||||
|
||||
/// <summary>
|
||||
/// valRequireNumbers control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.RequiredFieldValidator valRequireNumbers;
|
||||
|
||||
/// <summary>
|
||||
/// valCorrectNumbers control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.RegularExpressionValidator valCorrectNumbers;
|
||||
|
||||
/// <summary>
|
||||
/// lblMinimumSymbols control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.Label lblMinimumSymbols;
|
||||
|
||||
/// <summary>
|
||||
/// txtMinimumSymbols control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.TextBox txtMinimumSymbols;
|
||||
|
||||
/// <summary>
|
||||
/// valRequireSymbols control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.RequiredFieldValidator valRequireSymbols;
|
||||
|
||||
/// <summary>
|
||||
/// valCorrectSymbols control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.RegularExpressionValidator valCorrectSymbols;
|
||||
|
||||
/// <summary>
|
||||
/// rowEqualUsername control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.HtmlControls.HtmlTableRow rowEqualUsername;
|
||||
|
||||
/// <summary>
|
||||
/// chkNotEqualUsername control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.CheckBox chkNotEqualUsername;
|
||||
|
||||
/// <summary>
|
||||
/// lblLockedOut control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.Label lblLockedOut;
|
||||
|
||||
/// <summary>
|
||||
/// txtLockedOut control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.TextBox txtLockedOut;
|
||||
|
||||
/// <summary>
|
||||
/// valCorrectLockedOut control.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// Auto-generated field.
|
||||
/// To modify move field declaration from designer file to code-behind file.
|
||||
/// </remarks>
|
||||
protected global::System.Web.UI.WebControls.RegularExpressionValidator valCorrectLockedOut;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -51,6 +51,11 @@
|
|||
DataSourceID="odsUsersPaged" EnableViewState="False"
|
||||
EmptyDataText="gvUsers">
|
||||
<Columns>
|
||||
<asp:TemplateField>
|
||||
<ItemTemplate>
|
||||
<asp:Image ID="img2" runat="server" Width="16px" Height="16px" ImageUrl='<%# GetStateImage(Eval("LoginStatusId")) %>' ImageAlign="AbsMiddle" />
|
||||
</ItemTemplate>
|
||||
</asp:TemplateField>
|
||||
<asp:TemplateField SortExpression="Username" HeaderText="gvUsersUsername" HeaderStyle-Wrap="false">
|
||||
<ItemTemplate>
|
||||
<asp:hyperlink id=lnkEdit runat="server" NavigateUrl='<%# GetUserHomePageUrl((int)Eval("UserID")) %>'>
|
||||
|
|
|
@ -37,6 +37,8 @@ using System.Web.UI.WebControls;
|
|||
using System.Web.UI.WebControls.WebParts;
|
||||
using System.Web.UI.HtmlControls;
|
||||
|
||||
using WebsitePanel.EnterpriseServer;
|
||||
|
||||
namespace WebsitePanel.Portal
|
||||
{
|
||||
public partial class UserCustomers : WebsitePanelModuleBase
|
||||
|
@ -85,5 +87,37 @@ namespace WebsitePanel.Portal
|
|||
Response.Redirect(EditUrl(PortalUtils.USER_ID_PARAM, PanelSecurity.SelectedUserId.ToString(), "create_user",
|
||||
"frm=customers"));
|
||||
}
|
||||
|
||||
protected string GetStateImage(object status)
|
||||
{
|
||||
string imgName = "enabled.png";
|
||||
|
||||
if (status != null)
|
||||
{
|
||||
try
|
||||
{
|
||||
switch ((int)status)
|
||||
{
|
||||
case (int)UserLoginStatus.Disabled:
|
||||
imgName = "disabled.png";
|
||||
break;
|
||||
case (int)UserLoginStatus.LockedOut:
|
||||
imgName = "locked.png";
|
||||
break;
|
||||
default:
|
||||
imgName = "enabled.png";
|
||||
break;
|
||||
}
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
return GetThemedImage("Exchange/" + imgName);
|
||||
}
|
||||
|
||||
}
|
||||
}
|
|
@ -106,6 +106,7 @@
|
|||
<Content Include="App_Themes\Default\Images\Exchange\disabled.png" />
|
||||
<Content Include="App_Themes\Default\Images\Exchange\disabled_16.png" />
|
||||
<Content Include="App_Themes\Default\Images\Exchange\enabled.png" />
|
||||
<Content Include="App_Themes\Default\Images\Exchange\locked.png" />
|
||||
<Content Include="App_Themes\Default\Images\Exchange\lync16.png" />
|
||||
<Content Include="App_Themes\Default\Images\FileManager\vbhtml.png" />
|
||||
<Content Include="App_Themes\Default\Images\lync16.png" />
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue