-
Notifications
You must be signed in to change notification settings - Fork 22
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #33 from Ashi1993/event
Fixing issues in Event Notification Implementation
- Loading branch information
Showing
24 changed files
with
497 additions
and
154 deletions.
There are no files selected for viewing
66 changes: 66 additions & 0 deletions
66
...rator/accelerators/ob-is/carbon-home/dbscripts/open-banking/event-notifications/mssql.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,66 @@ | ||
/** | ||
* Copyright (c) 2023, WSO2 LLC. (https://www.wso2.com). | ||
* | ||
* WSO2 LLC. licenses this file to you under the Apache License, | ||
* Version 2.0 (the "License"); you may not use this file except | ||
* in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, | ||
* software distributed under the License is distributed on an | ||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | ||
* KIND, either express or implied. See the License for the | ||
* specific language governing permissions and limitations | ||
* under the License. | ||
*/ | ||
|
||
-- All the data related to time are stored in unix time stamp and therefore, the data types for the time related data | ||
-- are represented in BIGINT. | ||
-- Since the database systems does not support adding default unix time to the database columns, the default data | ||
-- storing is handled within the database querieS. | ||
|
||
CREATE TABLE OB_NOTIFICATION ( | ||
NOTIFICATION_ID varchar(36) NOT NULL, | ||
CLIENT_ID varchar(255) NOT NULL, | ||
RESOURCE_ID varchar(255) NOT NULL, | ||
STATUS varchar(10) NOT NULL, | ||
UPDATED_TIMESTAMP DATETIME2(0) DEFAULT GETDATE(), | ||
PRIMARY KEY (NOTIFICATION_ID) | ||
); | ||
|
||
CREATE TABLE OB_NOTIFICATION_EVENT ( | ||
EVENT_ID int NOT NULL IDENTITY, | ||
NOTIFICATION_ID varchar(36) NOT NULL, | ||
EVENT_TYPE varchar(200) NOT NULL, | ||
EVENT_INFO varchar(1000) NOT NULL, | ||
PRIMARY KEY (EVENT_ID), | ||
CONSTRAINT FK_NotificationEvent FOREIGN KEY (NOTIFICATION_ID) REFERENCES OB_NOTIFICATION(NOTIFICATION_ID) | ||
); | ||
|
||
CREATE TABLE OB_NOTIFICATION_ERROR ( | ||
NOTIFICATION_ID varchar(36) NOT NULL, | ||
ERROR_CODE varchar(255) NOT NULL, | ||
DESCRIPTION varchar(255) NOT NULL, | ||
PRIMARY KEY (NOTIFICATION_ID), | ||
CONSTRAINT FK_NotificationError FOREIGN KEY (NOTIFICATION_ID) REFERENCES OB_NOTIFICATION(NOTIFICATION_ID) | ||
); | ||
|
||
CREATE TABLE OB_NOTIFICATION_SUBSCRIPTION ( | ||
SUBSCRIPTION_ID varchar(36) NOT NULL, | ||
CLIENT_ID varchar(255) NOT NULL, | ||
REQUEST JSON NOT NULL, | ||
CALLBACK_URL varchar(255), | ||
TIMESTAMP BIGINT NOT NULL, | ||
SPEC_VERSION varchar(255), | ||
STATUS varchar(255) NOT NULL, | ||
PRIMARY KEY (SUBSCRIPTION_ID) | ||
); | ||
|
||
CREATE TABLE OB_NOTIFICATION_SUBSCRIBED_EVENTS ( | ||
SUBSCRIPTION_ID varchar(36) NOT NULL, | ||
EVENT_TYPE varchar(255) NOT NULL, | ||
PRIMARY KEY (SUBSCRIPTION_ID, EVENT_TYPE), | ||
CONSTRAINT FK_NotificationSubEvents FOREIGN KEY (SUBSCRIPTION_ID) REFERENCES OB_NOTIFICATION_SUBSCRIPTION(SUBSCRIPTION_ID) | ||
); |
73 changes: 73 additions & 0 deletions
73
...rator/accelerators/ob-is/carbon-home/dbscripts/open-banking/event-notifications/mysql.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,73 @@ | ||
/** | ||
* Copyright (c) 2023, WSO2 LLC. (https://www.wso2.com). | ||
* | ||
* WSO2 LLC. licenses this file to you under the Apache License, | ||
* Version 2.0 (the "License"); you may not use this file except | ||
* in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, | ||
* software distributed under the License is distributed on an | ||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | ||
* KIND, either express or implied. See the License for the | ||
* specific language governing permissions and limitations | ||
* under the License. | ||
*/ | ||
|
||
-- All the data related to time are stored in unix time stamp and therefore, the data types for the time related data | ||
-- are represented in BIGINT. | ||
-- Since the database systems does not support adding default unix time to the database columns, the default data | ||
-- storing is handled within the database querieS. | ||
|
||
-- For event notifications feature run the following queries against the openbank_openbankingdb-- | ||
|
||
CREATE TABLE IF NOT EXISTS OB_NOTIFICATION ( | ||
NOTIFICATION_ID varchar(36) NOT NULL, | ||
CLIENT_ID varchar(255) NOT NULL, | ||
RESOURCE_ID varchar(255) NOT NULL, | ||
STATUS varchar(10) NOT NULL, | ||
UPDATED_TIMESTAMP TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, | ||
PRIMARY KEY (NOTIFICATION_ID) | ||
) | ||
ENGINE=InnoDB; | ||
|
||
CREATE TABLE IF NOT EXISTS OB_NOTIFICATION_EVENT ( | ||
EVENT_ID int(11) NOT NULL AUTO_INCREMENT, | ||
NOTIFICATION_ID varchar(36) NOT NULL, | ||
EVENT_TYPE varchar(200) NOT NULL, | ||
EVENT_INFO varchar(1000) NOT NULL, | ||
PRIMARY KEY (EVENT_ID), | ||
CONSTRAINT FK_NotificationEvent FOREIGN KEY (NOTIFICATION_ID) REFERENCES OB_NOTIFICATION(NOTIFICATION_ID) | ||
) | ||
ENGINE=InnoDB; | ||
|
||
CREATE TABLE IF NOT EXISTS OB_NOTIFICATION_ERROR ( | ||
NOTIFICATION_ID varchar(36) NOT NULL, | ||
ERROR_CODE varchar(255) NOT NULL, | ||
DESCRIPTION varchar(255) NOT NULL, | ||
PRIMARY KEY (NOTIFICATION_ID), | ||
CONSTRAINT FK_NotificationError FOREIGN KEY (NOTIFICATION_ID) REFERENCES OB_NOTIFICATION(NOTIFICATION_ID) | ||
) | ||
ENGINE=InnoDB; | ||
|
||
CREATE TABLE IF NOT EXISTS OB_NOTIFICATION_SUBSCRIPTION ( | ||
SUBSCRIPTION_ID varchar(36) NOT NULL, | ||
CLIENT_ID varchar(255) NOT NULL, | ||
REQUEST JSON NOT NULL, | ||
CALLBACK_URL varchar(255), | ||
TIMESTAMP BIGINT NOT NULL, | ||
SPEC_VERSION varchar(255), | ||
STATUS varchar(255) NOT NULL, | ||
PRIMARY KEY (SUBSCRIPTION_ID) | ||
) | ||
ENGINE=InnoDB; | ||
|
||
CREATE TABLE IF NOT EXISTS OB_NOTIFICATION_SUBSCRIBED_EVENTS ( | ||
SUBSCRIPTION_ID varchar(36) NOT NULL, | ||
EVENT_TYPE varchar(255) NOT NULL, | ||
PRIMARY KEY (SUBSCRIPTION_ID, EVENT_TYPE), | ||
CONSTRAINT FK_NotificationSubEvents FOREIGN KEY (SUBSCRIPTION_ID) REFERENCES OB_NOTIFICATION_SUBSCRIPTION(SUBSCRIPTION_ID) | ||
) | ||
ENGINE=InnoDB; |
76 changes: 76 additions & 0 deletions
76
...ator/accelerators/ob-is/carbon-home/dbscripts/open-banking/event-notifications/oracle.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,76 @@ | ||
/** | ||
* Copyright (c) 2023, WSO2 LLC. (https://www.wso2.com). | ||
* | ||
* WSO2 LLC. licenses this file to you under the Apache License, | ||
* Version 2.0 (the "License"); you may not use this file except | ||
* in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, | ||
* software distributed under the License is distributed on an | ||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | ||
* KIND, either express or implied. See the License for the | ||
* specific language governing permissions and limitations | ||
* under the License. | ||
*/ | ||
|
||
-- All the data related to time are stored in unix time stamp and therefore, the data types for the time related data | ||
-- are represented in BIGINT. | ||
-- Since the database systems does not support adding default unix time to the database columns, the default data | ||
-- storing is handled within the database querieS. | ||
|
||
CREATE TABLE OB_NOTIFICATION ( | ||
NOTIFICATION_ID varchar2(36) NOT NULL, | ||
CLIENT_ID varchar2(255) NOT NULL, | ||
RESOURCE_ID varchar2(255) NOT NULL, | ||
STATUS varchar2(10) NOT NULL, | ||
UPDATED_TIMESTAMP TIMESTAMP(0) DEFAULT SYSTIMESTAMP, | ||
PRIMARY KEY (NOTIFICATION_ID) | ||
); | ||
|
||
CREATE TABLE OB_NOTIFICATION_EVENT ( | ||
EVENT_ID number(10) NOT NULL, | ||
NOTIFICATION_ID varchar2(36) NOT NULL, | ||
EVENT_TYPE varchar2(200) NOT NULL, | ||
EVENT_INFO varchar2(1000) NOT NULL, | ||
PRIMARY KEY (EVENT_ID), | ||
CONSTRAINT FK_NotificationEvent FOREIGN KEY (NOTIFICATION_ID) REFERENCES OB_NOTIFICATION(NOTIFICATION_ID) | ||
); | ||
|
||
-- Generate ID using sequence and trigger | ||
CREATE SEQUENCE OB_NOTIFICATION_EVENT_seq START WITH 1 INCREMENT BY 1; | ||
|
||
CREATE OR REPLACE TRIGGER OB_NOTIFICATION_EVENT_seq_tr | ||
BEFORE INSERT ON OB_NOTIFICATION_EVENT FOR EACH ROW | ||
WHEN (NEW.EVENT_ID IS NULL) | ||
BEGIN | ||
SELECT OB_NOTIFICATION_EVENT_seq.NEXTVAL INTO :NEW.EVENT_ID FROM DUAL; | ||
END; | ||
|
||
CREATE TABLE OB_NOTIFICATION_ERROR ( | ||
NOTIFICATION_ID varchar2(36) NOT NULL, | ||
ERROR_CODE varchar2(255) NOT NULL, | ||
DESCRIPTION varchar2(255) NOT NULL, | ||
PRIMARY KEY (NOTIFICATION_ID), | ||
CONSTRAINT FK_NotificationError FOREIGN KEY (NOTIFICATION_ID) REFERENCES OB_NOTIFICATION(NOTIFICATION_ID) | ||
) | ||
|
||
CREATE TABLE OB_NOTIFICATION_SUBSCRIPTION ( | ||
SUBSCRIPTION_ID varchar(36) NOT NULL, | ||
CLIENT_ID varchar(255) NOT NULL, | ||
REQUEST JSON NOT NULL, | ||
CALLBACK_URL varchar(255), | ||
TIMESTAMP BIGINT NOT NULL, | ||
SPEC_VERSION varchar(255), | ||
STATUS varchar(255) NOT NULL, | ||
PRIMARY KEY (SUBSCRIPTION_ID) | ||
); | ||
|
||
CREATE TABLE OB_NOTIFICATION_SUBSCRIBED_EVENTS ( | ||
SUBSCRIPTION_ID varchar(36) NOT NULL, | ||
EVENT_TYPE varchar(255) NOT NULL, | ||
PRIMARY KEY (SUBSCRIPTION_ID, EVENT_TYPE), | ||
CONSTRAINT FK_NotificationSubEvents FOREIGN KEY (SUBSCRIPTION_ID) REFERENCES OB_NOTIFICATION_SUBSCRIPTION(SUBSCRIPTION_ID) | ||
); |
67 changes: 67 additions & 0 deletions
67
.../accelerators/ob-is/carbon-home/dbscripts/open-banking/event-notifications/postgresql.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
/** | ||
* Copyright (c) 2023, WSO2 LLC. (https://www.wso2.com). | ||
* | ||
* WSO2 LLC. licenses this file to you under the Apache License, | ||
* Version 2.0 (the "License"); you may not use this file except | ||
* in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, | ||
* software distributed under the License is distributed on an | ||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | ||
* KIND, either express or implied. See the License for the | ||
* specific language governing permissions and limitations | ||
* under the License. | ||
*/ | ||
|
||
-- All the data related to time are stored in unix time stamp and therefore, the data types for the time related data | ||
-- are represented in BIGINT. | ||
-- Since the database systems does not support adding default unix time to the database columns, the default data | ||
-- storing is handled within the database querieS. | ||
|
||
-- For event notifications feature run the following queries against the openbank_openbankingdb-- | ||
|
||
CREATE TABLE IF NOT EXISTS OB_NOTIFICATION ( | ||
NOTIFICATION_ID varchar(36) NOT NULL, | ||
CLIENT_ID varchar(255) NOT NULL, | ||
RESOURCE_ID varchar(255) NOT NULL, | ||
STATUS varchar(10) NOT NULL, | ||
UPDATED_TIMESTAMP TIMESTAMP(0) DEFAULT CURRENT_TIMESTAMP, | ||
PRIMARY KEY (NOTIFICATION_ID) | ||
); | ||
|
||
CREATE TABLE IF NOT EXISTS OB_NOTIFICATION_EVENT ( | ||
EVENT_ID SERIAL PRIMARY KEY, | ||
NOTIFICATION_ID varchar(36) NOT NULL, | ||
EVENT_TYPE varchar(200) NOT NULL, | ||
EVENT_INFO varchar(1000) NOT NULL, | ||
CONSTRAINT FK_NotificationEvent FOREIGN KEY (NOTIFICATION_ID) REFERENCES OB_NOTIFICATION(NOTIFICATION_ID) | ||
); | ||
|
||
CREATE TABLE IF NOT EXISTS OB_NOTIFICATION_ERROR ( | ||
NOTIFICATION_ID varchar(36) NOT NULL, | ||
ERROR_CODE varchar(255) NOT NULL, | ||
DESCRIPTION varchar(255) NOT NULL, | ||
PRIMARY KEY (NOTIFICATION_ID), | ||
CONSTRAINT FK_NotificationError FOREIGN KEY (NOTIFICATION_ID) REFERENCES OB_NOTIFICATION(NOTIFICATION_ID) | ||
); | ||
|
||
CREATE TABLE IF NOT EXISTS OB_NOTIFICATION_SUBSCRIPTION ( | ||
SUBSCRIPTION_ID varchar(36) NOT NULL, | ||
CLIENT_ID varchar(255) NOT NULL, | ||
REQUEST JSON NOT NULL, | ||
CALLBACK_URL varchar(255), | ||
TIMESTAMP BIGINT NOT NULL, | ||
SPEC_VERSION varchar(255), | ||
STATUS varchar(255) NOT NULL, | ||
PRIMARY KEY (SUBSCRIPTION_ID) | ||
); | ||
|
||
CREATE TABLE IF NOT EXISTS OB_NOTIFICATION_SUBSCRIBED_EVENTS ( | ||
SUBSCRIPTION_ID varchar(36) NOT NULL, | ||
EVENT_TYPE varchar(255) NOT NULL, | ||
PRIMARY KEY (SUBSCRIPTION_ID, EVENT_TYPE), | ||
CONSTRAINT FK_NotificationSubEvents FOREIGN KEY (SUBSCRIPTION_ID) REFERENCES OB_NOTIFICATION_SUBSCRIPTION(SUBSCRIPTION_ID) | ||
); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.