rls-create.sql 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. INSERT INTO version (table_name, table_version) values ('rls_presentity','1');
  2. CREATE TABLE rls_presentity (
  3. id NUMBER(10) PRIMARY KEY,
  4. rlsubs_did VARCHAR2(255),
  5. resource_uri VARCHAR2(128),
  6. content_type VARCHAR2(255),
  7. presence_state BLOB,
  8. expires NUMBER(10),
  9. updated NUMBER(10),
  10. auth_state NUMBER(10),
  11. reason VARCHAR2(64),
  12. CONSTRAINT ORA_rls_presentity_idx UNIQUE (rlsubs_did, resource_uri)
  13. );
  14. CREATE OR REPLACE TRIGGER rls_presentity_tr
  15. before insert on rls_presentity FOR EACH ROW
  16. BEGIN
  17. auto_id(:NEW.id);
  18. END rls_presentity_tr;
  19. /
  20. BEGIN map2users('rls_presentity'); END;
  21. /
  22. CREATE INDEX rls_presentity_rlsubs_idx ON rls_presentity (rlsubs_did);
  23. CREATE INDEX rls_presentity_updated_idx ON rls_presentity (updated);
  24. CREATE INDEX rls_presentity_expires_idx ON rls_presentity (expires);
  25. INSERT INTO version (table_name, table_version) values ('rls_watchers','3');
  26. CREATE TABLE rls_watchers (
  27. id NUMBER(10) PRIMARY KEY,
  28. presentity_uri VARCHAR2(128),
  29. to_user VARCHAR2(64),
  30. to_domain VARCHAR2(64),
  31. watcher_username VARCHAR2(64),
  32. watcher_domain VARCHAR2(64),
  33. event VARCHAR2(64) DEFAULT 'presence',
  34. event_id VARCHAR2(64),
  35. to_tag VARCHAR2(64),
  36. from_tag VARCHAR2(64),
  37. callid VARCHAR2(255),
  38. local_cseq NUMBER(10),
  39. remote_cseq NUMBER(10),
  40. contact VARCHAR2(128),
  41. record_route CLOB,
  42. expires NUMBER(10),
  43. status NUMBER(10) DEFAULT 2 NOT NULL,
  44. reason VARCHAR2(64),
  45. version NUMBER(10) DEFAULT 0 NOT NULL,
  46. socket_info VARCHAR2(64),
  47. local_contact VARCHAR2(128),
  48. from_user VARCHAR2(64),
  49. from_domain VARCHAR2(64),
  50. updated NUMBER(10),
  51. CONSTRAINT rls_watchers_rls_watcher_idx UNIQUE (callid, to_tag, from_tag)
  52. );
  53. CREATE OR REPLACE TRIGGER rls_watchers_tr
  54. before insert on rls_watchers FOR EACH ROW
  55. BEGIN
  56. auto_id(:NEW.id);
  57. END rls_watchers_tr;
  58. /
  59. BEGIN map2users('rls_watchers'); END;
  60. /
  61. CREATE INDEX ORA_rls_watchers_update ON rls_watchers (watcher_username, watcher_domain, event);
  62. CREATE INDEX ORA_rls_watchers_expires ON rls_watchers (expires);
  63. CREATE INDEX rls_watchers_updated_idx ON rls_watchers (updated);