20120101000010_create_ticket.rb 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607
  1. # Copyright (C) 2012-2023 Zammad Foundation, https://zammad-foundation.org/
  2. class CreateTicket < ActiveRecord::Migration[4.2]
  3. def up
  4. create_table :ticket_state_types do |t|
  5. t.column :name, :string, limit: 250, null: false
  6. t.column :note, :string, limit: 250, null: true
  7. t.column :updated_by_id, :integer, null: false
  8. t.column :created_by_id, :integer, null: false
  9. t.timestamps limit: 3, null: false
  10. end
  11. add_index :ticket_state_types, [:name], unique: true
  12. add_foreign_key :ticket_state_types, :users, column: :created_by_id
  13. add_foreign_key :ticket_state_types, :users, column: :updated_by_id
  14. create_table :ticket_states do |t|
  15. t.references :state_type, null: false
  16. t.column :name, :string, limit: 250, null: false
  17. t.column :next_state_id, :integer, null: true
  18. t.column :ignore_escalation, :boolean, null: false, default: false
  19. t.column :default_create, :boolean, null: false, default: false
  20. t.column :default_follow_up, :boolean, null: false, default: false
  21. t.column :note, :string, limit: 250, null: true
  22. t.column :active, :boolean, null: false, default: true
  23. t.column :updated_by_id, :integer, null: false
  24. t.column :created_by_id, :integer, null: false
  25. t.timestamps limit: 3, null: false
  26. end
  27. add_index :ticket_states, [:name], unique: true
  28. add_index :ticket_states, [:default_create]
  29. add_index :ticket_states, [:default_follow_up]
  30. add_foreign_key :ticket_states, :ticket_state_types, column: :state_type_id
  31. add_foreign_key :ticket_states, :users, column: :created_by_id
  32. add_foreign_key :ticket_states, :users, column: :updated_by_id
  33. create_table :ticket_priorities do |t|
  34. t.column :name, :string, limit: 250, null: false
  35. t.column :default_create, :boolean, null: false, default: false
  36. t.column :ui_icon, :string, limit: 100, null: true
  37. t.column :ui_color, :string, limit: 100, null: true
  38. t.column :note, :string, limit: 250, null: true
  39. t.column :active, :boolean, null: false, default: true
  40. t.column :updated_by_id, :integer, null: false
  41. t.column :created_by_id, :integer, null: false
  42. t.timestamps limit: 3, null: false
  43. end
  44. add_index :ticket_priorities, [:name], unique: true
  45. add_index :ticket_priorities, [:default_create]
  46. add_foreign_key :ticket_priorities, :users, column: :created_by_id
  47. add_foreign_key :ticket_priorities, :users, column: :updated_by_id
  48. create_table :tickets do |t|
  49. t.references :group, null: false
  50. t.references :priority, null: false
  51. t.references :state, null: false
  52. t.references :organization, null: true
  53. t.column :number, :string, limit: 60, null: false
  54. t.column :title, :string, limit: 250, null: false
  55. t.column :owner_id, :integer, null: false
  56. t.column :customer_id, :integer, null: false
  57. t.column :note, :string, limit: 250, null: true
  58. t.column :first_response_at, :timestamp, limit: 3, null: true
  59. t.column :first_response_escalation_at, :timestamp, limit: 3, null: true
  60. t.column :first_response_in_min, :integer, null: true
  61. t.column :first_response_diff_in_min, :integer, null: true
  62. t.column :close_at, :timestamp, limit: 3, null: true
  63. t.column :close_escalation_at, :timestamp, limit: 3, null: true
  64. t.column :close_in_min, :integer, null: true
  65. t.column :close_diff_in_min, :integer, null: true
  66. t.column :update_escalation_at, :timestamp, limit: 3, null: true
  67. t.column :update_in_min, :integer, null: true
  68. t.column :update_diff_in_min, :integer, null: true
  69. t.column :last_close_at, :timestamp, limit: 3, null: true
  70. t.column :last_contact_at, :timestamp, limit: 3, null: true
  71. t.column :last_contact_agent_at, :timestamp, limit: 3, null: true
  72. t.column :last_contact_customer_at, :timestamp, limit: 3, null: true
  73. t.column :last_owner_update_at, :timestamp, limit: 3, null: true
  74. t.column :create_article_type_id, :integer, null: true
  75. t.column :create_article_sender_id, :integer, null: true
  76. t.column :article_count, :integer, null: true
  77. t.column :escalation_at, :timestamp, limit: 3, null: true
  78. t.column :pending_time, :timestamp, limit: 3, null: true
  79. t.column :type, :string, limit: 100, null: true
  80. t.column :time_unit, :decimal, precision: 6, scale: 2, null: true
  81. t.column :preferences, :text, limit: 500.kilobytes + 1, null: true
  82. t.column :updated_by_id, :integer, null: false
  83. t.column :created_by_id, :integer, null: false
  84. t.timestamps limit: 3, null: false
  85. end
  86. add_index :tickets, [:state_id]
  87. add_index :tickets, [:priority_id]
  88. add_index :tickets, [:group_id]
  89. add_index :tickets, [:owner_id]
  90. add_index :tickets, [:customer_id]
  91. add_index :tickets, %i[customer_id state_id created_at]
  92. add_index :tickets, [:number], unique: true
  93. add_index :tickets, [:title]
  94. add_index :tickets, [:created_at]
  95. add_index :tickets, [:updated_at]
  96. add_index :tickets, [:first_response_at]
  97. add_index :tickets, [:first_response_escalation_at]
  98. add_index :tickets, [:first_response_in_min]
  99. add_index :tickets, [:first_response_diff_in_min]
  100. add_index :tickets, [:close_at]
  101. add_index :tickets, [:close_escalation_at]
  102. add_index :tickets, [:close_in_min]
  103. add_index :tickets, [:close_diff_in_min]
  104. add_index :tickets, [:escalation_at]
  105. add_index :tickets, [:update_in_min]
  106. add_index :tickets, [:update_diff_in_min]
  107. add_index :tickets, [:last_contact_at]
  108. add_index :tickets, [:last_contact_agent_at]
  109. add_index :tickets, [:last_contact_customer_at]
  110. add_index :tickets, [:last_owner_update_at]
  111. add_index :tickets, [:create_article_type_id]
  112. add_index :tickets, [:create_article_sender_id]
  113. add_index :tickets, [:created_by_id]
  114. add_index :tickets, [:pending_time]
  115. add_index :tickets, [:type]
  116. add_index :tickets, [:time_unit]
  117. add_index :tickets, %i[group_id state_id]
  118. add_index :tickets, %i[group_id state_id owner_id]
  119. add_index :tickets, %i[group_id state_id updated_at]
  120. add_index :tickets, %i[group_id state_id owner_id updated_at], name: 'index_tickets_on_group_id_state_id_owner_id_updated_at'
  121. add_index :tickets, %i[group_id state_id created_at]
  122. add_index :tickets, %i[group_id state_id owner_id created_at], name: 'index_tickets_on_group_id_state_id_owner_id_created_at'
  123. add_index :tickets, %i[group_id state_id close_at]
  124. add_index :tickets, %i[group_id state_id owner_id close_at], name: 'index_tickets_on_group_id_state_id_owner_id_close_at'
  125. add_foreign_key :tickets, :groups
  126. add_foreign_key :tickets, :users, column: :owner_id
  127. add_foreign_key :tickets, :users, column: :customer_id
  128. add_foreign_key :tickets, :ticket_priorities, column: :priority_id
  129. add_foreign_key :tickets, :ticket_states, column: :state_id
  130. add_foreign_key :tickets, :organizations
  131. add_foreign_key :tickets, :users, column: :created_by_id
  132. add_foreign_key :tickets, :users, column: :updated_by_id
  133. create_table :ticket_flags do |t|
  134. t.references :ticket, null: false
  135. t.column :key, :string, limit: 50, null: false
  136. t.column :value, :string, limit: 50, null: true
  137. t.column :created_by_id, :integer, null: false
  138. t.timestamps limit: 3, null: false
  139. end
  140. add_index :ticket_flags, %i[ticket_id created_by_id]
  141. add_index :ticket_flags, %i[ticket_id key]
  142. add_index :ticket_flags, [:ticket_id]
  143. add_index :ticket_flags, [:created_by_id]
  144. add_foreign_key :ticket_flags, :tickets, column: :ticket_id
  145. add_foreign_key :ticket_flags, :users, column: :created_by_id
  146. create_table :ticket_article_types do |t|
  147. t.column :name, :string, limit: 250, null: false
  148. t.column :note, :string, limit: 250, null: true
  149. t.column :communication, :boolean, null: false
  150. t.column :active, :boolean, null: false, default: true
  151. t.column :updated_by_id, :integer, null: false
  152. t.column :created_by_id, :integer, null: false
  153. t.timestamps limit: 3, null: false
  154. end
  155. add_index :ticket_article_types, [:name], unique: true
  156. add_foreign_key :ticket_article_types, :users, column: :created_by_id
  157. add_foreign_key :ticket_article_types, :users, column: :updated_by_id
  158. create_table :ticket_article_senders do |t|
  159. t.column :name, :string, limit: 250, null: false
  160. t.column :note, :string, limit: 250, null: true
  161. t.column :updated_by_id, :integer, null: false
  162. t.column :created_by_id, :integer, null: false
  163. t.timestamps limit: 3, null: false
  164. end
  165. add_index :ticket_article_senders, [:name], unique: true
  166. add_foreign_key :ticket_article_senders, :users, column: :created_by_id
  167. add_foreign_key :ticket_article_senders, :users, column: :updated_by_id
  168. create_table :ticket_articles do |t|
  169. t.references :ticket, null: false
  170. t.references :type, null: false
  171. t.references :sender, null: false
  172. t.column :from, :string, limit: 3000, null: true
  173. t.column :to, :string, limit: 3000, null: true
  174. t.column :cc, :string, limit: 3000, null: true
  175. t.column :subject, :string, limit: 3000, null: true
  176. t.column :reply_to, :string, limit: 300, null: true
  177. t.column :message_id, :string, limit: 3000, null: true
  178. t.column :message_id_md5, :string, limit: 32, null: true
  179. t.column :in_reply_to, :string, limit: 3000, null: true
  180. t.column :content_type, :string, limit: 20, null: false, default: 'text/plain'
  181. t.column :references, :string, limit: 3200, null: true
  182. t.column :body, :text, limit: 20.megabytes + 1, null: false
  183. t.column :internal, :boolean, null: false, default: false
  184. t.column :preferences, :text, limit: 500.kilobytes + 1, null: true
  185. t.column :updated_by_id, :integer, null: false
  186. t.column :created_by_id, :integer, null: false
  187. t.column :origin_by_id, :integer
  188. t.timestamps limit: 3, null: false
  189. end
  190. add_index :ticket_articles, [:ticket_id]
  191. add_index :ticket_articles, [:message_id_md5]
  192. add_index :ticket_articles, %i[message_id_md5 type_id], name: 'index_ticket_articles_message_id_md5_type_id'
  193. add_index :ticket_articles, [:created_by_id]
  194. add_index :ticket_articles, [:created_at]
  195. add_index :ticket_articles, [:internal]
  196. add_index :ticket_articles, [:type_id]
  197. add_index :ticket_articles, [:sender_id]
  198. add_foreign_key :ticket_articles, :tickets
  199. add_foreign_key :ticket_articles, :ticket_article_types, column: :type_id
  200. add_foreign_key :ticket_articles, :ticket_article_senders, column: :sender_id
  201. add_foreign_key :ticket_articles, :users, column: :created_by_id
  202. add_foreign_key :ticket_articles, :users, column: :updated_by_id
  203. add_foreign_key :ticket_articles, :users, column: :origin_by_id
  204. create_table :ticket_article_flags do |t|
  205. t.references :ticket_article, null: false
  206. t.column :key, :string, limit: 50, null: false
  207. t.column :value, :string, limit: 50, null: true
  208. t.column :created_by_id, :integer, null: false
  209. t.timestamps limit: 3, null: false
  210. end
  211. add_index :ticket_article_flags, %i[ticket_article_id created_by_id], name: 'index_ticket_article_flags_on_articles_id_and_created_by_id'
  212. add_index :ticket_article_flags, %i[ticket_article_id key]
  213. add_index :ticket_article_flags, [:ticket_article_id]
  214. add_index :ticket_article_flags, [:created_by_id]
  215. add_foreign_key :ticket_article_flags, :ticket_articles, column: :ticket_article_id
  216. add_foreign_key :ticket_article_flags, :users, column: :created_by_id
  217. create_table :ticket_time_accountings do |t|
  218. t.references :ticket, null: false
  219. t.references :ticket_article, null: true
  220. t.column :time_unit, :decimal, precision: 6, scale: 2, null: false
  221. t.column :created_by_id, :integer, null: false
  222. t.timestamps limit: 3, null: false
  223. end
  224. add_index :ticket_time_accountings, [:ticket_id]
  225. add_index :ticket_time_accountings, [:ticket_article_id]
  226. add_index :ticket_time_accountings, [:created_by_id]
  227. add_index :ticket_time_accountings, [:time_unit]
  228. add_foreign_key :ticket_time_accountings, :tickets
  229. add_foreign_key :ticket_time_accountings, :ticket_articles
  230. add_foreign_key :ticket_time_accountings, :users, column: :created_by_id
  231. create_table :ticket_counters do |t|
  232. t.column :content, :string, limit: 100, null: false
  233. t.column :generator, :string, limit: 100, null: false
  234. end
  235. add_index :ticket_counters, [:generator], unique: true
  236. create_table :overviews do |t|
  237. t.column :name, :string, limit: 250, null: false
  238. t.column :link, :string, limit: 250, null: false
  239. t.column :prio, :integer, null: false
  240. t.column :condition, :text, limit: 500.kilobytes + 1, null: false
  241. t.column :order, :string, limit: 2500, null: false
  242. t.column :group_by, :string, limit: 250, null: true
  243. t.column :group_direction, :string, limit: 250, null: true
  244. t.column :organization_shared, :boolean, null: false, default: false
  245. t.column :out_of_office, :boolean, null: false, default: false
  246. t.column :view, :string, limit: 1000, null: false
  247. t.column :active, :boolean, null: false, default: true
  248. t.column :updated_by_id, :integer, null: false
  249. t.column :created_by_id, :integer, null: false
  250. t.timestamps limit: 3, null: false
  251. end
  252. add_index :overviews, [:name]
  253. add_foreign_key :overviews, :users, column: :created_by_id
  254. add_foreign_key :overviews, :users, column: :updated_by_id
  255. create_table :overviews_roles, id: false do |t|
  256. t.references :overview
  257. t.references :role
  258. end
  259. add_index :overviews_roles, [:overview_id]
  260. add_index :overviews_roles, [:role_id]
  261. add_foreign_key :overviews_roles, :overviews
  262. add_foreign_key :overviews_roles, :roles
  263. create_table :overviews_users, id: false do |t|
  264. t.references :overview
  265. t.references :user
  266. end
  267. add_index :overviews_users, [:overview_id]
  268. add_index :overviews_users, [:user_id]
  269. add_foreign_key :overviews_users, :overviews
  270. add_foreign_key :overviews_users, :users
  271. create_table :overviews_groups, id: false do |t|
  272. t.references :overview
  273. t.references :group
  274. end
  275. add_index :overviews_groups, [:overview_id]
  276. add_index :overviews_groups, [:group_id]
  277. add_foreign_key :overviews_groups, :overviews
  278. add_foreign_key :overviews_groups, :groups
  279. create_table :triggers do |t|
  280. t.column :name, :string, limit: 250, null: false
  281. t.column :condition, :text, limit: 500.kilobytes + 1, null: false
  282. t.column :perform, :text, limit: 500.kilobytes + 1, null: false
  283. t.column :disable_notification, :boolean, null: false, default: true
  284. t.column :note, :string, limit: 250, null: true
  285. t.column :active, :boolean, null: false, default: true
  286. t.column :updated_by_id, :integer, null: false
  287. t.column :created_by_id, :integer, null: false
  288. t.timestamps limit: 3, null: false
  289. end
  290. add_index :triggers, [:name], unique: true
  291. add_foreign_key :triggers, :users, column: :created_by_id
  292. add_foreign_key :triggers, :users, column: :updated_by_id
  293. create_table :jobs do |t|
  294. t.column :name, :string, limit: 250, null: false
  295. t.column :timeplan, :string, limit: 2500, null: false
  296. t.column :condition, :text, limit: 500.kilobytes + 1, null: false
  297. t.column :perform, :text, limit: 500.kilobytes + 1, null: false
  298. t.column :disable_notification, :boolean, null: false, default: true
  299. t.column :last_run_at, :timestamp, limit: 3, null: true
  300. t.column :next_run_at, :timestamp, limit: 3, null: true
  301. t.column :running, :boolean, null: false, default: false
  302. t.column :processed, :integer, null: false, default: 0
  303. t.column :matching, :integer, null: false
  304. t.column :pid, :string, limit: 250, null: true
  305. t.column :note, :string, limit: 250, null: true
  306. t.column :active, :boolean, null: false, default: false
  307. t.column :updated_by_id, :integer, null: false
  308. t.column :created_by_id, :integer, null: false
  309. t.timestamps limit: 3, null: false
  310. end
  311. add_index :jobs, [:name], unique: true
  312. add_foreign_key :jobs, :users, column: :created_by_id
  313. add_foreign_key :jobs, :users, column: :updated_by_id
  314. create_table :link_types do |t|
  315. t.column :name, :string, limit: 250, null: false
  316. t.column :note, :string, limit: 250, null: true
  317. t.column :active, :boolean, null: false, default: true
  318. t.timestamps limit: 3, null: false
  319. end
  320. add_index :link_types, [:name], unique: true
  321. create_table :link_objects do |t|
  322. t.column :name, :string, limit: 250, null: false
  323. t.column :note, :string, limit: 250, null: true
  324. t.column :active, :boolean, null: false, default: true
  325. t.timestamps limit: 3, null: false
  326. end
  327. add_index :link_objects, [:name], unique: true
  328. create_table :links do |t|
  329. t.references :link_type, null: false
  330. t.column :link_object_source_id, :integer, null: false
  331. t.column :link_object_source_value, :integer, null: false
  332. t.column :link_object_target_id, :integer, null: false
  333. t.column :link_object_target_value, :integer, null: false
  334. t.timestamps limit: 3, null: false
  335. end
  336. add_index :links, %i[link_object_source_id link_object_source_value link_object_target_id link_object_target_value link_type_id], unique: true, name: 'links_uniq_total'
  337. add_foreign_key :links, :link_types
  338. create_table :postmaster_filters do |t|
  339. t.column :name, :string, limit: 250, null: false
  340. t.column :channel, :string, limit: 250, null: false
  341. t.column :match, :text, limit: 500.kilobytes + 1, null: false
  342. t.column :perform, :text, limit: 500.kilobytes + 1, null: false
  343. t.column :active, :boolean, null: false, default: true
  344. t.column :note, :string, limit: 250, null: true
  345. t.column :updated_by_id, :integer, null: false
  346. t.column :created_by_id, :integer, null: false
  347. t.timestamps limit: 3, null: false
  348. end
  349. add_index :postmaster_filters, [:channel]
  350. add_foreign_key :postmaster_filters, :users, column: :created_by_id
  351. add_foreign_key :postmaster_filters, :users, column: :updated_by_id
  352. create_table :text_modules do |t|
  353. t.column :name, :string, limit: 250, null: false
  354. t.column :keywords, :string, limit: 500, null: true
  355. t.column :content, :text, limit: 10.megabytes + 1, null: false
  356. t.column :note, :string, limit: 250, null: true
  357. t.column :active, :boolean, null: false, default: true
  358. t.column :updated_by_id, :integer, null: false
  359. t.column :created_by_id, :integer, null: false
  360. t.timestamps limit: 3, null: false
  361. end
  362. add_index :text_modules, [:name]
  363. add_foreign_key :text_modules, :users, column: :created_by_id
  364. add_foreign_key :text_modules, :users, column: :updated_by_id
  365. create_table :text_modules_groups, id: false do |t|
  366. t.references :text_module
  367. t.references :group
  368. end
  369. add_index :text_modules_groups, [:text_module_id]
  370. add_index :text_modules_groups, [:group_id]
  371. add_foreign_key :text_modules_groups, :text_modules
  372. add_foreign_key :text_modules_groups, :groups
  373. create_table :templates do |t|
  374. t.column :name, :string, limit: 250, null: false
  375. t.column :options, :text, limit: 10.megabytes + 1, null: false
  376. t.column :active, :boolean, null: false, default: true
  377. t.column :updated_by_id, :integer, null: false
  378. t.column :created_by_id, :integer, null: false
  379. t.timestamps limit: 3, null: false
  380. end
  381. add_index :templates, [:name]
  382. add_foreign_key :templates, :users, column: :created_by_id
  383. add_foreign_key :templates, :users, column: :updated_by_id
  384. create_table :templates_groups, id: false do |t|
  385. t.references :template
  386. t.references :group
  387. end
  388. add_index :templates_groups, [:template_id]
  389. add_index :templates_groups, [:group_id]
  390. add_foreign_key :templates_groups, :templates
  391. add_foreign_key :templates_groups, :groups
  392. create_table :channels do |t|
  393. t.references :group, null: true
  394. t.column :area, :string, limit: 100, null: false
  395. t.column :options, :text, limit: 500.kilobytes + 1, null: true
  396. t.column :active, :boolean, null: false, default: true
  397. t.column :preferences, :string, limit: 2000, null: true
  398. t.column :last_log_in, :text, limit: 500.kilobytes + 1, null: true
  399. t.column :last_log_out, :text, limit: 500.kilobytes + 1, null: true
  400. t.column :status_in, :string, limit: 100, null: true
  401. t.column :status_out, :string, limit: 100, null: true
  402. t.column :updated_by_id, :integer, null: false
  403. t.column :created_by_id, :integer, null: false
  404. t.timestamps limit: 3, null: false
  405. end
  406. add_index :channels, [:area]
  407. add_foreign_key :channels, :groups
  408. add_foreign_key :channels, :users, column: :created_by_id
  409. add_foreign_key :channels, :users, column: :updated_by_id
  410. create_table :slas do |t|
  411. t.references :calendar, null: false
  412. t.column :name, :string, limit: 150, null: true
  413. t.column :first_response_time, :integer, null: true
  414. t.column :response_time, :integer, null: true
  415. t.column :update_time, :integer, null: true
  416. t.column :solution_time, :integer, null: true
  417. t.column :condition, :text, limit: 500.kilobytes + 1, null: true
  418. t.column :updated_by_id, :integer, null: false
  419. t.column :created_by_id, :integer, null: false
  420. t.timestamps limit: 3, null: false
  421. end
  422. add_index :slas, [:name], unique: true
  423. add_foreign_key :slas, :users, column: :created_by_id
  424. add_foreign_key :slas, :users, column: :updated_by_id
  425. create_table :macros do |t|
  426. t.string :name, limit: 250, null: true
  427. t.text :perform, limit: 500.kilobytes + 1, null: false
  428. t.boolean :active, null: false, default: true
  429. t.string :ux_flow_next_up, null: false, default: 'none'
  430. t.string :note, limit: 250, null: true
  431. t.integer :updated_by_id, null: false
  432. t.integer :created_by_id, null: false
  433. t.timestamps limit: 3, null: false
  434. end
  435. add_index :macros, [:name], unique: true
  436. add_foreign_key :macros, :users, column: :created_by_id
  437. add_foreign_key :macros, :users, column: :updated_by_id
  438. create_table :chats do |t|
  439. t.string :name, limit: 250, null: true
  440. t.integer :max_queue, null: false, default: 5
  441. t.string :note, limit: 250, null: true
  442. t.boolean :active, null: false, default: true
  443. t.boolean :public, null: false, default: false
  444. t.string :block_ip, limit: 5000, null: true
  445. t.string :block_country, limit: 5000, null: true
  446. t.string :allowed_websites, limit: 5000, null: true
  447. t.string :preferences, limit: 5000, null: true
  448. t.integer :updated_by_id, null: false
  449. t.integer :created_by_id, null: false
  450. t.timestamps limit: 3, null: false
  451. end
  452. add_index :chats, [:name], unique: true
  453. add_foreign_key :chats, :users, column: :created_by_id
  454. add_foreign_key :chats, :users, column: :updated_by_id
  455. create_table :chat_sessions do |t|
  456. t.references :chat, null: false
  457. t.string :session_id, null: false
  458. t.string :name, limit: 250, null: true
  459. t.string :state, limit: 50, null: false, default: 'waiting' # running, closed
  460. t.references :user, null: true
  461. t.text :preferences, limit: 100.kilobytes + 1, null: true
  462. t.integer :updated_by_id, null: true
  463. t.integer :created_by_id, null: true
  464. t.timestamps limit: 3, null: false
  465. end
  466. add_index :chat_sessions, [:session_id]
  467. add_index :chat_sessions, [:state]
  468. add_index :chat_sessions, [:user_id]
  469. add_index :chat_sessions, [:chat_id]
  470. add_foreign_key :chat_sessions, :chats
  471. add_foreign_key :chat_sessions, :users
  472. add_foreign_key :chat_sessions, :users, column: :created_by_id
  473. add_foreign_key :chat_sessions, :users, column: :updated_by_id
  474. create_table :chat_messages do |t|
  475. t.references :chat_session, null: false
  476. t.text :content, limit: 20.megabytes + 1, null: false
  477. t.integer :created_by_id, null: true
  478. t.timestamps limit: 3, null: false
  479. end
  480. add_index :chat_messages, [:chat_session_id]
  481. add_foreign_key :chat_messages, :chat_sessions
  482. add_foreign_key :chat_messages, :users, column: :created_by_id
  483. create_table :chat_agents do |t|
  484. t.boolean :active, null: false, default: true
  485. t.integer :concurrent, null: false, default: 5
  486. t.integer :updated_by_id, null: false
  487. t.integer :created_by_id, null: false
  488. t.timestamps limit: 3, null: false
  489. end
  490. add_index :chat_agents, [:active]
  491. add_index :chat_agents, [:updated_by_id], unique: true
  492. add_index :chat_agents, [:created_by_id], unique: true
  493. add_foreign_key :chat_agents, :users, column: :created_by_id
  494. add_foreign_key :chat_agents, :users, column: :updated_by_id
  495. create_table :report_profiles do |t|
  496. t.column :name, :string, limit: 150, null: true
  497. t.column :condition, :text, limit: 500.kilobytes + 1, null: true
  498. t.column :active, :boolean, null: false, default: true
  499. t.column :updated_by_id, :integer, null: false
  500. t.column :created_by_id, :integer, null: false
  501. t.timestamps limit: 3, null: false
  502. end
  503. add_index :report_profiles, [:name], unique: true
  504. add_foreign_key :report_profiles, :users, column: :created_by_id
  505. add_foreign_key :report_profiles, :users, column: :updated_by_id
  506. create_table :webhooks do |t|
  507. t.column :name, :string, limit: 250, null: false
  508. t.column :endpoint, :string, limit: 300, null: false
  509. t.column :signature_token, :string, limit: 200, null: true
  510. t.column :ssl_verify, :boolean, null: false, default: true
  511. t.column :basic_auth_username, :string, limit: 250, null: true
  512. t.column :basic_auth_password, :string, limit: 250, null: true
  513. t.column :note, :string, limit: 500, null: true
  514. t.column :active, :boolean, null: false, default: true
  515. t.column :updated_by_id, :integer, null: false
  516. t.column :created_by_id, :integer, null: false
  517. t.timestamps limit: 3, null: false
  518. end
  519. create_table :ticket_shared_draft_zooms do |t|
  520. t.references :ticket, null: false, foreign_key: { to_table: :tickets }
  521. t.text :new_article
  522. t.text :ticket_attributes
  523. t.column :created_by_id, :integer, null: false
  524. t.column :updated_by_id, :integer, null: false
  525. t.timestamps limit: 3
  526. end
  527. create_table :ticket_shared_draft_starts do |t|
  528. t.references :group, null: false, foreign_key: { to_table: :groups }
  529. t.string :name
  530. t.text :content
  531. t.column :created_by_id, :integer, null: false
  532. t.column :updated_by_id, :integer, null: false
  533. t.timestamps limit: 3
  534. end
  535. end
  536. def self.down
  537. drop_table :report_profiles
  538. drop_table :chat_sessions
  539. drop_table :chat_messages
  540. drop_table :chat_agents
  541. drop_table :chats
  542. drop_table :macros
  543. drop_table :slas
  544. drop_table :channels
  545. drop_table :templates_groups
  546. drop_table :templates
  547. drop_table :text_modules_groups
  548. drop_table :text_modules
  549. drop_table :postmaster_filters
  550. drop_table :triggers
  551. drop_table :links
  552. drop_table :link_types
  553. drop_table :link_objects
  554. drop_table :overviews
  555. drop_table :ticket_counters
  556. drop_table :ticket_time_accounting
  557. drop_table :ticket_article_flags
  558. drop_table :ticket_articles
  559. drop_table :ticket_article_types
  560. drop_table :ticket_article_senders
  561. drop_table :ticket_flags
  562. drop_table :tickets
  563. drop_table :ticket_priorities
  564. drop_table :ticket_states
  565. drop_table :ticket_state_types
  566. drop_table :webhooks
  567. drop_table :ticket_shared_draft_zooms
  568. drop_table :ticket_shared_draft_starts
  569. end
  570. end