242 lines
7.8 KiB
Transact-SQL
242 lines
7.8 KiB
Transact-SQL
USE [BootstrapAdmin]
|
|
GO
|
|
|
|
SET ANSI_NULLS ON
|
|
GO
|
|
SET QUOTED_IDENTIFIER ON
|
|
GO
|
|
Drop PROCEDURE Proc_DeleteUsers
|
|
GO
|
|
-- =============================================
|
|
-- Author: Argo Zhang
|
|
-- Create date: 2016-09-06
|
|
-- Description:
|
|
-- =============================================
|
|
Create PROCEDURE Proc_DeleteUsers
|
|
-- Add the parameters for the stored procedure here
|
|
@ids varchar(max)
|
|
WITH ENCRYPTION
|
|
AS
|
|
BEGIN
|
|
-- SET NOCOUNT ON added to prevent extra result sets from
|
|
-- interfering with SELECT statements.
|
|
SET NOCOUNT ON;
|
|
SET XACT_ABORT ON;
|
|
-- Insert statements for procedure here
|
|
declare @sql varchar(max)
|
|
set @sql = 'Delete from UserRole where UserID in (' + @ids + ');'
|
|
set @sql += 'delete from UserGroup where UserID in (' + @ids + ');'
|
|
set @sql += 'delete from Users where ID in (' + @ids + ');'
|
|
exec(@sql)
|
|
END
|
|
GO
|
|
|
|
Drop PROCEDURE Proc_DeleteRoles
|
|
GO
|
|
-- =============================================
|
|
-- Author: LiuChun
|
|
-- Create date: 2016-11-07
|
|
-- Description:
|
|
-- =============================================
|
|
Create PROCEDURE Proc_DeleteRoles
|
|
-- Add the parameters for the stored procedure here
|
|
@ids varchar(max)
|
|
WITH ENCRYPTION
|
|
AS
|
|
BEGIN
|
|
-- SET NOCOUNT ON added to prevent extra result sets from
|
|
-- interfering with SELECT statements.
|
|
SET NOCOUNT ON;
|
|
SET XACT_ABORT ON;
|
|
-- Insert statements for procedure here
|
|
declare @sql varchar(max)
|
|
set @sql = 'delete from UserRole where RoleID in (' + @ids + ');'
|
|
set @sql += 'delete from RoleGroup where RoleID in (' + @ids + ');'
|
|
set @sql += 'delete from NavigationRole where RoleID in (' + @ids + ');'
|
|
set @sql += 'delete from Roles where ID in (' + @ids + ');'
|
|
exec(@sql)
|
|
END
|
|
GO
|
|
|
|
|
|
Drop PROCEDURE Proc_DeleteGroups
|
|
GO
|
|
-- =============================================
|
|
-- Author: LiuChun
|
|
-- Create date: 2016-11-07
|
|
-- Description:
|
|
-- =============================================
|
|
Create PROCEDURE Proc_DeleteGroups
|
|
-- Add the parameters for the stored procedure here
|
|
@ids varchar(max)
|
|
WITH ENCRYPTION
|
|
AS
|
|
BEGIN
|
|
-- SET NOCOUNT ON added to prevent extra result sets from
|
|
-- interfering with SELECT statements.
|
|
SET NOCOUNT ON;
|
|
SET XACT_ABORT ON;
|
|
-- Insert statements for procedure here
|
|
declare @sql varchar(max)
|
|
set @sql = 'delete from UserGroup where GroupID in (' + @ids + ');'
|
|
set @sql += 'delete from RoleGroup where GroupID in (' + @ids + ');'
|
|
set @sql += 'delete from Groups where ID in (' + @ids + ');'
|
|
exec(@sql)
|
|
END
|
|
GO
|
|
|
|
Drop PROCEDURE Proc_DeleteMenus
|
|
GO
|
|
-- =============================================
|
|
-- Author: LiuChun
|
|
-- Create date: 2016-11-07
|
|
-- Description:
|
|
-- =============================================
|
|
Create PROCEDURE Proc_DeleteMenus
|
|
-- Add the parameters for the stored procedure here
|
|
@ids varchar(max)
|
|
WITH ENCRYPTION
|
|
AS
|
|
BEGIN
|
|
-- SET NOCOUNT ON added to prevent extra result sets from
|
|
-- interfering with SELECT statements.
|
|
SET NOCOUNT ON;
|
|
SET XACT_ABORT ON;
|
|
-- Insert statements for procedure here
|
|
declare @sql varchar(max)
|
|
set @sql = 'delete from NavigationRole where NavigationID in (' + @ids + ');'
|
|
set @sql += 'delete from Navigations where ID in (' + @ids + ');'
|
|
exec(@sql)
|
|
END
|
|
GO
|
|
|
|
Drop PROCEDURE Proc_RetrieveMenus
|
|
GO
|
|
-- =============================================
|
|
-- Author: Argo Zhang
|
|
-- Create date: 2016-11-08
|
|
-- Description:
|
|
-- =============================================
|
|
Create PROCEDURE Proc_RetrieveMenus
|
|
-- Add the parameters for the stored procedure here
|
|
@userName varchar(50) = null
|
|
WITH ENCRYPTION
|
|
AS
|
|
BEGIN
|
|
-- SET NOCOUNT ON added to prevent extra result sets from
|
|
-- interfering with SELECT statements.
|
|
SET NOCOUNT ON;
|
|
SET XACT_ABORT ON;
|
|
-- Insert statements for procedure here
|
|
if @userName = '' or @userName is null or exists(select ur.ID from Users u inner join UserRole ur on u.ID = ur.UserID inner join Roles r on ur.RoleID = r.ID where r.RoleName = 'administrators' and u.UserName = @userName)
|
|
select n.ID, n.ParentId, n.Name, n.[Order], n.Icon, n.Url, n.Category, n.Target, n.IsResource, n.[Application], d.Name as CategoryName, ln.Name as ParentName
|
|
from Navigations n inner join Dicts d on n.Category = d.Code and d.Category = N'菜单' and d.Define = 0
|
|
left join Navigations ln on n.ParentId = ln.ID
|
|
else
|
|
select n.ID, n.ParentId, n.Name, n.[Order], n.Icon, n.Url, n.Category, n.Target, n.IsResource, n.[Application], d.Name as CategoryName, ln.Name as ParentName
|
|
from Navigations n inner join Dicts d on n.Category = d.Code and d.Category = N'菜单' and d.Define = 0
|
|
left join Navigations ln on n.ParentId = ln.ID
|
|
inner join (
|
|
select nr.NavigationID from Users u
|
|
inner join UserRole ur on ur.UserID = u.ID
|
|
inner join NavigationRole nr on nr.RoleID = ur.RoleID
|
|
where u.UserName = @userName
|
|
union
|
|
select nr.NavigationID from Users u
|
|
inner join UserGroup ug on u.ID = ug.UserID
|
|
inner join RoleGroup rg on rg.GroupID = ug.GroupID
|
|
inner join NavigationRole nr on nr.RoleID = rg.RoleID
|
|
where u.UserName = @userName
|
|
union
|
|
select n.ID from Navigations n
|
|
where EXISTS (select UserName from Users u
|
|
inner join UserRole ur on u.ID = ur.UserID
|
|
inner join Roles r on ur.RoleID = r.ID
|
|
where u.UserName = @userName and r.RoleName = N'Administrators'
|
|
)
|
|
) nav on n.ID = nav.NavigationID
|
|
END
|
|
GO
|
|
|
|
/****** Object: StoredProcedure [dbo].[Proc_SaveUsers] Script Date: 11/11/2016 08:51:44 ******/
|
|
SET ANSI_NULLS ON
|
|
GO
|
|
|
|
SET QUOTED_IDENTIFIER ON
|
|
GO
|
|
|
|
Drop PROCEDURE Proc_SaveUsers
|
|
GO
|
|
-- =============================================
|
|
-- Author: LiuChun
|
|
-- Create date: 2016-11-10
|
|
-- Description:
|
|
-- =============================================
|
|
CREATE PROCEDURE [dbo].[Proc_SaveUsers]
|
|
-- Add the parameters for the stored procedure here
|
|
@userName varchar(50),
|
|
@password varchar(50),
|
|
@passSalt varchar(50),
|
|
@displayName nvarchar(50),
|
|
@approvedBy nvarchar(50) = null,
|
|
@description nvarchar(500)
|
|
WITH ENCRYPTION
|
|
AS
|
|
BEGIN
|
|
-- SET NOCOUNT ON added to prevent extra result sets from
|
|
-- interfering with SELECT statements.
|
|
SET NOCOUNT ON;
|
|
SET XACT_ABORT ON;
|
|
-- Insert statements for procedure here
|
|
declare @approvedTime datetime
|
|
if @approvedBy is not null set @approvedTime = GETDATE()
|
|
|
|
begin
|
|
if(not exists (select 1 from Users Where UserName = @userName))
|
|
begin
|
|
begin tran
|
|
Insert Into Users (UserName, [Password], PassSalt, DisplayName, RegisterTime, ApprovedBy, ApprovedTime, [Description]) values (@userName, @password, @passSalt, @displayName, GETDATE(), @approvedBy, @approvedTime, @description)
|
|
insert into UserRole (UserID, RoleID) select @@IDENTITY, ID from Roles where RoleName = N'Default'
|
|
commit tran
|
|
end
|
|
end
|
|
END
|
|
GO
|
|
|
|
Drop PROCEDURE Proc_RejectUsers
|
|
GO
|
|
-- =============================================
|
|
-- Author: Argo
|
|
-- Create date: 2018-09-07
|
|
-- Description:
|
|
-- =============================================
|
|
CREATE PROCEDURE [dbo].[Proc_RejectUsers]
|
|
-- Add the parameters for the stored procedure here
|
|
@id int,
|
|
@rejectedBy varchar(50),
|
|
@rejectedReason nvarchar(50)
|
|
WITH ENCRYPTION
|
|
AS
|
|
BEGIN
|
|
-- SET NOCOUNT ON added to prevent extra result sets from
|
|
-- interfering with SELECT statements.
|
|
SET NOCOUNT ON;
|
|
SET XACT_ABORT ON;
|
|
-- Insert statements for procedure here
|
|
begin
|
|
declare @registerTime datetime
|
|
declare @userName varchar(50)
|
|
declare @displayName nvarchar(50)
|
|
select @registerTime = Registertime, @userName = UserName, @displayName = DisplayName from Users where ID = @id
|
|
|
|
if @userName is not null
|
|
begin
|
|
begin tran
|
|
insert into RejectUsers (UserName, DisplayName, RegisterTime, RejectedBy, RejectedTime, RejectedReason) values (@userName, @displayName, @registerTime, @rejectedBy, GETDATE(), @rejectedReason)
|
|
delete from users where ID = @id
|
|
commit tran
|
|
end
|
|
end
|
|
END
|
|
GO
|