From 79515519cbb7d357d0aa4eb498eb2a3eb2ae3633 Mon Sep 17 00:00:00 2001 From: gchauhan-aot <113390759+gchauhan-aot@users.noreply.github.com> Date: Fri, 26 Jul 2024 12:47:41 -0600 Subject: [PATCH] ORV2-1506 Database Table Creation for OnRouteBC Special Authorization (#1518) Co-authored-by: John Fletcher --- .../versions/revert/v_37_ddl_revert.sql | 27 ++++ database/mssql/scripts/versions/v_37_ddl.sql | 147 ++++++++++++++++++ database/mssql/test/versions/v_35_1_test.sql | 5 +- database/mssql/test/versions/v_35_2_test.sql | 2 +- database/mssql/test/versions/v_37_1_test.sql | 8 + database/mssql/test/versions/v_37_test.sh | 16 ++ 6 files changed, 202 insertions(+), 3 deletions(-) create mode 100644 database/mssql/scripts/versions/revert/v_37_ddl_revert.sql create mode 100644 database/mssql/scripts/versions/v_37_ddl.sql create mode 100644 database/mssql/test/versions/v_37_1_test.sql create mode 100644 database/mssql/test/versions/v_37_test.sh diff --git a/database/mssql/scripts/versions/revert/v_37_ddl_revert.sql b/database/mssql/scripts/versions/revert/v_37_ddl_revert.sql new file mode 100644 index 000000000..afdb44dd6 --- /dev/null +++ b/database/mssql/scripts/versions/revert/v_37_ddl_revert.sql @@ -0,0 +1,27 @@ +SET ANSI_NULLS ON +GO +SET QUOTED_IDENTIFIER ON +GO +SET NOCOUNT ON +GO + +SET XACT_ABORT ON + +BEGIN TRY + BEGIN TRANSACTION + DROP TABLE [permit].[ORBC_SPECIAL_AUTH_HIST] + DROP TABLE [permit].[ORBC_SPECIAL_AUTH] + DROP SEQUENCE [permit].[ORBC_SPECIAL_AUTH_H_ID_SEQ] + DROP TABLE [permit].[ORBC_NO_FEE_TYPE] COMMIT +END TRY + +BEGIN CATCH + IF @@TRANCOUNT > 0 + ROLLBACK; + THROW +END CATCH + +DECLARE @VersionDescription VARCHAR(255) +SET @VersionDescription = 'Deleting orbc special authorization tables' + +INSERT [dbo].[ORBC_SYS_VERSION] ([VERSION_ID], [DESCRIPTION], [RELEASE_DATE]) VALUES (36, @VersionDescription, getutcdate()) diff --git a/database/mssql/scripts/versions/v_37_ddl.sql b/database/mssql/scripts/versions/v_37_ddl.sql new file mode 100644 index 000000000..d8dd735ac --- /dev/null +++ b/database/mssql/scripts/versions/v_37_ddl.sql @@ -0,0 +1,147 @@ +SET ANSI_NULLS ON +GO +SET QUOTED_IDENTIFIER ON +GO +SET NOCOUNT ON +GO + +SET XACT_ABORT ON +GO +SET TRANSACTION ISOLATION LEVEL SERIALIZABLE +GO +BEGIN TRANSACTION +GO +IF @@ERROR <> 0 SET NOEXEC ON +GO + +CREATE TABLE [permit].[ORBC_SPECIAL_AUTH]( + [ID] [int] IDENTITY(1,1) NOT NULL, + [COMPANY_ID] [int] NOT NULL, + [LCV] [char](1) NOT NULL, + [NO_FEE_TYPE] [varchar](12) NULL, + [APP_CREATE_TIMESTAMP] [datetime2](7) DEFAULT (getutcdate()), + [APP_CREATE_USERID] [nvarchar](30) DEFAULT (user_name()), + [APP_CREATE_USER_GUID] [char](32) NULL, + [APP_CREATE_USER_DIRECTORY] [nvarchar](30) DEFAULT (user_name()), + [APP_LAST_UPDATE_TIMESTAMP] [datetime2](7) DEFAULT (getutcdate()), + [APP_LAST_UPDATE_USERID] [nvarchar](30) DEFAULT (user_name()), + [APP_LAST_UPDATE_USER_GUID] [char](32) NULL, + [APP_LAST_UPDATE_USER_DIRECTORY] [nvarchar](30) DEFAULT (user_name()), + [CONCURRENCY_CONTROL_NUMBER] [int] NULL, + [DB_CREATE_USERID] [varchar](63) NOT NULL, + [DB_CREATE_TIMESTAMP] [datetime2](7) NOT NULL, + [DB_LAST_UPDATE_USERID] [varchar](63) NOT NULL, + [DB_LAST_UPDATE_TIMESTAMP] [datetime2](7) NOT NULL, + CONSTRAINT [PK_ORBC_SPECIAL_AUTH] PRIMARY KEY CLUSTERED +( + [ID] ASC +)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] +) ON [PRIMARY] +GO + +CREATE SEQUENCE [permit].[ORBC_SPECIAL_AUTH_H_ID_SEQ] AS [bigint] START WITH 1 INCREMENT BY 1 MINVALUE 1 MAXVALUE 2147483647 CACHE 50; + +CREATE TABLE [permit].[ORBC_SPECIAL_AUTH_HIST]( + _SPECIAL_AUTH_HIST_ID [bigint] DEFAULT (NEXT VALUE FOR [permit].[ORBC_SPECIAL_AUTH_H_ID_SEQ]) NOT NULL + ,EFFECTIVE_DATE_HIST [datetime] NOT NULL default getutcdate() + ,END_DATE_HIST [datetime] + , [ID] int NOT NULL, [COMPANY_ID] int NOT NULL, [LCV] char(1) NOT NULL, [NO_FEE_TYPE] varchar(12) NOT NULL, [APP_CREATE_TIMESTAMP] datetime2 NULL, [APP_CREATE_USERID] nvarchar(30) NULL, [APP_CREATE_USER_GUID] char(32) NULL, [APP_CREATE_USER_DIRECTORY] nvarchar(30) NULL, [APP_LAST_UPDATE_TIMESTAMP] datetime2 NULL, [APP_LAST_UPDATE_USERID] nvarchar(30) NULL, [APP_LAST_UPDATE_USER_GUID] char(32) NULL, [APP_LAST_UPDATE_USER_DIRECTORY] nvarchar(30) NULL, [CONCURRENCY_CONTROL_NUMBER] int NULL, [DB_CREATE_USERID] varchar(63) NOT NULL, [DB_CREATE_TIMESTAMP] datetime2 NOT NULL, [DB_LAST_UPDATE_USERID] varchar(63) NOT NULL, [DB_LAST_UPDATE_TIMESTAMP] datetime2 NOT NULL + ) +ALTER TABLE [permit].[ORBC_SPECIAL_AUTH_HIST] ADD CONSTRAINT ORBC_28_H_PK PRIMARY KEY CLUSTERED (_SPECIAL_AUTH_HIST_ID); +ALTER TABLE [permit].[ORBC_SPECIAL_AUTH_HIST] ADD CONSTRAINT ORBC_28_H_UK UNIQUE (_SPECIAL_AUTH_HIST_ID,END_DATE_HIST) +go + +CREATE TRIGGER ORBC_SPECIAL_AUTH_A_S_IUD_TR ON [permit].[ORBC_SPECIAL_AUTH] FOR INSERT, UPDATE, DELETE AS +SET NOCOUNT ON +BEGIN TRY +DECLARE @curr_date datetime; +SET @curr_date = getutcdate(); + IF NOT EXISTS(SELECT * FROM inserted) AND NOT EXISTS(SELECT * FROM deleted) + RETURN; + + -- historical + IF EXISTS(SELECT * FROM deleted) + update [permit].[ORBC_SPECIAL_AUTH_HIST] set END_DATE_HIST = @curr_date where ID in (select ID from deleted) and END_DATE_HIST is null; + IF EXISTS(SELECT * FROM inserted) + insert into [permit].[ORBC_SPECIAL_AUTH_HIST] ([ID], [COMPANY_ID], [LCV], [NO_FEE_TYPE], [APP_CREATE_TIMESTAMP], [APP_CREATE_USERID], [APP_CREATE_USER_GUID], [APP_CREATE_USER_DIRECTORY], [APP_LAST_UPDATE_TIMESTAMP], [APP_LAST_UPDATE_USERID], [APP_LAST_UPDATE_USER_GUID], [APP_LAST_UPDATE_USER_DIRECTORY], [CONCURRENCY_CONTROL_NUMBER], [DB_CREATE_USERID], [DB_CREATE_TIMESTAMP], [DB_LAST_UPDATE_USERID], [DB_LAST_UPDATE_TIMESTAMP], _SPECIAL_AUTH_HIST_ID, END_DATE_HIST, EFFECTIVE_DATE_HIST) + select [ID], [COMPANY_ID], [LCV], [NO_FEE_TYPE], [APP_CREATE_TIMESTAMP], [APP_CREATE_USERID], [APP_CREATE_USER_GUID], [APP_CREATE_USER_DIRECTORY], [APP_LAST_UPDATE_TIMESTAMP], [APP_LAST_UPDATE_USERID], [APP_LAST_UPDATE_USER_GUID], [APP_LAST_UPDATE_USER_DIRECTORY], [CONCURRENCY_CONTROL_NUMBER], [DB_CREATE_USERID], [DB_CREATE_TIMESTAMP], [DB_LAST_UPDATE_USERID], [DB_LAST_UPDATE_TIMESTAMP], (next value for [permit].[ORBC_SPECIAL_AUTH_H_ID_SEQ]) as [_SPECIAL_AUTH_HIST_ID], null as [END_DATE_HIST], @curr_date as [EFFECTIVE_DATE_HIST] from inserted; + +END TRY +BEGIN CATCH + IF @@trancount > 0 ROLLBACK TRANSACTION + EXEC orbc_error_handling +END CATCH; +go + +CREATE TABLE [permit].[ORBC_NO_FEE_TYPE]( + [NO_FEE_TYPE] [varchar](12) NOT NULL, + [DESCRIPTION] [nvarchar](100) NOT NULL, + [CONCURRENCY_CONTROL_NUMBER] [int] NULL, + [DB_CREATE_USERID] [varchar](63) NOT NULL, + [DB_CREATE_TIMESTAMP] [datetime2](7) NOT NULL, + [DB_LAST_UPDATE_USERID] [varchar](63) NOT NULL, + [DB_LAST_UPDATE_TIMESTAMP] [datetime2](7) NOT NULL, + CONSTRAINT [PK_ORBC_NO_FEE_TYPE] PRIMARY KEY CLUSTERED +( + [NO_FEE_TYPE] ASC +)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] +) ON [PRIMARY] +GO + +ALTER TABLE [permit].[ORBC_SPECIAL_AUTH] WITH CHECK ADD CONSTRAINT [FK_ORBC_SPECIAL_AUTH_COMPANY_ID] FOREIGN KEY([COMPANY_ID]) +REFERENCES [dbo].[ORBC_COMPANY] ([COMPANY_ID]) +ALTER TABLE [permit].[ORBC_SPECIAL_AUTH] CHECK CONSTRAINT [FK_ORBC_SPECIAL_AUTH_COMPANY_ID] +-- Check Contraints +ALTER TABLE [permit].[ORBC_SPECIAL_AUTH] WITH CHECK ADD CONSTRAINT DK_ORBC_SPECIAL_AUTH_LCV_VAL CHECK ([LCV] IN ('Y','N')); +GO +ALTER TABLE [permit].[ORBC_SPECIAL_AUTH] WITH CHECK ADD CONSTRAINT [FK_ORBC_SPECIAL_AUTH_NO_FEE_TYPE] FOREIGN KEY([NO_FEE_TYPE]) +REFERENCES [permit].[ORBC_NO_FEE_TYPE] ([NO_FEE_TYPE]) +ALTER TABLE [permit].[ORBC_SPECIAL_AUTH] CHECK CONSTRAINT [FK_ORBC_SPECIAL_AUTH_NO_FEE_TYPE] +GO + +-- Default values +ALTER TABLE [permit].[ORBC_SPECIAL_AUTH] + ADD CONSTRAINT [DF_ORBC_SPECIAL_AUTH_LCV] + DEFAULT('N') + FOR [LCV] +GO + +INSERT [permit].[ORBC_NO_FEE_TYPE] ([NO_FEE_TYPE], [DESCRIPTION], [CONCURRENCY_CONTROL_NUMBER], [DB_CREATE_USERID], [DB_CREATE_TIMESTAMP], [DB_LAST_UPDATE_USERID], [DB_LAST_UPDATE_TIMESTAMP]) VALUES (N'CA_GOVT', N'The government of Canada or any province or any territory', NULL, N'dbo', GETUTCDATE(), N'dbo', GETUTCDATE()) +INSERT [permit].[ORBC_NO_FEE_TYPE] ([NO_FEE_TYPE], [DESCRIPTION], [CONCURRENCY_CONTROL_NUMBER], [DB_CREATE_USERID], [DB_CREATE_TIMESTAMP], [DB_LAST_UPDATE_USERID], [DB_LAST_UPDATE_TIMESTAMP]) VALUES (N'MUNICPALITY', N'A municipality', NULL, N'dbo', GETUTCDATE(), N'dbo', GETUTCDATE()) +INSERT [permit].[ORBC_NO_FEE_TYPE] ([NO_FEE_TYPE], [DESCRIPTION], [CONCURRENCY_CONTROL_NUMBER], [DB_CREATE_USERID], [DB_CREATE_TIMESTAMP], [DB_LAST_UPDATE_USERID], [DB_LAST_UPDATE_TIMESTAMP]) VALUES (N'SCHOOL', N'A school distrct outside of BC (S.9 Commercial Transaport Act)', NULL, N'dbo', GETUTCDATE(), N'dbo', GETUTCDATE()) +INSERT [permit].[ORBC_NO_FEE_TYPE] ([NO_FEE_TYPE], [DESCRIPTION], [CONCURRENCY_CONTROL_NUMBER], [DB_CREATE_USERID], [DB_CREATE_TIMESTAMP], [DB_LAST_UPDATE_USERID], [DB_LAST_UPDATE_TIMESTAMP]) VALUES (N'USA_GOVT', N'The government of the United States of America', NULL, N'dbo', GETUTCDATE(), N'dbo', GETUTCDATE()) +INSERT [permit].[ORBC_NO_FEE_TYPE] ([NO_FEE_TYPE], [DESCRIPTION], [CONCURRENCY_CONTROL_NUMBER], [DB_CREATE_USERID], [DB_CREATE_TIMESTAMP], [DB_LAST_UPDATE_USERID], [DB_LAST_UPDATE_TIMESTAMP]) VALUES (N'ANY_USA_GOVT', N'The government of any state or country in the Unites States of America', NULL, N'dbo', GETUTCDATE(), N'dbo', GETUTCDATE()) +GO + +EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'Surrogate primary key for the special authorization table' , @level0type=N'SCHEMA',@level0name=N'permit', @level1type=N'TABLE',@level1name=N'ORBC_SPECIAL_AUTH', @level2type=N'COLUMN',@level2name=N'ID' +EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'Foreign key to the ORBC_COMPANY table, this field represents the company that holds the special authorizations' , @level0type=N'SCHEMA',@level0name=N'permit', @level1type=N'TABLE',@level1name=N'ORBC_SPECIAL_AUTH', @level2type=N'COLUMN',@level2name=N'COMPANY_ID' +EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'The LCV flag indicates whether a company is permitted to operate long combination vehicles' , @level0type=N'SCHEMA',@level0name=N'permit', @level1type=N'TABLE',@level1name=N'ORBC_SPECIAL_AUTH', @level2type=N'COLUMN',@level2name=N'LCV' +EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'Foreign key to ORBC_NO_FEE_TYPE table. If the fee type is null, it indicates that the company cannot apply for free permits. Otherwise, it provides the description why the company is eligible for free permits.' , @level0type=N'SCHEMA',@level0name=N'permit', @level1type=N'TABLE',@level1name=N'ORBC_SPECIAL_AUTH', @level2type=N'COLUMN',@level2name=N'NO_FEE_TYPE' +EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'It provides the abbreviations of the conditions under which the company is eligible for free permits.' , @level0type=N'SCHEMA',@level0name=N'permit', @level1type=N'TABLE',@level1name=N'ORBC_NO_FEE_TYPE', @level2type=N'COLUMN',@level2name=N'NO_FEE_TYPE' +EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'It provides the description of the conditions under which the company is eligible for free permits.' , @level0type=N'SCHEMA',@level0name=N'permit', @level1type=N'TABLE',@level1name=N'ORBC_NO_FEE_TYPE', @level2type=N'COLUMN',@level2name=N'DESCRIPTION' +GO + +IF @@ERROR <> 0 SET NOEXEC ON +GO + +DECLARE @VersionDescription VARCHAR(255) +SET @VersionDescription = 'Creation of orbc special authorization tables' + +INSERT [dbo].[ORBC_SYS_VERSION] ([VERSION_ID], [DESCRIPTION], [UPDATE_SCRIPT], [REVERT_SCRIPT], [RELEASE_DATE]) VALUES (37, @VersionDescription, '$(UPDATE_SCRIPT)', '$(REVERT_SCRIPT)', getutcdate()) +IF @@ERROR <> 0 SET NOEXEC ON +GO + +COMMIT TRANSACTION +GO +IF @@ERROR <> 0 SET NOEXEC ON +GO +DECLARE @Success AS BIT +SET @Success = 1 +SET NOEXEC OFF +IF (@Success = 1) PRINT 'The database update succeeded' +ELSE BEGIN + IF @@TRANCOUNT > 0 ROLLBACK TRANSACTION + PRINT 'The database update failed' +END +GO + diff --git a/database/mssql/test/versions/v_35_1_test.sql b/database/mssql/test/versions/v_35_1_test.sql index bc3b47b72..4bdbc0cc1 100644 --- a/database/mssql/test/versions/v_35_1_test.sql +++ b/database/mssql/test/versions/v_35_1_test.sql @@ -1,7 +1,7 @@ -- Test that the auth groups have been inserted correctly SET NOCOUNT ON -SELECT COUNT(*) FROM $(DB_NAME).[access].[ORBC_USER_AUTH_GROUP_TYPE] +SELECT COUNT(*) FROM $(DB_NAME).[access].[ORBC_GROUP_ROLE] WHERE USER_AUTH_GROUP_TYPE IN ( 'PAPPLICANT', 'ORGADMIN', @@ -15,5 +15,6 @@ WHERE USER_AUTH_GROUP_TYPE IN ( 'ORBC-READ-LCV-FLAG', 'ORBC-READ-LOA', 'ORBC-READ-SPECIAL-AUTH', - 'ORBC-WRITE-LOA' + 'ORBC-WRITE-LOA', + 'ORBC-WRITE-NOFEE' ) \ No newline at end of file diff --git a/database/mssql/test/versions/v_35_2_test.sql b/database/mssql/test/versions/v_35_2_test.sql index fe4596ef7..2f7f6e73a 100644 --- a/database/mssql/test/versions/v_35_2_test.sql +++ b/database/mssql/test/versions/v_35_2_test.sql @@ -1,6 +1,6 @@ -- Test that the auth groups have been inserted correctly SET NOCOUNT ON -SELECT COUNT(*) FROM $(DB_NAME).[access].[ORBC_USER_AUTH_GROUP_TYPE] +SELECT COUNT(*) FROM $(DB_NAME).[access].[ORBC_GROUP_ROLE] WHERE USER_AUTH_GROUP_TYPE = 'FINANCE' AND ROLE_TYPE = 'ORBC-READ-LCV-FLAG' \ No newline at end of file diff --git a/database/mssql/test/versions/v_37_1_test.sql b/database/mssql/test/versions/v_37_1_test.sql new file mode 100644 index 000000000..27217ffe0 --- /dev/null +++ b/database/mssql/test/versions/v_37_1_test.sql @@ -0,0 +1,8 @@ +-- Test that the role types have been inserted correctly against user auth groups +SET NOCOUNT ON + +IF OBJECT_ID('[$(DB_NAME)].[permit].[ORBC_NO_FEE_TYPE]', 'U') IS NOT NULL +AND OBJECT_ID('[$(DB_NAME)].[permit].[ORBC_SPECIAL_AUTH]', 'U') IS NOT NULL + SELECT 1 +ELSE + SELECT 0 \ No newline at end of file diff --git a/database/mssql/test/versions/v_37_test.sh b/database/mssql/test/versions/v_37_test.sh new file mode 100644 index 000000000..24c87f2c3 --- /dev/null +++ b/database/mssql/test/versions/v_37_test.sh @@ -0,0 +1,16 @@ +#!/bin/bash + +# Retrieve arguments +source ${SCRIPT_DIR}/utility/getopt.sh +USAGE="-u USER -p PASS -s SERVER -d DATABASE" +parse_options "${USAGE}" ${@} + +# All database tests for database version 37 are run from this shell script. +# TESTS_DIR variable set by the calling test-runner script. + +TEST_37_1_RESULT=$(/opt/mssql-tools/bin/sqlcmd -U ${USER} -P "${PASS}" -S ${SERVER} -v DB_NAME=${DATABASE} -h -1 -i ${TESTS_DIR}/v_37_1_test.sql | xargs) +if [[ $TEST_37_1_RESULT -eq 1 ]]; then + echo "Test 37.1 passed: Special auth tables are create correctly" +else + echo "******** Test 37.1 failed: Special auth tables are not create correctly" +fi \ No newline at end of file