database.constants.inc.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356
  1. <?php
  2. /* For licensing terms, see /license.txt */
  3. /**
  4. * This is the database constants definition for Chamilo
  5. * This file is called by database.lib.php and database.mysqli.lib.php
  6. *
  7. * @todo the table constants have all to start with TABLE_
  8. * This is because of the analogy with the tool constants TOOL_
  9. *
  10. * @package chamilo.library
  11. */
  12. /**
  13. * CONSTANTS
  14. */
  15. //See #3910 defines the default prefix for the single course database
  16. // Modified by hubert.borderiou 2011-10-21 Add course category
  17. define('DB_COURSE_PREFIX', 'c_');
  18. // Main database tables
  19. define('TABLE_MAIN_COURSE', 'course');
  20. define('TABLE_MAIN_USER', 'user');
  21. define('TABLE_MAIN_CLASS', 'class');
  22. define('TABLE_MAIN_ADMIN', 'admin');
  23. define('TABLE_MAIN_COURSE_CLASS', 'course_rel_class');
  24. define('TABLE_MAIN_COURSE_USER', 'course_rel_user');
  25. define('TABLE_MAIN_CLASS_USER', 'class_user');
  26. define('TABLE_MAIN_CATEGORY', 'course_category');
  27. define('TABLE_MAIN_COURSE_MODULE', 'course_module');
  28. define('TABLE_MAIN_SYSTEM_ANNOUNCEMENTS', 'sys_announcement');
  29. define('TABLE_MAIN_SYSTEM_ANNOUNCEMENTS_GROUPS', 'announcement_rel_group');
  30. define('TABLE_MAIN_LANGUAGE', 'language');
  31. define('TABLE_MAIN_SETTINGS_OPTIONS', 'settings_options');
  32. define('TABLE_MAIN_SETTINGS_CURRENT', 'settings_current');
  33. define('TABLE_MAIN_SESSION', 'session');
  34. define('TABLE_MAIN_SESSION_CATEGORY', 'session_category');
  35. define('TABLE_MAIN_SESSION_COURSE', 'session_rel_course');
  36. define('TABLE_MAIN_SESSION_USER', 'session_rel_user');
  37. define('TABLE_MAIN_SESSION_CLASS', 'session_rel_class');
  38. define('TABLE_MAIN_SESSION_COURSE_USER', 'session_rel_course_rel_user');
  39. define('TABLE_MAIN_SHARED_SURVEY', 'shared_survey');
  40. define('TABLE_MAIN_SHARED_SURVEY_QUESTION', 'shared_survey_question');
  41. define('TABLE_MAIN_SHARED_SURVEY_QUESTION_OPTION', 'shared_survey_question_option');
  42. define('TABLE_MAIN_TEMPLATES', 'templates');
  43. define('TABLE_MAIN_SYSTEM_TEMPLATE', 'system_template');
  44. define('TABLE_MAIN_OPENID_ASSOCIATION', 'openid_association');
  45. define('TABLE_MAIN_COURSE_REQUEST', 'course_request');
  46. // Gradebook
  47. define('TABLE_MAIN_GRADEBOOK_CATEGORY', 'gradebook_category');
  48. define('TABLE_MAIN_GRADEBOOK_EVALUATION', 'gradebook_evaluation');
  49. define('TABLE_MAIN_GRADEBOOK_EVALUATION_TYPE', 'gradebook_evaluation_type');
  50. define('TABLE_MAIN_GRADEBOOK_LINKEVAL_LOG', 'gradebook_linkeval_log');
  51. define('TABLE_MAIN_GRADEBOOK_RESULT', 'gradebook_result');
  52. define('TABLE_MAIN_GRADEBOOK_RESULT_LOG', 'gradebook_result_log');
  53. define('TABLE_MAIN_GRADEBOOK_LINK', 'gradebook_link');
  54. define('TABLE_MAIN_GRADEBOOK_SCORE_DISPLAY','gradebook_score_display');
  55. define('TABLE_MAIN_GRADEBOOK_CERTIFICATE', 'gradebook_certificate');
  56. //Profiling
  57. define('TABLE_MAIN_USER_FIELD', 'user_field');
  58. define('TABLE_MAIN_USER_FIELD_OPTIONS', 'user_field_options');
  59. define('TABLE_MAIN_USER_FIELD_VALUES', 'user_field_values');
  60. //User tags
  61. define('TABLE_MAIN_TAG', 'tag');
  62. define('TABLE_MAIN_USER_REL_TAG', 'user_rel_tag');
  63. // Search engine
  64. define('TABLE_MAIN_SPECIFIC_FIELD', 'specific_field');
  65. define('TABLE_MAIN_SPECIFIC_FIELD_VALUES', 'specific_field_values');
  66. define('TABLE_MAIN_SEARCH_ENGINE_REF', 'search_engine_ref');
  67. // Access URLs
  68. define('TABLE_MAIN_ACCESS_URL', 'access_url');
  69. define('TABLE_MAIN_ACCESS_URL_REL_USER', 'access_url_rel_user');
  70. define('TABLE_MAIN_ACCESS_URL_REL_COURSE', 'access_url_rel_course');
  71. define('TABLE_MAIN_ACCESS_URL_REL_SESSION', 'access_url_rel_session');
  72. // Global calendar
  73. define('TABLE_MAIN_SYSTEM_CALENDAR', 'sys_calendar');
  74. // Reservation System
  75. define('TABLE_MAIN_RESERVATION_ITEM', 'reservation_item');
  76. define('TABLE_MAIN_RESERVATION_RESERVATION', 'reservation_main');
  77. define('TABLE_MAIN_RESERVATION_SUBSCRIBTION', 'reservation_subscription');
  78. define('TABLE_MAIN_RESERVATION_CATEGORY', 'reservation_category');
  79. define('TABLE_MAIN_RESERVATION_ITEM_RIGHTS', 'reservation_item_rights');
  80. // Social networking
  81. define('TABLE_MAIN_USER_REL_USER', 'user_rel_user');
  82. define('TABLE_MAIN_USER_FRIEND_RELATION_TYPE', 'user_friend_relation_type');
  83. // Web services
  84. define('TABLE_MAIN_USER_API_KEY', 'user_api_key');
  85. //Extra fields
  86. define('TABLE_MAIN_COURSE_FIELD', 'course_field');
  87. define('TABLE_MAIN_COURSE_FIELD_OPTIONS', 'course_field_options');
  88. define('TABLE_MAIN_COURSE_FIELD_VALUES', 'course_field_values');
  89. define('TABLE_MAIN_SESSION_FIELD', 'session_field');
  90. define('TABLE_MAIN_SESSION_FIELD_OPTIONS', 'session_field_options');
  91. define('TABLE_MAIN_SESSION_FIELD_VALUES', 'session_field_values');
  92. define('TABLE_MAIN_QUESTION_FIELD', 'question_field');
  93. define('TABLE_MAIN_QUESTION_FIELD_OPTIONS', 'question_field_options');
  94. define('TABLE_MAIN_QUESTION_FIELD_VALUES', 'question_field_values');
  95. // Message
  96. define('TABLE_MAIN_MESSAGE', 'message');
  97. // Term and conditions
  98. define('TABLE_MAIN_LEGAL', 'legal');
  99. // Dashboard blocks plugin
  100. define('TABLE_MAIN_BLOCK', 'block');
  101. // Statistic database tables
  102. define('TABLE_STATISTIC_TRACK_E_LASTACCESS', 'track_e_lastaccess');
  103. define('TABLE_STATISTIC_TRACK_E_ACCESS', 'track_e_access');
  104. define('TABLE_STATISTIC_TRACK_E_LOGIN', 'track_e_login');
  105. define('TABLE_STATISTIC_TRACK_E_DOWNLOADS', 'track_e_downloads');
  106. define('TABLE_STATISTIC_TRACK_E_LINKS', 'track_e_links');
  107. define('TABLE_STATISTIC_TRACK_E_ONLINE', 'track_e_online');
  108. define('TABLE_STATISTIC_TRACK_E_HOTPOTATOES', 'track_e_hotpotatoes');
  109. define('TABLE_STATISTIC_TRACK_E_COURSE_ACCESS', 'track_e_course_access');
  110. define('TABLE_STATISTIC_TRACK_E_EXERCICES', 'track_e_exercices');
  111. define('TABLE_STATISTIC_TRACK_E_ATTEMPT', 'track_e_attempt');
  112. define('TABLE_STATISTIC_TRACK_E_ATTEMPT_RECORDING', 'track_e_attempt_recording');
  113. define('TABLE_STATISTIC_TRACK_E_DEFAULT', 'track_e_default');
  114. define('TABLE_STATISTIC_TRACK_E_UPLOADS', 'track_e_uploads');
  115. define('TABLE_STATISTIC_TRACK_E_HOTSPOT', 'track_e_hotspot');
  116. define('TABLE_STATISTIC_TRACK_E_ITEM_PROPERTY', 'track_e_item_property');
  117. define('TABLE_STATISTIC_TRACK_FILTERED_TERMS', 'track_filtered_terms');
  118. //Course catalog stats see #4191
  119. define('TABLE_STATISTIC_TRACK_COURSE_RANKING', 'track_course_ranking');
  120. define('TABLE_MAIN_USER_REL_COURSE_VOTE', 'user_rel_course_vote');
  121. // SCORM database tables this is used only during the migration from 1.6 to 1.8 see update-db-scorm-1.6.x-1.8.0.inc
  122. define('TABLE_SCORM_MAIN', 'scorm_main');
  123. define('TABLE_SCORM_SCO_DATA', 'scorm_sco_data');
  124. // Course tables
  125. define('TABLE_AGENDA', 'calendar_event');
  126. define('TABLE_AGENDA_REPEAT', 'calendar_event_repeat');
  127. define('TABLE_AGENDA_REPEAT_NOT', 'calendar_event_repeat_not');
  128. define('TABLE_AGENDA_ATTACHMENT', 'calendar_event_attachment');
  129. define('TABLE_ANNOUNCEMENT', 'announcement');
  130. define('TABLE_ANNOUNCEMENT_ATTACHMENT', 'announcement_attachment');
  131. define('TABLE_CHAT_CONNECTED', 'chat_connected');
  132. define('TABLE_COURSE_DESCRIPTION', 'course_description');
  133. define('TABLE_DOCUMENT', 'document');
  134. define('TABLE_ITEM_PROPERTY', 'item_property');
  135. define('TABLE_LINK', 'link');
  136. define('TABLE_LINK_CATEGORY', 'link_category');
  137. define('TABLE_TOOL_LIST', 'tool');
  138. define('TABLE_TOOL_INTRO', 'tool_intro');
  139. define('TABLE_SCORMDOC', 'scormdocument');
  140. define('TABLE_STUDENT_PUBLICATION', 'student_publication');
  141. define('TABLE_STUDENT_PUBLICATION_ASSIGNMENT', 'student_publication_assignment');
  142. // Course forum tables
  143. define('TABLE_FORUM_CATEGORY', 'forum_category');
  144. define('TABLE_FORUM', 'forum_forum');
  145. define('TABLE_FORUM_THREAD', 'forum_thread');
  146. define('TABLE_FORUM_POST', 'forum_post');
  147. define('TABLE_FORUM_ATTACHMENT', 'forum_attachment');
  148. define('TABLE_FORUM_MAIL_QUEUE', 'forum_mailcue');
  149. define('TABLE_FORUM_THREAD_QUALIFY', 'forum_thread_qualify');
  150. define('TABLE_FORUM_THREAD_QUALIFY_LOG', 'forum_thread_qualify_log');
  151. define('TABLE_FORUM_NOTIFICATION', 'forum_notification');
  152. // Course group tables
  153. define('TABLE_GROUP', 'group_info');
  154. define('TABLE_GROUP_USER', 'group_rel_user');
  155. define('TABLE_GROUP_TUTOR', 'group_rel_tutor');
  156. define('TABLE_GROUP_CATEGORY', 'group_category');
  157. // Course dropbox tables
  158. define('TABLE_DROPBOX_CATEGORY','dropbox_category');
  159. define('TABLE_DROPBOX_FEEDBACK','dropbox_feedback');
  160. define('TABLE_DROPBOX_POST', 'dropbox_post');
  161. define('TABLE_DROPBOX_FILE', 'dropbox_file');
  162. define('TABLE_DROPBOX_PERSON', 'dropbox_person');
  163. // Course quiz (or test, or exercise) tables
  164. define('TABLE_QUIZ_QUESTION', 'quiz_question');
  165. define('TABLE_QUIZ_TEST', 'quiz');
  166. define('TABLE_QUIZ_ORDER', 'quiz_order');
  167. define('TABLE_QUIZ_ANSWER', 'quiz_answer');
  168. define('TABLE_QUIZ_TEST_QUESTION', 'quiz_rel_question');
  169. define('TABLE_QUIZ_QUESTION_OPTION', 'quiz_question_option');
  170. define('TABLE_QUIZ_CATEGORY', 'quiz_category');
  171. define('TABLE_QUIZ_QUESTION_REL_CATEGORY', 'quiz_question_rel_category');
  172. define('TABLE_QUIZ_REL_CATEGORY', 'quiz_rel_category');
  173. // Linked resource table
  174. //@todo table exists?
  175. define('TABLE_LINKED_RESOURCES', 'resource');
  176. // New SCORM tables
  177. define('TABLE_LP_MAIN', 'lp');
  178. define('TABLE_LP_CATEGORY', 'lp_category');
  179. define('TABLE_LP_ITEM', 'lp_item');
  180. define('TABLE_LP_VIEW', 'lp_view');
  181. define('TABLE_LP_ITEM_VIEW', 'lp_item_view');
  182. define('TABLE_LP_IV_INTERACTION', 'lp_iv_interaction'); // IV = Item View
  183. define('TABLE_LP_IV_OBJECTIVE', 'lp_iv_objective'); // IV = Item View
  184. // Smartblogs (Kevin Van Den Haute::kevin@develop-it.be)
  185. // Permission tables
  186. define('TABLE_PERMISSION_USER', 'permission_user');
  187. define('TABLE_PERMISSION_TASK', 'permission_task');
  188. define('TABLE_PERMISSION_GROUP', 'permission_group');
  189. // Role tables
  190. define('TABLE_ROLE', 'roles');
  191. define('TABLE_ROLE_PERMISSION', 'role_permissions');
  192. define('TABLE_ROLE_USER', 'users_roles');
  193. define('TABLE_ROLE_GROUP', 'role_group');
  194. // Blog tables
  195. define('TABLE_BLOGS', 'blog');
  196. define('TABLE_BLOGS_POSTS', 'blog_post');
  197. define('TABLE_BLOGS_COMMENTS', 'blog_comment');
  198. define('TABLE_BLOGS_REL_USER', 'blog_rel_user');
  199. define('TABLE_BLOGS_TASKS', 'blog_task');
  200. define('TABLE_BLOGS_TASKS_REL_USER', 'blog_task_rel_user');
  201. define('TABLE_BLOGS_RATING', 'blog_rating');
  202. define('TABLE_BLOGS_ATTACHMENT', 'blog_attachment');
  203. define('TABLE_BLOGS_TASKS_PERMISSIONS', 'permission_task');
  204. //end of Smartblogs
  205. // User information tables
  206. define('TABLE_USER_INFO', 'userinfo_def');
  207. define('TABLE_USER_INFO_CONTENT', 'userinfo_content');
  208. // Course settings table
  209. define('TABLE_COURSE_SETTING', 'course_setting');
  210. // Course online tables
  211. define('TABLE_ONLINE_LINK', 'online_link');
  212. define('TABLE_ONLINE_CONNECTED','online_connected');
  213. // User database
  214. define('TABLE_PERSONAL_AGENDA', 'personal_agenda');
  215. define('TABLE_PERSONAL_AGENDA_REPEAT', 'personal_agenda_repeat');
  216. define('TABLE_PERSONAL_AGENDA_REPEAT_NOT', 'personal_agenda_repeat_not');
  217. define('TABLE_USER_COURSE_CATEGORY', 'user_course_category');
  218. // Survey
  219. // @TODO: Are these MAIN tables or course tables?
  220. // @TODO: Probably these constants are obsolete.
  221. define('TABLE_MAIN_SURVEY', 'survey');
  222. define('TABLE_MAIN_SURVEYQUESTION', 'questions');
  223. // Survey
  224. define('TABLE_SURVEY', 'survey');
  225. define('TABLE_SURVEY_QUESTION', 'survey_question');
  226. define('TABLE_SURVEY_QUESTION_OPTION', 'survey_question_option');
  227. define('TABLE_SURVEY_INVITATION', 'survey_invitation');
  228. define('TABLE_SURVEY_ANSWER', 'survey_answer');
  229. define('TABLE_SURVEY_QUESTION_GROUP', 'survey_group');
  230. define('TABLE_SURVEY_REPORT', 'survey_report');
  231. // Wiki tables
  232. define('TABLE_WIKI', 'wiki');
  233. define('TABLE_WIKI_CONF', 'wiki_conf');
  234. define('TABLE_WIKI_DISCUSS', 'wiki_discuss');
  235. define('TABLE_WIKI_MAILCUE', 'wiki_mailcue');
  236. // Glossary
  237. define('TABLE_GLOSSARY', 'glossary');
  238. // Notebook
  239. define('TABLE_NOTEBOOK', 'notebook');
  240. // Message
  241. define('TABLE_MESSAGE', 'message');
  242. define('TABLE_MESSAGE_ATTACHMENT', 'message_attachment');
  243. // Metadata
  244. define('TABLE_METADATA', 'metadata');
  245. // Attendance Sheet
  246. define('TABLE_ATTENDANCE', 'attendance');
  247. define('TABLE_ATTENDANCE_CALENDAR', 'attendance_calendar');
  248. define('TABLE_ATTENDANCE_SHEET_LOG','attendance_sheet_log');
  249. define('TABLE_ATTENDANCE_SHEET', 'attendance_sheet');
  250. define('TABLE_ATTENDANCE_RESULT', 'attendance_result');
  251. // Thematic
  252. define('TABLE_THEMATIC','thematic');
  253. define('TABLE_THEMATIC_PLAN', 'thematic_plan');
  254. define('TABLE_THEMATIC_ADVANCE','thematic_advance');
  255. //User groups
  256. //Needed for migration
  257. define('TABLE_MAIN_GROUP', 'groups');
  258. /*
  259. define('TABLE_MAIN_USER_REL_GROUP', 'group_rel_user');
  260. define('TABLE_MAIN_GROUP_REL_TAG', 'group_rel_tag');
  261. define('TABLE_MAIN_GROUP_REL_GROUP', 'group_rel_group');
  262. */
  263. // Careers, promotions, Usergroups
  264. define('TABLE_CAREER', 'career');
  265. define('TABLE_PROMOTION', 'promotion');
  266. define('TABLE_USERGROUP', 'usergroup');
  267. define('TABLE_USERGROUP_REL_USER', 'usergroup_rel_user');
  268. define('TABLE_USERGROUP_REL_COURSE', 'usergroup_rel_course');
  269. define('TABLE_USERGROUP_REL_SESSION', 'usergroup_rel_session');
  270. define('TABLE_USERGROUP_REL_TAG', 'usergroup_rel_tag');
  271. define('TABLE_USERGROUP_REL_USERGROUP', 'usergroup_rel_usergroup');
  272. // Mail notifications
  273. define('TABLE_NOTIFICATION', 'notification');
  274. //Storage api tables
  275. define('TABLE_TRACK_STORED_VALUES', 'track_stored_values');
  276. define('TABLE_TRACK_STORED_VALUES_STACK', 'track_stored_values_stack');
  277. //Event tables
  278. define('TABLE_EVENT_EMAIL_TEMPLATE', 'event_email_template');
  279. define('TABLE_EVENT_TYPE_REL_USER', 'user_rel_event_type');
  280. define('TABLE_EVENT_SENT', 'event_sent');
  281. define('TABLE_MAIN_SKILL', 'skill');
  282. define('TABLE_MAIN_SKILL_REL_SKILL', 'skill_rel_skill');
  283. define('TABLE_MAIN_SKILL_REL_GRADEBOOK', 'skill_rel_gradebook');
  284. define('TABLE_MAIN_SKILL_REL_USER', 'skill_rel_user');
  285. define('TABLE_MAIN_SKILL_PROFILE', 'skill_profile');
  286. define('TABLE_MAIN_SKILL_REL_PROFILE', 'skill_rel_profile');
  287. define('TABLE_MAIN_CHAT', 'chat');
  288. define('TABLE_TIMELINE', 'timeline');
  289. //Gradebook model
  290. define('TABLE_GRADE_MODEL', 'grade_model');
  291. define('TABLE_GRADE_MODEL_COMPONENTS', 'grade_components');
  292. // Transaction related tables
  293. define('TABLE_BRANCH_REL_SESSION', 'branch_rel_session');
  294. define('TABLE_BRANCH_SYNC', 'branch_sync');
  295. define('TABLE_BRANCH_TRANSACTION', 'branch_transaction');
  296. define('TABLE_BRANCH_TRANSACTION_STATUS', 'branch_transaction_status');
  297. define('TABLE_BRANCH_TRANSACTION_DATA', 'branch_transaction_data');
  298. define('TABLE_BRANCH_TRANSACTION_LOG', 'branch_transaction_log');
  299. define('TABLE_RECEIVED_ENVELOPES', 'received_envelopes');