diff --git a/WebsitePanel/Database/update_db.sql b/WebsitePanel/Database/update_db.sql index d3e28219..f762c643 100644 --- a/WebsitePanel/Database/update_db.sql +++ b/WebsitePanel/Database/update_db.sql @@ -2240,4 +2240,94 @@ LEFT OUTER JOIN ExchangeMailboxPlans AS P ON EA.MailboxPlanId = P.MailboxPlanId EXEC sp_executesql @sql, N'@ItemID int', @ItemID RETURN -GO \ No newline at end of file +GO + +---- Additional Default Groups------------- + +IF EXISTS (SELECT * FROM SYS.TABLES WHERE name = 'AdditionalGroups') +DROP TABLE AdditionalGroups +GO + +CREATE TABLE AdditionalGroups +( + ID INT IDENTITY(1,1) NOT NULL PRIMARY KEY, + UserID INT NOT NULL, + GroupName NVARCHAR(255) +) +GO + +IF EXISTS (SELECT * FROM SYS.OBJECTS WHERE type = 'P' AND name = 'GetAdditionalGroups') +DROP PROCEDURE GetAdditionalGroups +GO + +CREATE PROCEDURE [dbo].[GetAdditionalGroups] +( + @UserID INT +) +AS + +SELECT + AG.ID, + AG.UserID, + AG.GroupName +FROM AdditionalGroups AS AG +WHERE AG.UserID = @UserID +GO + +IF EXISTS (SELECT * FROM SYS.OBJECTS WHERE type = 'P' AND name = 'AddAdditionalGroup') +DROP PROCEDURE AddAdditionalGroup +GO + +CREATE PROCEDURE [dbo].[AddAdditionalGroup] +( + @GroupID INT OUTPUT, + @UserID INT, + @GroupName NVARCHAR(255) +) +AS + +INSERT INTO AdditionalGroups +( + UserID, + GroupName +) +VALUES +( + @UserID, + @GroupName +) + +SET @GroupID = SCOPE_IDENTITY() + +RETURN +GO + +IF EXISTS (SELECT * FROM SYS.OBJECTS WHERE type = 'P' AND name = 'DeleteAdditionalGroup') +DROP PROCEDURE DeleteAdditionalGroup +GO + +CREATE PROCEDURE [dbo].[DeleteAdditionalGroup] +( + @GroupID INT +) +AS + +DELETE FROM AdditionalGroups +WHERE ID = @GroupID +GO + +IF EXISTS (SELECT * FROM SYS.OBJECTS WHERE type = 'P' AND name = 'UpdateAdditionalGroup') +DROP PROCEDURE UpdateAdditionalGroup +GO + +CREATE PROCEDURE [dbo].[UpdateAdditionalGroup] +( + @GroupID INT, + @GroupName NVARCHAR(255) +) +AS + +UPDATE AdditionalGroups SET + GroupName = @GroupName +WHERE ID = @GroupID +GO diff --git a/WebsitePanel/Sources/WebsitePanel.EnterpriseServer.Base/HostedSolution/AdditionalGroup.cs b/WebsitePanel/Sources/WebsitePanel.EnterpriseServer.Base/HostedSolution/AdditionalGroup.cs new file mode 100644 index 00000000..c7dd8c98 --- /dev/null +++ b/WebsitePanel/Sources/WebsitePanel.EnterpriseServer.Base/HostedSolution/AdditionalGroup.cs @@ -0,0 +1,20 @@ +namespace WebsitePanel.EnterpriseServer.Base.HostedSolution +{ + public class AdditionalGroup + { + int groupId; + string groupName; + + public int GroupId + { + get { return this.groupId; } + set { this.groupId = value; } + } + + public string GroupName + { + get { return this.groupName; } + set { this.groupName = value; } + } + } +} diff --git a/WebsitePanel/Sources/WebsitePanel.EnterpriseServer.Base/WebsitePanel.EnterpriseServer.Base.csproj b/WebsitePanel/Sources/WebsitePanel.EnterpriseServer.Base/WebsitePanel.EnterpriseServer.Base.csproj index dde357fa..e5ea3611 100644 --- a/WebsitePanel/Sources/WebsitePanel.EnterpriseServer.Base/WebsitePanel.EnterpriseServer.Base.csproj +++ b/WebsitePanel/Sources/WebsitePanel.EnterpriseServer.Base/WebsitePanel.EnterpriseServer.Base.csproj @@ -116,6 +116,7 @@ + @@ -236,6 +237,7 @@ true +