pg_create.sql 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471
  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. CREATE TABLE acc (
  7. id SERIAL NOT NULL,
  8. from_uid VARCHAR(64),
  9. to_uid VARCHAR(64),
  10. to_did VARCHAR(64),
  11. from_did VARCHAR(64),
  12. sip_from VARCHAR(255),
  13. sip_to VARCHAR(255),
  14. sip_status VARCHAR(128),
  15. sip_method VARCHAR(16),
  16. in_ruri VARCHAR(255),
  17. out_ruri VARCHAR(255),
  18. from_uri VARCHAR(255),
  19. to_uri VARCHAR(255),
  20. sip_callid VARCHAR(255),
  21. sip_cseq INTEGER,
  22. digest_username VARCHAR(64),
  23. digest_realm VARCHAR(255),
  24. from_tag VARCHAR(128),
  25. to_tag VARCHAR(128),
  26. src_ip INTEGER,
  27. src_port SMALLINT,
  28. request_timestamp TIMESTAMP NOT NULL,
  29. response_timestamp TIMESTAMP NOT NULL,
  30. flags INTEGER NOT NULL DEFAULT '0',
  31. attrs VARCHAR(255),
  32. CONSTRAINT acc_id_key UNIQUE (id)
  33. );
  34. CREATE INDEX acc_cid_key ON acc (sip_callid);
  35. INSERT INTO version (table_name, table_version) values ('missed_calls','3');
  36. CREATE TABLE missed_calls (
  37. id SERIAL NOT NULL,
  38. from_uid VARCHAR(64),
  39. to_uid VARCHAR(64),
  40. to_did VARCHAR(64),
  41. from_did VARCHAR(64),
  42. sip_from VARCHAR(255),
  43. sip_to VARCHAR(255),
  44. sip_status VARCHAR(128),
  45. sip_method VARCHAR(16),
  46. in_ruri VARCHAR(255),
  47. out_ruri VARCHAR(255),
  48. from_uri VARCHAR(255),
  49. to_uri VARCHAR(255),
  50. sip_callid VARCHAR(255),
  51. sip_cseq INTEGER,
  52. digest_username VARCHAR(64),
  53. digest_realm VARCHAR(255),
  54. from_tag VARCHAR(128),
  55. to_tag VARCHAR(128),
  56. src_ip INTEGER,
  57. src_port SMALLINT,
  58. request_timestamp TIMESTAMP NOT NULL,
  59. response_timestamp TIMESTAMP NOT NULL,
  60. flags INTEGER NOT NULL DEFAULT '0',
  61. attrs VARCHAR(255),
  62. CONSTRAINT mc_id_key UNIQUE (id)
  63. );
  64. CREATE INDEX mc_cid_key ON missed_calls (sip_callid);
  65. INSERT INTO version (table_name, table_version) values ('credentials','7');
  66. CREATE TABLE credentials (
  67. auth_username VARCHAR(64) NOT NULL,
  68. did VARCHAR(64) NOT NULL DEFAULT '_default',
  69. realm VARCHAR(64) NOT NULL,
  70. password VARCHAR(28) NOT NULL DEFAULT '',
  71. flags INTEGER NOT NULL DEFAULT '0',
  72. ha1 VARCHAR(32) NOT NULL,
  73. ha1b VARCHAR(32) NOT NULL DEFAULT '',
  74. uid VARCHAR(64) NOT NULL
  75. );
  76. CREATE INDEX cred_idx ON credentials (auth_username, did);
  77. CREATE INDEX uid ON credentials (uid);
  78. INSERT INTO version (table_name, table_version) values ('attr_types','4');
  79. CREATE TABLE attr_types (
  80. name VARCHAR(32) NOT NULL,
  81. rich_type VARCHAR(32) NOT NULL DEFAULT 'string',
  82. raw_type INTEGER NOT NULL DEFAULT '2',
  83. type_spec VARCHAR(255) DEFAULT NULL,
  84. description VARCHAR(255) DEFAULT NULL,
  85. default_flags INTEGER NOT NULL DEFAULT '0',
  86. flags INTEGER NOT NULL DEFAULT '0',
  87. priority INTEGER NOT NULL DEFAULT '0',
  88. access INTEGER NOT NULL DEFAULT '0',
  89. ordering INTEGER NOT NULL DEFAULT '0',
  90. grp VARCHAR(32) NOT NULL DEFAULT 'other',
  91. CONSTRAINT upt_idx1 UNIQUE (name)
  92. );
  93. INSERT INTO version (table_name, table_version) values ('global_attrs','1');
  94. CREATE TABLE global_attrs (
  95. name VARCHAR(32) NOT NULL,
  96. type INTEGER NOT NULL DEFAULT '0',
  97. value VARCHAR(255),
  98. flags INTEGER NOT NULL DEFAULT '0',
  99. CONSTRAINT global_attrs_idx UNIQUE (name, value)
  100. );
  101. INSERT INTO version (table_name, table_version) values ('domain_attrs','1');
  102. CREATE TABLE domain_attrs (
  103. did VARCHAR(64),
  104. name VARCHAR(32) NOT NULL,
  105. type INTEGER NOT NULL DEFAULT '0',
  106. value VARCHAR(255),
  107. flags INTEGER NOT NULL DEFAULT '0',
  108. CONSTRAINT domain_attr_idx UNIQUE (did, name, value)
  109. );
  110. CREATE INDEX domain_did ON domain_attrs (did, flags);
  111. INSERT INTO version (table_name, table_version) values ('user_attrs','3');
  112. CREATE TABLE user_attrs (
  113. uid VARCHAR(64) NOT NULL,
  114. name VARCHAR(32) NOT NULL,
  115. value VARCHAR(255),
  116. type INTEGER NOT NULL DEFAULT '0',
  117. flags INTEGER NOT NULL DEFAULT '0',
  118. CONSTRAINT userattrs_idx UNIQUE (uid, name, value)
  119. );
  120. INSERT INTO version (table_name, table_version) values ('uri_attrs','2');
  121. CREATE TABLE uri_attrs (
  122. username VARCHAR(64) NOT NULL,
  123. did VARCHAR(64) NOT NULL,
  124. name VARCHAR(32) NOT NULL,
  125. value VARCHAR(255),
  126. type INTEGER NOT NULL DEFAULT '0',
  127. flags INTEGER NOT NULL DEFAULT '0',
  128. scheme VARCHAR(8) NOT NULL DEFAULT 'sip',
  129. CONSTRAINT uriattrs_idx UNIQUE (username, did, name, value, scheme)
  130. );
  131. INSERT INTO version (table_name, table_version) values ('domain','2');
  132. CREATE TABLE domain (
  133. did VARCHAR(64) NOT NULL,
  134. domain VARCHAR(128) NOT NULL,
  135. flags INTEGER NOT NULL DEFAULT '0',
  136. CONSTRAINT domain_idx UNIQUE (domain)
  137. );
  138. INSERT INTO version (table_name, table_version) values ('domain_settings','1');
  139. CREATE TABLE domain_settings (
  140. did VARCHAR(64) NOT NULL,
  141. filename VARCHAR(255) NOT NULL,
  142. version INTEGER NOT NULL,
  143. timestamp INTEGER,
  144. content BYTEA,
  145. flags INTEGER NOT NULL DEFAULT '0',
  146. CONSTRAINT ds_id UNIQUE (did, filename, version)
  147. );
  148. CREATE INDEX ds_df ON domain_settings (did, filename);
  149. INSERT INTO version (table_name, table_version) values ('location','9');
  150. CREATE TABLE location (
  151. uid VARCHAR(64) NOT NULL,
  152. aor VARCHAR(255) NOT NULL,
  153. contact VARCHAR(255) NOT NULL,
  154. received VARCHAR(255),
  155. expires TIMESTAMP NOT NULL DEFAULT '1970-01-01 00:00:00',
  156. q REAL NOT NULL DEFAULT '1.0',
  157. callid VARCHAR(255),
  158. cseq INTEGER,
  159. flags INTEGER NOT NULL DEFAULT '0',
  160. user_agent VARCHAR(64),
  161. instance VARCHAR(255),
  162. CONSTRAINT location_key UNIQUE (uid, contact)
  163. );
  164. CREATE INDEX location_contact ON location (contact);
  165. INSERT INTO version (table_name, table_version) values ('contact_attrs','1');
  166. CREATE TABLE contact_attrs (
  167. uid VARCHAR(64) NOT NULL,
  168. contact VARCHAR(255) NOT NULL,
  169. name VARCHAR(32) NOT NULL,
  170. value VARCHAR(255),
  171. type INTEGER NOT NULL DEFAULT '0',
  172. flags INTEGER NOT NULL DEFAULT '0',
  173. CONSTRAINT contactattrs_idx UNIQUE (uid, contact, name)
  174. );
  175. INSERT INTO version (table_name, table_version) values ('trusted','1');
  176. CREATE TABLE trusted (
  177. src_ip VARCHAR(39) NOT NULL,
  178. proto VARCHAR(4) NOT NULL,
  179. from_pattern VARCHAR(64) NOT NULL,
  180. CONSTRAINT trusted_idx UNIQUE (src_ip, proto, from_pattern)
  181. );
  182. INSERT INTO version (table_name, table_version) values ('ipmatch','1');
  183. CREATE TABLE ipmatch (
  184. ip VARCHAR(50) NOT NULL DEFAULT '',
  185. avp_val VARCHAR(30) DEFAULT NULL,
  186. mark INTEGER NOT NULL DEFAULT '1',
  187. flags INTEGER NOT NULL DEFAULT '0',
  188. CONSTRAINT ipmatch_idx UNIQUE (ip, mark)
  189. );
  190. INSERT INTO version (table_name, table_version) values ('phonebook','1');
  191. CREATE TABLE phonebook (
  192. id SERIAL NOT NULL,
  193. uid VARCHAR(64) NOT NULL,
  194. fname VARCHAR(32),
  195. lname VARCHAR(32),
  196. sip_uri VARCHAR(255) NOT NULL,
  197. CONSTRAINT pb_idx UNIQUE (id)
  198. );
  199. CREATE INDEX pb_uid ON phonebook (uid);
  200. INSERT INTO version (table_name, table_version) values ('gw','3');
  201. CREATE TABLE gw (
  202. gw_name VARCHAR(128) NOT NULL,
  203. ip_addr INTEGER NOT NULL,
  204. port SMALLINT,
  205. uri_scheme SMALLINT,
  206. transport SMALLINT,
  207. grp_id INTEGER NOT NULL,
  208. CONSTRAINT gw_idx1 UNIQUE (gw_name)
  209. );
  210. CREATE INDEX gw_idx2 ON gw (grp_id);
  211. INSERT INTO version (table_name, table_version) values ('gw_grp','2');
  212. CREATE TABLE gw_grp (
  213. grp_id SERIAL NOT NULL,
  214. grp_name VARCHAR(64) NOT NULL,
  215. CONSTRAINT gwgrp_idx UNIQUE (grp_id)
  216. );
  217. INSERT INTO version (table_name, table_version) values ('lcr','1');
  218. CREATE TABLE lcr (
  219. prefix VARCHAR(16) NOT NULL,
  220. from_uri VARCHAR(255) NOT NULL DEFAULT '%',
  221. grp_id INTEGER,
  222. priority INTEGER
  223. );
  224. CREATE INDEX lcr_idx1 ON lcr (prefix);
  225. CREATE INDEX lcr_idx2 ON lcr (from_uri);
  226. CREATE INDEX lcr_idx3 ON lcr (grp_id);
  227. INSERT INTO version (table_name, table_version) values ('grp','3');
  228. CREATE TABLE grp (
  229. uid VARCHAR(64) NOT NULL DEFAULT '',
  230. grp VARCHAR(64) NOT NULL DEFAULT '',
  231. last_modified TIMESTAMP NOT NULL DEFAULT '1970-01-01 00:00:00'
  232. );
  233. CREATE INDEX grp_idx ON grp (uid, grp);
  234. INSERT INTO version (table_name, table_version) values ('silo','4');
  235. CREATE TABLE silo (
  236. mid SERIAL NOT NULL,
  237. from_hdr VARCHAR(255) NOT NULL,
  238. to_hdr VARCHAR(255) NOT NULL,
  239. ruri VARCHAR(255) NOT NULL,
  240. uid VARCHAR(64) NOT NULL,
  241. inc_time TIMESTAMP NOT NULL DEFAULT '1970-01-01 00:00:00',
  242. exp_time TIMESTAMP NOT NULL DEFAULT '1970-01-01 00:00:00',
  243. ctype VARCHAR(128) NOT NULL DEFAULT 'text/plain',
  244. body BYTEA NOT NULL DEFAULT '',
  245. CONSTRAINT silo_idx1 UNIQUE (mid)
  246. );
  247. INSERT INTO version (table_name, table_version) values ('uri','3');
  248. CREATE TABLE uri (
  249. uid VARCHAR(64) NOT NULL,
  250. did VARCHAR(64) NOT NULL,
  251. username VARCHAR(64) NOT NULL,
  252. flags INTEGER NOT NULL DEFAULT '0',
  253. scheme VARCHAR(8) NOT NULL DEFAULT 'sip'
  254. );
  255. CREATE INDEX uri_idx1 ON uri (username, did, scheme);
  256. CREATE INDEX uri_uid ON uri (uid);
  257. INSERT INTO version (table_name, table_version) values ('speed_dial','2');
  258. CREATE TABLE speed_dial (
  259. id SERIAL NOT NULL,
  260. uid VARCHAR(64) NOT NULL,
  261. dial_username VARCHAR(64) NOT NULL,
  262. dial_did VARCHAR(64) NOT NULL,
  263. new_uri VARCHAR(255) NOT NULL,
  264. CONSTRAINT speeddial_idx1 UNIQUE (uid, dial_did, dial_username),
  265. CONSTRAINT speeddial_id UNIQUE (id)
  266. );
  267. CREATE INDEX speeddial_uid ON speed_dial (uid);
  268. INSERT INTO version (table_name, table_version) values ('sd_attrs','1');
  269. CREATE TABLE sd_attrs (
  270. id VARCHAR(64) NOT NULL,
  271. name VARCHAR(32) NOT NULL,
  272. value VARCHAR(255),
  273. type INTEGER NOT NULL DEFAULT '0',
  274. flags INTEGER NOT NULL DEFAULT '0',
  275. CONSTRAINT sd_idx UNIQUE (id, name, value)
  276. );
  277. INSERT INTO version (table_name, table_version) values ('presentity','5');
  278. CREATE TABLE presentity (
  279. pres_id VARCHAR(64) NOT NULL,
  280. uri VARCHAR(255) NOT NULL,
  281. uid VARCHAR(64) NOT NULL,
  282. pdomain VARCHAR(128) NOT NULL,
  283. xcap_params BYTEA NOT NULL,
  284. CONSTRAINT presentity_key UNIQUE (pres_id)
  285. );
  286. INSERT INTO version (table_name, table_version) values ('presentity_notes','5');
  287. CREATE TABLE presentity_notes (
  288. dbid VARCHAR(64) NOT NULL,
  289. pres_id VARCHAR(64) NOT NULL,
  290. etag VARCHAR(64) NOT NULL,
  291. note VARCHAR(128) NOT NULL,
  292. lang VARCHAR(64) NOT NULL,
  293. expires TIMESTAMP NOT NULL DEFAULT '2005-12-07 08:13:15',
  294. CONSTRAINT pnotes_idx1 UNIQUE (dbid)
  295. );
  296. INSERT INTO version (table_name, table_version) values ('presentity_extensions','5');
  297. CREATE TABLE presentity_extensions (
  298. dbid VARCHAR(64) NOT NULL,
  299. pres_id VARCHAR(64) NOT NULL,
  300. etag VARCHAR(64) NOT NULL,
  301. element BYTEA NOT NULL,
  302. expires TIMESTAMP NOT NULL DEFAULT '2005-12-07 08:13:15',
  303. CONSTRAINT presextensions_idx1 UNIQUE (dbid)
  304. );
  305. INSERT INTO version (table_name, table_version) values ('presentity_contact','5');
  306. CREATE TABLE presentity_contact (
  307. pres_id VARCHAR(64) NOT NULL,
  308. basic INTEGER NOT NULL,
  309. expires TIMESTAMP NOT NULL DEFAULT '2004-05-28 21:32:15',
  310. priority REAL NOT NULL DEFAULT '0.5',
  311. contact VARCHAR(255),
  312. tupleid VARCHAR(64) NOT NULL,
  313. etag VARCHAR(64) NOT NULL,
  314. published_id VARCHAR(64) NOT NULL,
  315. CONSTRAINT presid_index UNIQUE (pres_id, tupleid)
  316. );
  317. INSERT INTO version (table_name, table_version) values ('watcherinfo','5');
  318. CREATE TABLE watcherinfo (
  319. w_uri VARCHAR(255) NOT NULL,
  320. display_name VARCHAR(128) NOT NULL,
  321. s_id VARCHAR(64) NOT NULL,
  322. package VARCHAR(32) NOT NULL DEFAULT 'presence',
  323. status VARCHAR(32) NOT NULL DEFAULT 'pending',
  324. event VARCHAR(32) NOT NULL,
  325. expires TIMESTAMP NOT NULL DEFAULT '2005-12-07 08:13:15',
  326. accepts INTEGER NOT NULL,
  327. pres_id VARCHAR(64) NOT NULL,
  328. server_contact VARCHAR(255) NOT NULL,
  329. dialog BYTEA NOT NULL,
  330. doc_index INTEGER NOT NULL,
  331. CONSTRAINT wi_idx1 UNIQUE (s_id)
  332. );
  333. INSERT INTO version (table_name, table_version) values ('tuple_notes','5');
  334. CREATE TABLE tuple_notes (
  335. pres_id VARCHAR(64) NOT NULL,
  336. tupleid VARCHAR(64) NOT NULL,
  337. note VARCHAR(128) NOT NULL,
  338. lang VARCHAR(64) NOT NULL
  339. );
  340. INSERT INTO version (table_name, table_version) values ('tuple_extensions','5');
  341. CREATE TABLE tuple_extensions (
  342. pres_id VARCHAR(64) NOT NULL,
  343. tupleid VARCHAR(64) NOT NULL,
  344. element BYTEA NOT NULL,
  345. status_extension INTEGER NOT NULL
  346. );
  347. INSERT INTO version (table_name, table_version) values ('offline_winfo','5');
  348. CREATE TABLE offline_winfo (
  349. uid VARCHAR(64) NOT NULL,
  350. watcher VARCHAR(255) NOT NULL,
  351. events VARCHAR(64) NOT NULL,
  352. domain VARCHAR(128),
  353. status VARCHAR(32),
  354. created_on TIMESTAMP NOT NULL DEFAULT '2006-01-31 13:13:13',
  355. expires_on TIMESTAMP NOT NULL DEFAULT '2006-01-31 13:13:13',
  356. dbid SERIAL NOT NULL,
  357. CONSTRAINT offline_winfo_key UNIQUE (dbid)
  358. );
  359. INSERT INTO version (table_name, table_version) values ('rls_subscription','1');
  360. CREATE TABLE rls_subscription (
  361. id VARCHAR(48) NOT NULL,
  362. doc_version INTEGER NOT NULL,
  363. dialog BYTEA NOT NULL,
  364. expires TIMESTAMP NOT NULL DEFAULT '2005-12-02 09:00:13',
  365. status INTEGER NOT NULL,
  366. contact VARCHAR(255) NOT NULL,
  367. uri VARCHAR(255) NOT NULL,
  368. package VARCHAR(128) NOT NULL,
  369. w_uri VARCHAR(255) NOT NULL,
  370. xcap_params BYTEA NOT NULL,
  371. CONSTRAINT rls_subscription_key UNIQUE (id)
  372. );
  373. INSERT INTO version (table_name, table_version) values ('rls_vs','1');
  374. CREATE TABLE rls_vs (
  375. id VARCHAR(48) NOT NULL,
  376. rls_id VARCHAR(48) NOT NULL,
  377. uri VARCHAR(255) NOT NULL,
  378. CONSTRAINT rls_vs_key UNIQUE (id)
  379. );
  380. INSERT INTO version (table_name, table_version) values ('rls_vs_names','1');
  381. CREATE TABLE rls_vs_names (
  382. id VARCHAR(48) NOT NULL,
  383. name VARCHAR(64),
  384. lang VARCHAR(64)
  385. );
  386. INSERT INTO version (table_name, table_version) values ('i18n','1');
  387. CREATE TABLE i18n (
  388. code INTEGER NOT NULL,
  389. reason_re VARCHAR(255) DEFAULT NULL,
  390. lang VARCHAR(32) NOT NULL,
  391. new_reason VARCHAR(255),
  392. CONSTRAINT i18n_uniq_idx UNIQUE (code, lang)
  393. );
  394. CREATE INDEX i18n_idx ON i18n (code);
  395. INSERT INTO version (table_name, table_version) values ('pdt','1');
  396. CREATE TABLE pdt (
  397. prefix VARCHAR(32) NOT NULL,
  398. domain VARCHAR(255) NOT NULL,
  399. CONSTRAINT pdt_idx UNIQUE (prefix)
  400. );
  401. INSERT INTO version (table_name, table_version) values ('cpl','2');
  402. CREATE TABLE cpl (
  403. uid VARCHAR(64) NOT NULL,
  404. cpl_xml BYTEA,
  405. cpl_bin BYTEA,
  406. CONSTRAINT cpl_key UNIQUE (uid)
  407. );
  408. INSERT INTO version (table_name, table_version) values ('customers','1');
  409. CREATE TABLE customers (
  410. cid SERIAL NOT NULL,
  411. name VARCHAR(128) NOT NULL,
  412. address VARCHAR(255),
  413. phone VARCHAR(64),
  414. email VARCHAR(255),
  415. CONSTRAINT cu_idx UNIQUE (cid)
  416. );