-- -- The Notifications -- -- @author Ben Adida (ben@openforce.net) -- @version $Id: notifications-core-create.sql,v 1.17.2.1 2020/04/12 08:57:27 gustafn Exp $ -- -- Copyright (C) 2000 MIT -- -- GNU GPL v2 -- -- intervals should really be service contracts so other intervals can be -- taken into account. For now we're going to make them just intervals create table notification_intervals ( interval_id constraint notif_interv_id_fk references acs_objects (object_id) constraint notif_interv_id_pk primary key, name varchar(200) constraint notif_interv_name_nn not null constraint notif_interv_name_un unique, -- how to schedule this n_seconds integer constraint notif_interv_n_seconds_nn not null ); -- delivery methods should be service contracts, too. create table notification_delivery_methods ( delivery_method_id constraint notif_deliv_meth_fk references acs_objects (object_id) constraint notif_deliv_meth_pk primary key, sc_impl_id integer not null constraint notif_deliv_meth_impl_id_fk references acs_sc_impls(impl_id), short_name varchar(100) constraint notif_deliv_short_name_nn not null constraint notif_deliv_short_name_un unique, pretty_name varchar(200) not null ); create table notification_types ( type_id constraint notif_type_type_id_fk references acs_objects (object_id) constraint notif_type_type_id_pk primary key, sc_impl_id integer not null constraint notif_type_impl_id_fk references acs_sc_impls(impl_id), short_name varchar(100) constraint notif_type_short_name_nn not null constraint notif_type_short_name_un unique, pretty_name varchar(200) constraint notif_type_pretty_name_nn not null, description varchar(2000) ); -- what's allowed for a given notification type? create table notification_types_intervals ( type_id constraint notif_type_int_type_id_fk references notification_types (type_id) on delete cascade, interval_id constraint notif_type_int_int_id_fk references notification_intervals (interval_id) on delete cascade, constraint notif_type_int_pk primary key (type_id, interval_id) ); -- allowed delivery methods create table notification_types_del_methods ( type_id constraint notif_type_del_type_id_fk references notification_types (type_id) on delete cascade, delivery_method_id constraint notif_type_del_meth_id_fk references notification_delivery_methods (delivery_method_id) on delete cascade, constraint notif_type_deliv_pk primary key (type_id, delivery_method_id) ); -- Requests for Notifications create table notification_requests ( request_id constraint notif_request_id_fk references acs_objects (object_id) on delete cascade constraint notif_request_id_pk primary key, type_id constraint notif_request_type_id_fk references notification_types (type_id) on delete cascade, user_id constraint notif_request_user_id_fk references users (user_id) on delete cascade, -- The object this request pertains to object_id constraint notif_request_object_id_fk references acs_objects (object_id) on delete cascade, -- the interval must be allowed for this type interval_id integer constraint notif_request_interv_id_nn not null, -- the delivery method must be allowed for this type delivery_method_id integer constraint notif_request_delivery_meth_nn not null, -- the format of the notification should be... format varchar(100) default 'text' constraint notif_request_format_ch check (format in ('text', 'html')), dynamic_p char(1) default 'f' constraint notif_request_dynamic_ch check (dynamic_p in ('t', 'f')), constraint notif_request_interv_fk foreign key (type_id, interval_id) references notification_types_intervals (type_id, interval_id), constraint notif_request_deliv_fk foreign key (type_id, delivery_method_id) references notification_types_del_methods (type_id, delivery_method_id), constraint notification_requests_un unique (type_id, user_id, object_id) ); create index notification_requests_t_o_idx on notification_requests(type_id, object_id); create index notification_requests_u_id_idx on notification_requests(user_id); create index notification_requests_o_id_idx on notification_requests(object_id); -- preferences -- -- for preferences that apply to each request, we're using the -- notification_requests table. For preferences that are notification-wide, -- we use user-preferences -- the actual stuff that has to go out create table notifications ( notification_id constraint notif_notif_id_fk references acs_objects (object_id) on delete cascade constraint notif_notif_id_pk primary key, type_id constraint notif_type_id_fk references notification_types(type_id), -- the object this notification pertains to object_id constraint notif_object_id_fk references acs_objects(object_id) on delete cascade, notif_date date constraint notif_notif_date_nn not null, -- this is to allow responses to notifications response_id constraint notif_response_id_fk references acs_objects (object_id) on delete cascade, notif_user integer constraint notif_user_id_fk references users(user_id), notif_subject varchar(1000), notif_text clob, notif_html clob, file_ids varchar(4000) ); -- RI indexes create index notifications_type_id_idx ON notifications(type_id); create index notifications_response_id_idx ON notifications(response_id); create index notifications_object_id_idx ON notifications(object_id); -- who has received this notification? create table notification_user_map ( notification_id constraint notif_user_map_notif_id_fk references notifications (notification_id) on delete cascade, user_id constraint notif_user_map_user_id_fk references users(user_id) on delete cascade, constraint notif_user_map_pk primary key (notification_id, user_id), sent_date date ); -- RI Indexes create index notification_user_map_user_idx ON notification_user_map(user_id); -- -- Object Types -- declare begin acs_object_type.create_type( supertype => 'acs_object', object_type => 'notification_interval', pretty_name => 'Notification Interval', pretty_plural => 'Notification Intervals', table_name => 'notification_intervals', id_column => 'interval_id', package_name => 'notification_interval' ); acs_object_type.create_type( supertype => 'acs_object', object_type => 'notification_delivery_method', pretty_name => 'Notification Delivery Method', pretty_plural => 'Notification Delivery Methods', table_name => 'notification_delivery_methods', id_column => 'delivery_method_id', package_name => 'notification_delivery_method' ); acs_object_type.create_type( supertype => 'acs_object', object_type => 'notification_type', pretty_name => 'Notification Type', pretty_plural => 'Notification Types', table_name => 'notification_types', id_column => 'type_id', package_name => 'notification_type' ); acs_object_type.create_type( supertype => 'acs_object', object_type => 'notification_request', pretty_name => 'Notification Request', pretty_plural => 'Notification Requests', table_name => 'notification_requests', id_column => 'request_id', package_name => 'notification_request' ); acs_object_type.create_type( supertype => 'acs_object', object_type => 'notification', pretty_name => 'Notification', pretty_plural => 'Notifications', table_name => 'notifications', id_column => 'notification_id', package_name => 'notification' ); end; / show errors