2004-03-16 10:15:14 -05:00
-- mappings
-- objectClass mappings: these may be viewed as structuralObjectClass, the ones that are used to decide how to build an entry
-- id a unique number identifying the objectClass
-- name the name of the objectClass; it MUST match the name of an objectClass that is loaded in slapd's schema
-- keytbl the name of the table that is referenced for the primary key of an entry
-- keycol the name of the column in "keytbl" that contains the primary key of an entry; the pair "keytbl.keycol" uniquely identifies an entry of objectClass "id"
-- create_proc a procedure to create the entry
-- delete_proc a procedure to delete the entry; it takes "keytbl.keycol" of the row to be deleted
-- expect_return a bitmap that marks whether create_proc (1) and delete_proc (2) return a value or not
2000-08-15 13:05:53 -04:00
insert into ldap_oc_mappings ( id , name , keytbl , keycol , create_proc , delete_proc , expect_return )
2004-09-11 07:05:01 -04:00
values ( 1 , ' inetOrgPerson ' , ' persons ' , ' id ' , ' call create_person(?) ' , ' call delete_person(?) ' , 0 ) ;
2000-08-15 13:05:53 -04:00
insert into ldap_oc_mappings ( id , name , keytbl , keycol , create_proc , delete_proc , expect_return )
2004-03-16 10:15:14 -05:00
values ( 2 , ' document ' , ' documents ' , ' id ' , ' call create_document(?) ' , ' call delete_document(?) ' , 0 ) ;
2000-08-15 13:05:53 -04:00
insert into ldap_oc_mappings ( id , name , keytbl , keycol , create_proc , delete_proc , expect_return )
2004-03-16 10:15:14 -05:00
values ( 3 , ' organization ' , ' institutes ' , ' id ' , ' call create_org(?) ' , ' call delete_org(?) ' , 0 ) ;
-- attributeType mappings: describe how an attributeType for a certain objectClass maps to the SQL data.
-- id a unique number identifying the attribute
-- oc_map_id the value of "ldap_oc_mappings.id" that identifies the objectClass this attributeType is defined for
-- name the name of the attributeType; it MUST match the name of an attributeType that is loaded in slapd's schema
-- sel_expr the expression that is used to select this attribute (the "select <sel_expr> from ..." portion)
-- from_tbls the expression that defines the table(s) this attribute is taken from (the "select ... from <from_tbls> where ..." portion)
-- join_where the expression that defines the condition to select this attribute (the "select ... where <join_where> ..." portion)
-- add_proc a procedure to insert the attribute; it takes the value of the attribute that is added, and the "keytbl.keycol" of the entry it is associated to
-- delete_proc a procedure to delete the attribute; it takes the value of the attribute that is added, and the "keytbl.keycol" of the entry it is associated to
-- param_order a mask that marks if the "keytbl.keycol" value comes before or after the value in add_proc (1) and delete_proc (2)
-- expect_return a mask that marks whether add_proc (1) and delete_proc(2) are expected to return a value or not
2000-08-15 13:05:53 -04:00
insert into ldap_attr_mappings ( id , oc_map_id , name , sel_expr , from_tbls , join_where , add_proc , delete_proc , param_order , expect_return )
2004-09-11 07:05:01 -04:00
values ( 1 , 1 , ' cn ' , ' persons.name|| '' '' ||persons.surname ' , ' persons ' , NULL ,
NULL , NULL , 0 , 0 ) ;
2000-08-15 13:05:53 -04:00
insert into ldap_attr_mappings ( id , oc_map_id , name , sel_expr , from_tbls , join_where , add_proc , delete_proc , param_order , expect_return )
values ( 2 , 1 , ' telephoneNumber ' , ' phones.phone ' , ' persons,phones ' ,
2004-03-16 10:15:14 -05:00
' phones.pers_id=persons.id ' , ' call add_phone(?,?) ' ,
' call delete_phone(?,?) ' , 0 , 0 ) ;
2000-08-15 13:05:53 -04:00
insert into ldap_attr_mappings ( id , oc_map_id , name , sel_expr , from_tbls , join_where , add_proc , delete_proc , param_order , expect_return )
2004-09-11 07:05:01 -04:00
values ( 3 , 1 , ' givenName ' , ' persons.name ' , ' persons ' , NULL , ' call set_person_name(?,?) ' ,
2000-08-15 13:05:53 -04:00
NULL , 0 , 0 ) ;
insert into ldap_attr_mappings ( id , oc_map_id , name , sel_expr , from_tbls , join_where , add_proc , delete_proc , param_order , expect_return )
2004-09-11 07:05:01 -04:00
values ( 4 , 1 , ' sn ' , ' persons.surname ' , ' persons ' , NULL , ' call set_person_surname(?,?) ' ,
2000-08-15 13:05:53 -04:00
NULL , 0 , 0 ) ;
insert into ldap_attr_mappings ( id , oc_map_id , name , sel_expr , from_tbls , join_where , add_proc , delete_proc , param_order , expect_return )
2004-09-11 07:05:01 -04:00
values ( 5 , 1 , ' userPassword ' , ' persons.password ' , ' persons ' ,
' persons.password IS NOT NULL ' , ' call set_person_password(?,?) ' ,
2000-08-15 13:05:53 -04:00
NULL , 0 , 0 ) ;
2004-09-11 07:05:01 -04:00
insert into ldap_attr_mappings ( id , oc_map_id , name , sel_expr , from_tbls , join_where , add_proc , delete_proc , param_order , expect_return )
values ( 6 , 1 , ' seeAlso ' , ' seeAlso.dn ' , ' ldap_entries seeAlso,documents,authors_docs,persons ' ,
' seeAlso.keyval=documents.id AND seeAlso.oc_map_id=2 AND authors_docs.doc_id=documents.id AND authors_docs.pers_id=persons.id ' ,
NULL , NULL , 0 , 0 ) ;
2000-08-15 13:05:53 -04:00
insert into ldap_attr_mappings ( id , oc_map_id , name , sel_expr , from_tbls , join_where , add_proc , delete_proc , param_order , expect_return )
2004-09-11 07:05:01 -04:00
values ( 7 , 2 , ' description ' , ' documents.abstract ' , ' documents ' , NULL , ' call set_doc_abstract(?,?) ' ,
NULL , 0 , 0 ) ;
2000-08-15 13:05:53 -04:00
insert into ldap_attr_mappings ( id , oc_map_id , name , sel_expr , from_tbls , join_where , add_proc , delete_proc , param_order , expect_return )
2004-09-11 07:05:01 -04:00
values ( 8 , 2 , ' documentTitle ' , ' documents.title ' , ' documents ' , NULL , ' call set_doc_title(?,?) ' , NULL , 0 , 0 ) ;
2000-08-15 13:05:53 -04:00
insert into ldap_attr_mappings ( id , oc_map_id , name , sel_expr , from_tbls , join_where , add_proc , delete_proc , param_order , expect_return )
2004-09-11 07:05:01 -04:00
values ( 9 , 2 , ' documentAuthor ' , ' documentAuthor.dn ' , ' ldap_entries documentAuthor,documents,authors_docs,persons ' ,
' documentAuthor.keyval=persons.id AND documentAuthor.oc_map_id=1 AND authors_docs.doc_id=documents.id AND authors_docs.pers_id=persons.id ' ,
2004-03-16 10:15:14 -05:00
' ?=call make_author_link(?,?) ' , ' ?=call del_author_link(?,?) ' , 0 , 3 ) ;
2000-08-15 13:05:53 -04:00
2004-09-11 07:05:01 -04:00
insert into ldap_attr_mappings ( id , oc_map_id , name , sel_expr , from_tbls , join_where , add_proc , delete_proc , param_order , expect_return )
values ( 10 , 2 , ' documentIdentifier ' , ' '' document '' ||text(documents.id) ' , ' documents ' , NULL , NULL , NULL , 0 , 0 ) ;
insert into ldap_attr_mappings ( id , oc_map_id , name , sel_expr , from_tbls , join_where , add_proc , delete_proc , param_order , expect_return )
values ( 11 , 3 , ' o ' , ' institutes.name ' , ' institutes ' , NULL , ' call set_org_name(?,?) ' , NULL , 0 , 0 ) ;
insert into ldap_attr_mappings ( id , oc_map_id , name , sel_expr , from_tbls , join_where , add_proc , delete_proc , param_order , expect_return )
values ( 12 , 3 , ' dc ' , ' lower(institutes.name) ' , ' institutes,ldap_entries dcObject,ldap_entry_objclasses auxObjectClass ' ,
' institutes.id=dcObject.keyval AND dcObject.oc_map_id=3 AND dcObject.id=auxObjectClass.entry_id AND auxObjectClass.oc_name= '' dcObject '' ' ,
NULL , NULL , 0 , 0 ) ;
2000-08-15 13:05:53 -04:00
2004-03-16 10:15:14 -05:00
-- entries mapping: each entry must appear in this table, with a unique DN rooted at the database naming context
-- id a unique number > 0 identifying the entry
-- dn the DN of the entry, in "pretty" form
-- oc_map_id the "ldap_oc_mappings.id" of the main objectClass of this entry (view it as the structuralObjectClass)
-- parent the "ldap_entries.id" of the parent of this objectClass; 0 if it is the "suffix" of the database
-- keyval the value of the "keytbl.keycol" defined for this objectClass
2000-08-15 13:05:53 -04:00
insert into ldap_entries ( id , dn , oc_map_id , parent , keyval )
2004-09-11 07:05:01 -04:00
values ( ldap_entry_ids . nextval , ' dc=example,dc=com ' , 3 , 0 , 1 ) ;
2000-08-15 13:05:53 -04:00
insert into ldap_entries ( id , dn , oc_map_id , parent , keyval )
2004-09-11 07:05:01 -04:00
values ( ldap_entry_ids . nextval , ' cn=Mitya Kovalev,dc=example,dc=com ' , 1 , 1 , 1 ) ;
2000-08-15 13:05:53 -04:00
insert into ldap_entries ( id , dn , oc_map_id , parent , keyval )
2004-09-11 07:05:01 -04:00
values ( ldap_entry_ids . nextval , ' cn=Torvlobnor Puzdoy,dc=example,dc=com ' , 1 , 1 , 2 ) ;
2000-08-15 13:05:53 -04:00
insert into ldap_entries ( id , dn , oc_map_id , parent , keyval )
2004-09-11 07:05:01 -04:00
values ( ldap_entry_ids . nextval , ' cn=Akakiy Zinberstein,dc=example,dc=com ' , 1 , 1 , 3 ) ;
2000-08-15 13:05:53 -04:00
insert into ldap_entries ( id , dn , oc_map_id , parent , keyval )
2004-09-11 07:05:01 -04:00
values ( ldap_entry_ids . nextval , ' documentTitle=book1,dc=example,dc=com ' , 2 , 1 , 1 ) ;
2000-08-15 13:05:53 -04:00
insert into ldap_entries ( id , dn , oc_map_id , parent , keyval )
2004-09-11 07:05:01 -04:00
values ( ldap_entry_ids . nextval , ' documentTitle=book2,dc=example,dc=com ' , 2 , 1 , 2 ) ;
2000-08-15 13:05:53 -04:00
2004-03-16 10:15:14 -05:00
-- objectClass mapping: entries that have multiple objectClass instances are listed here with the objectClass name (view them as auxiliary objectClass)
-- entry_id the "ldap_entries.id" of the entry this objectClass value must be added
-- oc_name the name of the objectClass; it MUST match the name of an objectClass that is loaded in slapd's schema
2004-09-11 07:05:01 -04:00
insert into ldap_entry_objclasses ( entry_id , oc_name )
values ( 1 , ' dcObject ' ) ;
2000-08-15 13:05:53 -04:00
insert into ldap_entry_objclasses ( entry_id , oc_name )
values ( 4 , ' referral ' ) ;
2004-03-16 10:15:14 -05:00
-- referrals mapping: entries that should be treated as referrals are stored here
-- entry_id the "ldap_entries.id" of the entry that should be treated as a referral
-- url the URI of the referral
2000-08-15 13:05:53 -04:00
insert into ldap_referrals ( entry_id , url )
2005-07-20 07:17:06 -04:00
values ( 4 , ' ldap://localhost:9012/ ' ) ;
2000-08-15 13:05:53 -04:00
-- procedures
2004-03-16 10:15:14 -05:00
-- these procedures are specific for this RDBMS and are used in mapping objectClass and attributeType creation/modify/deletion
2000-08-15 13:05:53 -04:00
CREATE OR REPLACE PROCEDURE create_person ( keyval OUT NUMBER ) AS
BEGIN
INSERT INTO persons ( id , name ) VALUES ( person_ids . nextval , ' ' ) ;
SELECT person_ids . currval INTO keyval FROM DUAL ;
END ;
/
CREATE OR REPLACE PROCEDURE delete_person ( keyval IN NUMBER ) AS
BEGIN
DELETE FROM phones WHERE pers_id = keyval ;
DELETE FROM authors_docs WHERE pers_id = keyval ;
DELETE FROM persons WHERE id = keyval ;
END ;
/
CREATE OR REPLACE PROCEDURE create_org ( keyval OUT NUMBER ) AS
BEGIN
INSERT INTO institutes ( id , name ) VALUES ( institute_ids . nextval , ' ' ) ;
SELECT institute_ids . currval INTO keyval FROM DUAL ;
END ;
/
CREATE OR REPLACE PROCEDURE delete_org ( keyval IN NUMBER ) AS
BEGIN
DELETE FROM institutes WHERE id = keyval ;
END ;
/
CREATE OR REPLACE PROCEDURE create_document ( keyval OUT NUMBER ) AS
BEGIN
INSERT INTO documents ( id , title ) VALUES ( document_ids . nextval , ' ' ) ;
SELECT document_ids . currval INTO keyval FROM DUAL ;
END ;
/
CREATE OR REPLACE PROCEDURE delete_document ( keyval IN NUMBER ) AS
BEGIN
DELETE FROM authors_docs WHERE doc_id = keyval ;
DELETE FROM documents WHERE id = keyval ;
END ;
/
CREATE OR REPLACE PROCEDURE add_phone ( pers_id IN NUMBER , phone IN varchar2 ) AS
BEGIN
INSERT INTO phones ( id , pers_id , phone ) VALUES ( phone_ids . nextval , pers_id , phone ) ;
END ;
/
CREATE OR REPLACE PROCEDURE delete_phone ( keyval IN NUMBER , phone IN varchar2 ) AS
BEGIN
DELETE FROM phones WHERE pers_id = keyval AND phone = phone ;
END ;
/
CREATE OR REPLACE PROCEDURE set_person_name ( keyval IN NUMBER , new_name IN varchar2 ) AS
BEGIN
UPDATE persons SET name = new_name WHERE id = keyval ;
END ;
/
CREATE OR REPLACE PROCEDURE set_org_name ( keyval IN NUMBER , new_name IN varchar2 ) AS
BEGIN
UPDATE institutes SET name = new_name WHERE id = keyval ;
END ;
/
CREATE OR REPLACE PROCEDURE set_doc_title ( keyval IN NUMBER , new_title IN varchar2 ) AS
BEGIN
UPDATE documents SET title = new_title WHERE id = keyval ;
END ;
/
CREATE OR REPLACE PROCEDURE set_doc_abstract ( keyval IN NUMBER , new_abstract IN varchar2 ) AS
BEGIN
UPDATE documents SET abstract = new_abstract WHERE id = keyval ;
END ;
/
CREATE OR REPLACE FUNCTION make_author_link ( keyval IN NUMBER , author_dn IN varchar2 ) RETURN NUMBER AS
per_id NUMBER ;
BEGIN
SELECT keyval INTO per_id FROM ldap_entries
WHERE oc_map_id = 1 AND dn = author_dn ;
IF NOT ( per_id IS NULL ) THEN
INSERT INTO authors_docs ( doc_id , pers_id ) VALUES ( keyval , per_id ) ;
RETURN 1 ;
END IF ;
RETURN 0 ;
END ;
/
CREATE OR REPLACE FUNCTION make_doc_link ( keyval IN NUMBER , doc_dn IN varchar2 ) RETURN NUMBER AS
docid NUMBER ;
BEGIN
SELECT keyval INTO docid FROM ldap_entries
WHERE oc_map_id = 2 AND dn = doc_dn ;
IF NOT ( docid IS NULL ) THEN
INSERT INTO authors_docs ( pers_id , doc_id ) VALUES ( keyval , docid ) ;
RETURN 1 ;
END IF ;
RETURN 0 ;
END ;
/
CREATE OR REPLACE FUNCTION del_doc_link ( keyval IN NUMBER , doc_dn IN varchar2 ) RETURN NUMBER AS
docid NUMBER ;
BEGIN
SELECT keyval INTO docid FROM ldap_entries
WHERE oc_map_id = 2 AND dn = doc_dn ;
IF NOT ( docid IS NULL ) THEN
DELETE FROM authors_docs WHERE pers_id = keyval AND doc_id = docid ;
RETURN 1 ;
END IF ;
RETURN 0 ;
END ;
/
CREATE OR REPLACE FUNCTION del_author_link ( keyval IN NUMBER , author_dn IN varchar2 ) RETURN NUMBER AS
per_id NUMBER ;
BEGIN
SELECT keyval INTO per_id FROM ldap_entries
WHERE oc_map_id = 1 AND dn = author_dn ;
IF NOT ( per_id IS NULL ) THEN
DELETE FROM authors_docs WHERE doc_id = keyval AND pers_id = per_id ;
RETURN 1 ;
END IF ;
RETURN 0 ;
END ;
/