pg_create.sql 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336
  1. CREATE TABLE version (
  2. table_name VARCHAR(32) NOT NULL,
  3. table_version INTEGER NOT NULL DEFAULT '0'
  4. );
  5. INSERT INTO version (table_name, table_version) VALUES ('acc', '3');
  6. INSERT INTO version (table_name, table_version) VALUES ('missed_calls', '3');
  7. INSERT INTO version (table_name, table_version) VALUES ('location', '8');
  8. INSERT INTO version (table_name, table_version) VALUES ('credentials', '6');
  9. INSERT INTO version (table_name, table_version) VALUES ('domain', '2');
  10. INSERT INTO version (table_name, table_version) VALUES ('attr_types', '1');
  11. INSERT INTO version (table_name, table_version) VALUES ('global_attrs', '1');
  12. INSERT INTO version (table_name, table_version) VALUES ('domain_attrs', '1');
  13. INSERT INTO version (table_name, table_version) VALUES ('user_attrs', '3');
  14. INSERT INTO version (table_name, table_version) VALUES ('phonebook', '1');
  15. INSERT INTO version (table_name, table_version) VALUES ('silo', '3');
  16. INSERT INTO version (table_name, table_version) VALUES ('uri', '2');
  17. INSERT INTO version (table_name, table_version) VALUES ('server_monitoring', '1');
  18. INSERT INTO version (table_name, table_version) VALUES ('trusted', '1');
  19. INSERT INTO version (table_name, table_version) VALUES ('server_monitoring_agg', '1');
  20. INSERT INTO version (table_name, table_version) VALUES ('speed_dial', '2');
  21. INSERT INTO version (table_name, table_version) VALUES ('sd_attrs', '1');
  22. INSERT INTO version (table_name, table_version) VALUES ('gw', '2');
  23. INSERT INTO version (table_name, table_version) VALUES ('gw_grp', '2');
  24. INSERT INTO version (table_name, table_version) VALUES ('lcr', '1');
  25. INSERT INTO version (table_name, table_version) VALUES ('presentity', '1');
  26. INSERT INTO version (table_name, table_version) VALUES ('presentity_contact', '1');
  27. INSERT INTO version (table_name, table_version) VALUES ('watcherinfo', '1');
  28. CREATE TABLE acc (
  29. id SERIAL NOT NULL,
  30. from_uid VARCHAR(64),
  31. to_uid VARCHAR(64),
  32. to_did VARCHAR(64),
  33. from_did VARCHAR(64),
  34. sip_from VARCHAR(255),
  35. sip_to VARCHAR(255),
  36. sip_status VARCHAR(128),
  37. sip_method VARCHAR(16),
  38. in_ruri VARCHAR(255),
  39. out_ruri VARCHAR(255),
  40. from_uri VARCHAR(255),
  41. to_uri VARCHAR(255),
  42. sip_callid VARCHAR(255),
  43. sip_cseq INTEGER,
  44. digest_username VARCHAR(64),
  45. digest_realm VARCHAR(255),
  46. from_tag VARCHAR(128),
  47. to_tag VARCHAR(128),
  48. src_ip INTEGER,
  49. src_port SMALLINT,
  50. request_timestamp TIMESTAMP NOT NULL,
  51. response_timestamp TIMESTAMP NOT NULL,
  52. flags INTEGER NOT NULL DEFAULT '0',
  53. attrs VARCHAR(255),
  54. CONSTRAINT id_key UNIQUE (id)
  55. );
  56. CREATE INDEX cid_key ON acc (sip_callid);
  57. CREATE TABLE missed_calls (
  58. id SERIAL NOT NULL,
  59. from_uid VARCHAR(64),
  60. to_uid VARCHAR(64),
  61. to_did VARCHAR(64),
  62. from_did VARCHAR(64),
  63. sip_from VARCHAR(255),
  64. sip_to VARCHAR(255),
  65. sip_status VARCHAR(128),
  66. sip_method VARCHAR(16),
  67. inbound_ruri VARCHAR(255),
  68. outbound_ruri VARCHAR(255),
  69. from_uri VARCHAR(255),
  70. to_uri VARCHAR(255),
  71. sip_callid VARCHAR(255),
  72. sip_cseq INTEGER,
  73. digest_username VARCHAR(64),
  74. digest_realm VARCHAR(255),
  75. from_tag VARCHAR(128),
  76. to_tag VARCHAR(128),
  77. request_timestamp TIMESTAMP NOT NULL,
  78. response_timestamp TIMESTAMP NOT NULL,
  79. flags INTEGER NOT NULL DEFAULT '0',
  80. attrs VARCHAR(255),
  81. CONSTRAINT id_key UNIQUE (id)
  82. );
  83. CREATE INDEX cid_key ON missed_calls (sip_callid);
  84. CREATE TABLE credentials (
  85. auth_username VARCHAR(64) NOT NULL,
  86. realm VARCHAR(64) NOT NULL,
  87. password VARCHAR(28) NOT NULL DEFAULT '',
  88. flags INTEGER NOT NULL DEFAULT '0',
  89. ha1 VARCHAR(32) NOT NULL,
  90. ha1b VARCHAR(32) NOT NULL DEFAULT '',
  91. uid VARCHAR(64) NOT NULL,
  92. UNIQUE (auth_username, realm)
  93. );
  94. CREATE INDEX uid ON credentials (uid);
  95. CREATE TABLE attr_types (
  96. name VARCHAR(32) NOT NULL,
  97. rich_type VARCHAR(32) NOT NULL DEFAULT 'string',
  98. raw_type INTEGER NOT NULL DEFAULT '2',
  99. type_spec VARCHAR(255) DEFAULT NULL
  100. );
  101. CREATE INDEX upt_idx1 ON attr_types (name);
  102. INSERT INTO attr_types (name, raw_type) VALUES ('uid', '2');
  103. INSERT INTO attr_types (name, raw_type) VALUES ('did', '2');
  104. INSERT INTO attr_types (name, raw_type) VALUES ('digest_realm', '2');
  105. INSERT INTO attr_types (name, raw_type) VALUES ('rpid', '2');
  106. INSERT INTO attr_types (name, raw_type) VALUES ('fr_timer', '0');
  107. INSERT INTO attr_types (name, raw_type) VALUES ('fr_inv_timer', '2');
  108. INSERT INTO attr_types (name, raw_type) VALUES ('flags', '0');
  109. CREATE TABLE global_attrs (
  110. name VARCHAR(32) NOT NULL,
  111. type INTEGER NOT NULL DEFAULT '0',
  112. value VARCHAR(64),
  113. flags INTEGER NOT NULL DEFAULT '0',
  114. CONSTRAINT global_attrs_idx UNIQUE (name, value)
  115. );
  116. CREATE TABLE domain_attrs (
  117. did VARCHAR(64),
  118. name VARCHAR(32) NOT NULL,
  119. type INTEGER NOT NULL DEFAULT '0',
  120. value VARCHAR(64),
  121. flags INTEGER NOT NULL DEFAULT '0',
  122. CONSTRAINT domain_attr_idx UNIQUE (did, name, value)
  123. );
  124. CREATE INDEX domain_did ON domain_attrs (did, flags);
  125. CREATE TABLE user_attrs (
  126. uid VARCHAR(64) NOT NULL,
  127. name VARCHAR(32) NOT NULL,
  128. value VARCHAR(64),
  129. type INTEGER NOT NULL DEFAULT '0',
  130. flags INTEGER NOT NULL DEFAULT '0',
  131. CONSTRAINT userattrs_idx UNIQUE (uid, name, value)
  132. );
  133. CREATE TABLE domain (
  134. did VARCHAR(64) NOT NULL,
  135. domain VARCHAR(128) NOT NULL,
  136. last_modified TIMESTAMP NOT NULL,
  137. flags INTEGER NOT NULL DEFAULT '0',
  138. CONSTRAINT domain_idx UNIQUE (did, domain)
  139. );
  140. CREATE TABLE location (
  141. uid VARCHAR(64) NOT NULL,
  142. contact VARCHAR(255) NOT NULL,
  143. received VARCHAR(255),
  144. expires TIMESTAMP NOT NULL DEFAULT '1970-01-01 00:00:00',
  145. q REAL NOT NULL DEFAULT '1.0',
  146. callid VARCHAR(255),
  147. cseq INTEGER,
  148. flags INTEGER NOT NULL DEFAULT '0',
  149. user_agent VARCHAR(64),
  150. CONSTRAINT location_key UNIQUE (uid, contact)
  151. );
  152. CREATE INDEX location_contact ON location (contact);
  153. CREATE TABLE trusted (
  154. src_ip VARCHAR(39) NOT NULL,
  155. proto VARCHAR(4) NOT NULL,
  156. from_pattern VARCHAR(64) NOT NULL,
  157. CONSTRAINT trusted_idx UNIQUE (src_ip, proto, from_pattern)
  158. );
  159. CREATE TABLE server_monitoring (
  160. time TIMESTAMP NOT NULL DEFAULT '1970-01-01 00:00:00',
  161. id INTEGER NOT NULL DEFAULT '0',
  162. param VARCHAR(32) NOT NULL DEFAULT '',
  163. value INTEGER NOT NULL DEFAULT '0',
  164. increment INTEGER NOT NULL DEFAULT '0'
  165. );
  166. CREATE INDEX sm_idx1 ON server_monitoring (id, param);
  167. CREATE TABLE server_monitoring_agg (
  168. param VARCHAR(32) NOT NULL DEFAULT '',
  169. s_value INTEGER NOT NULL DEFAULT '0',
  170. s_increment INTEGER NOT NULL DEFAULT '0',
  171. last_aggregated_increment INTEGER NOT NULL DEFAULT '0',
  172. av DOUBLE PRECISION NOT NULL DEFAULT '0',
  173. mv INTEGER NOT NULL DEFAULT '0',
  174. ad DOUBLE PRECISION NOT NULL DEFAULT '0',
  175. lv INTEGER NOT NULL DEFAULT '0',
  176. min_val INTEGER NOT NULL DEFAULT '0',
  177. max_val INTEGER NOT NULL DEFAULT '0',
  178. min_inc INTEGER NOT NULL DEFAULT '0',
  179. max_inc INTEGER NOT NULL DEFAULT '0',
  180. lastupdate TIMESTAMP NOT NULL DEFAULT '1970-01-01 00:00:00'
  181. );
  182. CREATE INDEX smagg_idx1 ON server_monitoring_agg (param);
  183. CREATE TABLE phonebook (
  184. id SERIAL NOT NULL,
  185. uid VARCHAR(64) NOT NULL,
  186. fname VARCHAR(32),
  187. lname VARCHAR(32),
  188. sip_uri VARCHAR(255) NOT NULL,
  189. CONSTRAINT pb_idx UNIQUE (id)
  190. );
  191. CREATE INDEX pb_uid ON phonebook (uid);
  192. CREATE TABLE gw (
  193. gw_name VARCHAR(128) NOT NULL,
  194. ip_addr INTEGER NOT NULL,
  195. port SMALLINT,
  196. uri_scheme SMALLINT,
  197. transport SMALLINT,
  198. grp_id INTEGER NOT NULL,
  199. CONSTRAINT gw_idx1 UNIQUE (gw_name)
  200. );
  201. CREATE INDEX gw_idx2 ON gw (grp_id);
  202. CREATE TABLE gw_grp (
  203. grp_id SERIAL NOT NULL,
  204. grp_name VARCHAR(64) NOT NULL,
  205. CONSTRAINT gwgrp_idx UNIQUE (grp_id)
  206. );
  207. CREATE TABLE lcr (
  208. prefix VARCHAR(16) NOT NULL,
  209. from_uri VARCHAR(255) NOT NULL DEFAULT '%',
  210. grp_id INTEGER,
  211. priority INTEGER
  212. );
  213. CREATE INDEX lcr_idx1 ON lcr (prefix);
  214. CREATE INDEX lcr_idx2 ON lcr (from_uri);
  215. CREATE INDEX lcr_idx3 ON lcr (grp_id);
  216. CREATE TABLE silo (
  217. mid SERIAL NOT NULL,
  218. src_addr VARCHAR(255) NOT NULL,
  219. dst_addr VARCHAR(255) NOT NULL,
  220. r_uri VARCHAR(255) NOT NULL,
  221. uid VARCHAR(64) NOT NULL,
  222. inc_time TIMESTAMP NOT NULL DEFAULT '1970-01-01 00:00:00',
  223. exp_time TIMESTAMP NOT NULL DEFAULT '1970-01-01 00:00:00',
  224. ctype VARCHAR(128) NOT NULL DEFAULT 'text/plain',
  225. body BYTEA NOT NULL DEFAULT '',
  226. CONSTRAINT silo_idx1 UNIQUE (mid)
  227. );
  228. CREATE TABLE uri (
  229. uid VARCHAR(64) NOT NULL,
  230. did VARCHAR(64) NOT NULL,
  231. username VARCHAR(64) NOT NULL,
  232. flags INTEGER NOT NULL DEFAULT '0',
  233. CONSTRAINT uri_idx1 UNIQUE (username, did, flags),
  234. CONSTRAINT uri_uid UNIQUE (uid, flags)
  235. );
  236. CREATE TABLE speed_dial (
  237. id SERIAL NOT NULL,
  238. uid VARCHAR(64) NOT NULL,
  239. dial_username VARCHAR(64) NOT NULL,
  240. dial_did VARCHAR(64) NOT NULL,
  241. new_uri VARCHAR(255) NOT NULL,
  242. CONSTRAINT speeddial_idx1 UNIQUE (uid, dial_did, dial_username),
  243. CONSTRAINT speeddial_id UNIQUE (id)
  244. );
  245. CREATE INDEX speeddial_uid ON speed_dial (uid);
  246. CREATE TABLE sd_attrs (
  247. id VARCHAR(64) NOT NULL,
  248. name VARCHAR(32) NOT NULL,
  249. value VARCHAR(64),
  250. type INTEGER NOT NULL DEFAULT '0',
  251. flags INTEGER NOT NULL DEFAULT '0',
  252. CONSTRAINT userattrs_idx UNIQUE (id, name, value)
  253. );
  254. CREATE TABLE presentity (
  255. presid SERIAL NOT NULL,
  256. uri VARCHAR(255) NOT NULL,
  257. pdomain VARCHAR(128) NOT NULL,
  258. CONSTRAINT presentity_key UNIQUE (presid)
  259. );
  260. CREATE INDEX presentity_key2 ON presentity (uri);
  261. CREATE TABLE presentity_contact (
  262. contactid SERIAL NOT NULL,
  263. presid INTEGER NOT NULL,
  264. basic VARCHAR(32) NOT NULL DEFAULT 'offline',
  265. status VARCHAR(32) NOT NULL,
  266. location VARCHAR(128) NOT NULL,
  267. expires TIMESTAMP NOT NULL DEFAULT '2020-05-28 21:32:15',
  268. placeid INTEGER,
  269. priority REAL NOT NULL DEFAULT '0.5',
  270. contact VARCHAR(255),
  271. tupleid VARCHAR(64) NOT NULL,
  272. prescaps INTEGER NOT NULL,
  273. CONSTRAINT pc_idx1 UNIQUE (contactid)
  274. );
  275. CREATE INDEX presid_index ON presentity_contact (presid);
  276. CREATE INDEX location_index ON presentity_contact (location);
  277. CREATE INDEX placeid_index ON presentity_contact (placeid);
  278. CREATE TABLE watcherinfo (
  279. r_uri VARCHAR(255) NOT NULL,
  280. w_uri VARCHAR(255) NOT NULL,
  281. display_name VARCHAR(128) NOT NULL,
  282. s_id VARCHAR(64) NOT NULL,
  283. package VARCHAR(32) NOT NULL DEFAULT 'presence',
  284. status VARCHAR(32) NOT NULL DEFAULT 'pending',
  285. event VARCHAR(32) NOT NULL,
  286. expires INTEGER NOT NULL,
  287. accepts INTEGER NOT NULL,
  288. presid INTEGER NOT NULL,
  289. server_contact VARCHAR(255) NOT NULL,
  290. dialog BYTEA NOT NULL,
  291. doc_index INTEGER NOT NULL,
  292. CONSTRAINT wi_idx1 UNIQUE (s_id)
  293. );
  294. CREATE INDEX wi_ruri_idx ON watcherinfo (r_uri);
  295. CREATE INDEX wi_wuri_idx ON watcherinfo (w_uri);