-- -- packages/acs-subsite/sql/user-profiles-create.sql -- -- @author oumi@arsdigita.com -- @creation-date 2000-02-02 -- @cvs-id $Id: user-profiles-create.sql,v 1.8.2.1 2021/01/05 08:51:46 gustafn Exp $ -- ------------------------------- -- APPLICATION USER PROFILES -- ------------------------------- -- begin -- -- the 'user' role should already exist from the portraits stuff. -- -- acs_rel_type.create_role('user', -- -- 'Registered User', 'Registered Users'); -- acs_rel_type.create_role('application', -- 'Application Group', 'Application Group'); -- acs_rel_type.create_type( -- rel_type => 'user_profile', -- pretty_name => 'User Profile', -- pretty_plural => 'User Profiles', -- supertype => 'membership_rel', -- table_name => 'user_profiles', -- id_column => 'profile_id', -- package_name => 'user_profile', -- abstract_p => 'f', -- object_type_one => 'application_group', -- role_one => 'application', -- min_n_rels_one => 0, -- max_n_rels_one => null, -- object_type_two => 'user', -- role_two => 'user', -- min_n_rels_two => 0, -- max_n_rels_two => null -- ); -- end; -- / -- show errors CREATE OR REPLACE FUNCTION inline_0 () RETURNS integer AS $$ BEGIN -- the 'user' role should already exist from the portraits stuff. -- acs_rel_type.create_role('user', -- 'Registered User', 'Registered Users'); PERFORM acs_rel_type__create_role('application', 'Application Group', 'Application Group'); PERFORM acs_rel_type__create_type ( 'user_profile', 'User Profile', 'User Profiles', 'membership_rel', 'user_profiles', 'profile_id', 'user_profile', 'application_group', 'application', 0, null::integer, 'user', 'user', 0, null::integer, 'f' ); return 0; END; $$ LANGUAGE plpgsql; select inline_0 (); drop function inline_0 (); create table user_profiles ( profile_id integer constraint user_profiles_profile_id_fk references membership_rels (rel_id) constraint user_profiles_profile_id_pk primary key ); -- create or replace package user_profile -- as -- function new ( -- profile_id in user_profiles.profile_id%TYPE default null, -- rel_type in acs_rels.rel_type%TYPE default 'user_profile', -- object_id_one in acs_rels.object_id_one%TYPE, -- object_id_two in acs_rels.object_id_two%TYPE, -- member_state in membership_rels.member_state%TYPE default null, -- creation_user in acs_objects.creation_user%TYPE default null, -- creation_ip in acs_objects.creation_ip%TYPE default null -- ) return user_profiles.profile_id%TYPE; -- procedure delete ( -- profile_id in user_profiles.profile_id%TYPE -- ); -- end user_profile; -- / -- show errors -- create or replace package body user_profile -- as -- function new ( -- profile_id in user_profiles.profile_id%TYPE default null, -- rel_type in acs_rels.rel_type%TYPE default 'user_profile', -- object_id_one in acs_rels.object_id_one%TYPE, -- object_id_two in acs_rels.object_id_two%TYPE, -- member_state in membership_rels.member_state%TYPE default null, -- creation_user in acs_objects.creation_user%TYPE default null, -- creation_ip in acs_objects.creation_ip%TYPE default null -- ) return user_profiles.profile_id%TYPE -- is -- v_profile_id integer; -- begin -- v_profile_id := membership_rel.new ( -- rel_id => profile_id, -- rel_type => rel_type, -- object_id_one => object_id_one, -- object_id_two => object_id_two, -- member_state => member_state, -- creation_user => creation_user, -- creation_ip => creation_ip -- ); -- insert into user_profiles (profile_id) values (v_profile_id); -- return v_profile_id; -- end new; -- old define_function_args('user_profile__new','profile_id,rel_type;user_profile,object_id_one,object_id_two,member_state,creation_user,creation_ip') -- new select define_function_args('user_profile__new','profile_id;null,rel_type;user_profile,object_id_one,object_id_two,member_state;null,creation_user;null,creation_ip;null'); -- -- procedure user_profile__new/7 -- CREATE OR REPLACE FUNCTION user_profile__new( new__profile_id integer, -- default null, new__rel_type varchar, -- default 'user_profile', new__object_id_one integer, new__object_id_two integer, new__member_state varchar, -- default null, new__creation_user integer, -- default null, new__creation_ip varchar -- default null ) RETURNS integer AS $$ DECLARE v_profile_id integer; BEGIN v_profile_id := membership_rel__new ( new__profile_id, new__rel_type, new__object_id_one, new__object_id_two, new__member_state, new__creation_user, new__creation_ip ); insert into user_profiles (profile_id) values (v_profile_id); return v_profile_id; END; $$ LANGUAGE plpgsql; -- procedure delete ( -- profile_id in user_profiles.profile_id%TYPE -- ) -- is -- begin -- membership_rel.delete(profile_id); -- end delete; -- added select define_function_args('user_profile__delete','profile_id'); -- -- procedure user_profile__delete/1 -- CREATE OR REPLACE FUNCTION user_profile__delete( profile_id integer ) RETURNS integer AS $$ DECLARE BEGIN PERFORM membership_rel__delete(profile_id); return 0; END; $$ LANGUAGE plpgsql; -- end user_profile; -- / -- show errors insert into group_type_rels (group_rel_type_id, group_type, rel_type) values (nextval('t_acs_object_id_seq', 'application_group', 'user_profile'); -- This view is extremely fast, but for some reason its not so blaxing fast -- when used in the registered_users_of_package_id view below. create view application_users as select ag.package_id, gem.element_id as user_id from user_profiles up, group_element_map gem, application_groups ag where ag.group_id = gem.group_id and gem.rel_id = up.profile_id; -- create the generalized versions of the registered_users and cc_users views: create view registered_users_of_package_id as select u.*, au.package_id from application_users au, registered_users u where au.user_id = u.user_id; create view cc_users_of_package_id as select u.*, au.package_id from application_users au, cc_users u where au.user_id = u.user_id;