wagn 1.13.0 → 1.14.0.pre1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (459) hide show
  1. checksums.yaml +4 -4
  2. data/Guardfile +3 -2
  3. data/VERSION +1 -1
  4. data/app/controllers/card_controller.rb +33 -38
  5. data/config/routes.rb +2 -2
  6. data/config/version.txt +1 -1
  7. data/db/bootstrap/card_actions.yml +3543 -0
  8. data/db/bootstrap/card_acts.yml +7 -0
  9. data/db/bootstrap/card_changes.yml +9150 -0
  10. data/db/bootstrap/card_references.yml +666 -344
  11. data/db/bootstrap/cards.yml +3256 -1702
  12. data/db/migrate/20140822073704_create_new_revision_tables.rb +43 -0
  13. data/db/migrate/20141001105348_move_revisions_to_actions.rb +62 -0
  14. data/db/migrate_cards/20130411191151_renaming_for_menu.rb +42 -45
  15. data/db/migrate_cards/20130411211600_delete_old_related_tab_cards.rb +13 -16
  16. data/db/migrate_cards/20130419215612_import_help_text.rb +7 -10
  17. data/db/migrate_cards/20130823192433_add_style_cards.rb +77 -81
  18. data/db/migrate_cards/20130910183318_move_styles_to_content.rb +4 -7
  19. data/db/migrate_cards/20130920214038_jsonize_tinymce.rb +9 -12
  20. data/db/migrate_cards/20130920291703_update_stylesheets.rb +10 -13
  21. data/db/migrate_cards/20130927191728_account_events.rb +15 -18
  22. data/db/migrate_cards/20131016172445_common_css_patch.rb +5 -8
  23. data/db/migrate_cards/20140110193325_reset_account_request_type.rb +4 -7
  24. data/db/migrate_cards/20140307231621_user_data_to_cards.rb +50 -53
  25. data/db/migrate_cards/20140317035504_account_requests_to_signups.rb +39 -42
  26. data/db/migrate_cards/20140512155840_add_script_cards.rb +56 -59
  27. data/db/migrate_cards/20140629222005_add_email_cards.rb +168 -0
  28. data/db/migrate_cards/20140725180118_config_card_updates.rb +4 -7
  29. data/db/migrate_cards/data/mailer/follower_notification_email.html +9 -0
  30. data/db/migrate_cards/data/mailer/follower_notification_email.txt +11 -0
  31. data/db/migrate_cards/data/mailer/mail_config.json +22 -0
  32. data/db/migrate_cards/data/mailer/password_reset_email.html +10 -0
  33. data/db/migrate_cards/data/mailer/password_reset_email.txt +11 -0
  34. data/db/migrate_cards/data/mailer/signup_alert_email.html +7 -0
  35. data/db/migrate_cards/data/mailer/signup_alert_email.txt +5 -0
  36. data/db/migrate_cards/data/mailer/verification_email.html +9 -0
  37. data/db/migrate_cards/data/mailer/verification_email.txt +8 -0
  38. data/db/schema.rb +31 -1
  39. data/features/conflict.feature +39 -0
  40. data/features/flexmail.feature +54 -54
  41. data/features/notifications.feature +4 -2
  42. data/features/reset_password.feature +1 -1
  43. data/features/step_definitions/wagn_steps.rb +20 -2
  44. data/features/step_definitions/window_steps.rb +23 -0
  45. data/features/support/env.rb +1 -0
  46. data/features/update_includers.feature +16 -10
  47. data/features/watch.feature +2 -2
  48. data/lib/card.rb +11 -10
  49. data/lib/card/act.rb +63 -0
  50. data/lib/card/action.rb +194 -0
  51. data/lib/card/change.rb +29 -0
  52. data/lib/card/content.rb +1 -1
  53. data/lib/card/diff.rb +229 -276
  54. data/lib/card/env.rb +4 -3
  55. data/lib/card/format.rb +2 -5
  56. data/lib/card/generators/card_migration/USAGE +15 -3
  57. data/lib/card/generators/card_migration/card_migration_generator.rb +22 -2
  58. data/lib/card/generators/card_migration/templates/card_migration.erb +4 -5
  59. data/lib/card/generators/format/USAGE +2 -2
  60. data/lib/card/generators/format/format_generator.rb +2 -2
  61. data/lib/card/generators/set/USAGE +2 -2
  62. data/lib/card/mailer.rb +21 -100
  63. data/lib/card/name.rb +4 -3
  64. data/lib/card/query.rb +2 -2
  65. data/lib/card/query/card_spec.rb +20 -30
  66. data/lib/card/query/value_spec.rb +2 -3
  67. data/lib/card/set.rb +3 -0
  68. data/lib/wagn/all.rb +6 -0
  69. data/lib/wagn/application.rb +16 -6
  70. data/lib/wagn/commands.rb +87 -27
  71. data/lib/wagn/config/environments/development.rb +17 -0
  72. data/lib/wagn/config/environments/test.rb +14 -1
  73. data/lib/wagn/config/initializers/airbrake.rb +1 -1
  74. data/lib/wagn/generators/wagn/templates/Gemfile +27 -9
  75. data/lib/wagn/generators/wagn/templates/config/application.rb +12 -3
  76. data/lib/wagn/generators/wagn/templates/simplecov +5 -0
  77. data/lib/wagn/generators/wagn/templates/spec/spec_helper.rb +1 -0
  78. data/lib/wagn/generators/wagn/wagn_generator.rb +75 -45
  79. data/lib/wagn/location.rb +9 -0
  80. data/lib/wagn/migration.rb +96 -0
  81. data/lib/wagn/mods_spec_helper.rb +16 -8
  82. data/lib/wagn/simplecov_helper.rb +61 -0
  83. data/lib/wagn/{wagn_spec_helper.rb → spec_helper.rb} +11 -3
  84. data/lib/wagn/tasks/test.rake +1 -1
  85. data/lib/wagn/tasks/wagn.rake +100 -34
  86. data/lib/wagn/version.rb +7 -2
  87. data/mod/{core → 01_core}/chunk/include.rb +0 -0
  88. data/mod/{core → 01_core}/chunk/link.rb +0 -0
  89. data/mod/{core → 01_core}/chunk/literal.rb +0 -0
  90. data/mod/{core → 01_core}/chunk/reference.rb +15 -3
  91. data/mod/{core → 01_core}/chunk/uri.rb +0 -0
  92. data/mod/{core → 01_core}/format/data_format.rb +0 -0
  93. data/mod/{core → 01_core}/format/html_format.rb +5 -2
  94. data/mod/{core → 01_core}/format/text_format.rb +0 -0
  95. data/mod/{core → 01_core}/layout/blank.html +0 -0
  96. data/mod/{core → 01_core}/layout/default.html +0 -0
  97. data/mod/{core → 01_core}/layout/noside.html +0 -0
  98. data/mod/{core → 01_core}/layout/pre.html +0 -0
  99. data/mod/{core → 01_core}/layout/simple.html +0 -0
  100. data/mod/{core → 01_core}/set/all/active_card.rb +0 -0
  101. data/mod/{core → 01_core}/set/all/collection.rb +33 -5
  102. data/mod/01_core/set/all/content.rb +144 -0
  103. data/mod/01_core/set/all/erb.rb +11 -0
  104. data/mod/{core → 01_core}/set/all/fetch.rb +8 -1
  105. data/mod/01_core/set/all/haml.rb +7 -0
  106. data/mod/{core → 01_core}/set/all/initialize.rb +4 -2
  107. data/mod/{core → 01_core}/set/all/name.rb +2 -3
  108. data/mod/01_core/set/all/notify.rb +215 -0
  109. data/mod/{core → 01_core}/set/all/pattern.rb +0 -0
  110. data/mod/{core → 01_core}/set/all/permissions.rb +1 -1
  111. data/mod/{core → 01_core}/set/all/phases.rb +24 -8
  112. data/mod/{core → 01_core}/set/all/references.rb +2 -2
  113. data/mod/{core → 01_core}/set/all/rules.rb +2 -2
  114. data/mod/{core → 01_core}/set/all/states.rb +1 -1
  115. data/mod/{core → 01_core}/set/all/templating.rb +4 -4
  116. data/mod/{core → 01_core}/set/all/tracked_attributes.rb +15 -64
  117. data/mod/{core → 01_core}/set/all/trash.rb +6 -5
  118. data/mod/{core → 01_core}/set/all/type.rb +0 -0
  119. data/mod/{core → 01_core}/set/all/utils.rb +1 -1
  120. data/mod/{core → 01_core}/set_pattern/01_all.rb +0 -0
  121. data/mod/{core → 01_core}/set_pattern/02_all_plus.rb +0 -0
  122. data/mod/{core → 01_core}/set_pattern/03_type.rb +0 -0
  123. data/mod/{core → 01_core}/set_pattern/04_star.rb +0 -0
  124. data/mod/{core → 01_core}/set_pattern/05_rstar.rb +0 -0
  125. data/mod/{core → 01_core}/set_pattern/06_right.rb +0 -0
  126. data/mod/{core → 01_core}/set_pattern/07_type_plus_right.rb +0 -0
  127. data/mod/{core → 01_core}/set_pattern/08_self.rb +0 -0
  128. data/mod/01_core/spec/chunk/literal_spec.rb +14 -0
  129. data/{spec/mod/core → mod/01_core/spec}/chunk/uri_spec.rb +3 -3
  130. data/{spec/mod/core → mod/01_core/spec}/format/data_format_spec.rb +0 -0
  131. data/{spec/mod/core → mod/01_core/spec}/format/html_format_spec.rb +9 -8
  132. data/{spec/mod/core → mod/01_core/spec}/format/text_format_spec.rb +0 -0
  133. data/{spec/mod/core → mod/01_core/spec}/set/all/active_card_spec.rb +0 -0
  134. data/mod/01_core/spec/set/all/attribute_tracking_spec.rb +21 -0
  135. data/mod/01_core/spec/set/all/collection_spec.rb +65 -0
  136. data/mod/01_core/spec/set/all/content_spec.rb +15 -0
  137. data/{spec/mod/core → mod/01_core/spec}/set/all/fetch_spec.rb +70 -68
  138. data/{spec/mod/core → mod/01_core/spec}/set/all/initialize_spec.rb +12 -12
  139. data/{spec/mod/core → mod/01_core/spec}/set/all/name_spec.rb +7 -7
  140. data/mod/01_core/spec/set/all/notify_spec.rb +199 -0
  141. data/{spec/mod/core → mod/01_core/spec}/set/all/pattern_spec.rb +16 -16
  142. data/{spec/mod/core → mod/01_core/spec}/set/all/permissions_spec.rb +62 -62
  143. data/{spec/mod/core → mod/01_core/spec}/set/all/phases_spec.rb +0 -0
  144. data/{spec/mod/core → mod/01_core/spec}/set/all/references_spec.rb +1 -1
  145. data/{spec/mod/core → mod/01_core/spec}/set/all/rules2_spec.rb +57 -57
  146. data/mod/01_core/spec/set/all/rules_spec.rb +81 -0
  147. data/{spec/mod/core → mod/01_core/spec}/set/all/states_spec.rb +0 -0
  148. data/{spec/mod/core → mod/01_core/spec}/set/all/templating_spec.rb +16 -12
  149. data/{spec/mod/core → mod/01_core/spec}/set/all/tracked_attributes_spec.rb +24 -22
  150. data/{spec/mod/core → mod/01_core/spec}/set/all/trash_spec.rb +2 -2
  151. data/{spec/mod/core → mod/01_core/spec}/set/all/type_spec.rb +13 -13
  152. data/{spec/mod/core → mod/01_core/spec}/set/all/utils_spec.rb +0 -0
  153. data/mod/{core → 02_basic_types}/set/type/plain_text.rb +0 -0
  154. data/mod/{standard → 02_basic_types}/set/type/pointer.rb +21 -8
  155. data/{spec/mod/standard/set/type → mod/02_basic_types/spec/set}/plain_text_spec.rb +0 -0
  156. data/{spec/mod/standard/set/type → mod/02_basic_types/spec/set}/pointer_spec.rb +22 -9
  157. data/mod/{standard → 03_machines}/lib/card/machine.rb +3 -2
  158. data/mod/{standard → 03_machines}/lib/card/machine_input.rb +1 -1
  159. data/mod/{standard → 03_machines}/lib/javascript/html5shiv-printshiv.js +0 -0
  160. data/mod/{standard → 03_machines}/lib/javascript/jquery-ui.js +0 -0
  161. data/mod/{standard → 03_machines}/lib/javascript/jquery.autosize.js +0 -0
  162. data/mod/{standard → 03_machines}/lib/javascript/jquery.fileupload.js +0 -0
  163. data/mod/{standard → 03_machines}/lib/javascript/jquery.iframe-transport.js +0 -0
  164. data/mod/{standard → 03_machines}/lib/javascript/jquery.js +0 -0
  165. data/mod/{standard → 03_machines}/lib/javascript/jquery.ui.autocomplete.html.js +0 -0
  166. data/mod/{standard → 03_machines}/lib/javascript/jquery_ujs.js +0 -0
  167. data/mod/{standard → 03_machines}/lib/javascript/jquerymobile.js +0 -0
  168. data/mod/{standard → 03_machines}/lib/javascript/tinymce.js +0 -0
  169. data/mod/{standard → 03_machines}/lib/javascript/wagn.js.coffee +17 -9
  170. data/mod/{standard → 03_machines}/lib/javascript/wagn_menu.js +0 -0
  171. data/mod/{standard → 03_machines}/lib/javascript/wagn_mod.js.coffee +1 -1
  172. data/mod/{standard → 03_machines}/lib/stylesheets/functional.scss +1 -1
  173. data/mod/{standard → 03_machines}/lib/stylesheets/jquery-ui-smoothness.css +0 -0
  174. data/mod/{standard → 03_machines}/lib/stylesheets/standard.scss +126 -21
  175. data/mod/{standard → 03_machines}/set/right/machine_output.rb +3 -2
  176. data/mod/{standard → 03_machines}/set/self/script_card_menu.rb +1 -1
  177. data/mod/{standard → 03_machines}/set/self/script_html5shiv_printshiv.rb +1 -1
  178. data/mod/{standard → 03_machines}/set/self/script_jquery.rb +1 -1
  179. data/mod/{standard → 03_machines}/set/self/script_jquery_helper.rb +1 -1
  180. data/mod/{standard → 03_machines}/set/self/script_slot.rb +1 -1
  181. data/mod/{standard → 03_machines}/set/self/script_tinymce.rb +1 -1
  182. data/mod/{standard → 03_machines}/set/self/style_functional.rb +1 -1
  183. data/mod/{standard → 03_machines}/set/self/style_jquery_ui_smoothness.rb +1 -1
  184. data/mod/{standard → 03_machines}/set/self/style_standard.rb +1 -1
  185. data/mod/{standard → 03_machines}/set/type/coffee_script.rb +0 -0
  186. data/mod/{standard → 03_machines}/set/type/css.rb +0 -0
  187. data/mod/{standard → 03_machines}/set/type/java_script.rb +0 -0
  188. data/mod/{standard → 03_machines}/set/type/scss.rb +0 -0
  189. data/mod/{standard → 03_machines}/set/type/skin.rb +0 -0
  190. data/{spec/mod/standard → mod/03_machines/spec}/lib/machine_input_spec.rb +0 -0
  191. data/{spec/mod/standard → mod/03_machines/spec}/lib/machine_spec.rb +4 -4
  192. data/{spec/mod/standard → mod/03_machines/spec}/set/right/machine_output_spec.rb +0 -0
  193. data/{spec/mod/standard → mod/03_machines/spec}/set/self/style_functional_spec.rb +0 -0
  194. data/{spec/mod/standard → mod/03_machines/spec}/set/self/style_jquery_ui_smoothness_spec.rb +0 -0
  195. data/{spec/mod/standard → mod/03_machines/spec}/set/self/style_standard_spec.rb +0 -0
  196. data/{spec/mod/standard → mod/03_machines/spec}/set/type/coffeescript_spec.rb +0 -0
  197. data/{spec/mod/standard → mod/03_machines/spec}/set/type/css_spec.rb +0 -0
  198. data/{spec/mod/standard → mod/03_machines/spec}/set/type/javascript_spec.rb +0 -0
  199. data/{spec/mod/standard → mod/03_machines/spec}/set/type/scss_spec.rb +1 -1
  200. data/{spec/mod/standard → mod/03_machines/spec}/set/type/skin_spec.rb +22 -0
  201. data/mod/04_settings/lib/card/setting.rb +57 -0
  202. data/mod/{core/set/right/structure.rb → 04_settings/set/right/add_help.rb} +0 -2
  203. data/mod/{standard → 04_settings}/set/right/comment.rb +0 -1
  204. data/mod/{standard → 04_settings}/set/right/create.rb +0 -1
  205. data/mod/04_settings/set/right/default.rb +3 -0
  206. data/mod/{standard → 04_settings}/set/right/delete.rb +2 -0
  207. data/mod/04_settings/set/right/help.rb +3 -0
  208. data/mod/{standard → 04_settings}/set/right/read.rb +0 -0
  209. data/mod/{standard → 04_settings}/set/right/script.rb +0 -0
  210. data/mod/04_settings/set/right/structure.rb +4 -0
  211. data/mod/{standard → 04_settings}/set/right/style.rb +0 -0
  212. data/mod/{standard → 04_settings}/set/right/update.rb +0 -0
  213. data/mod/04_settings/set/self/accountable.rb +2 -0
  214. data/mod/04_settings/set/self/add_help.rb +2 -0
  215. data/mod/04_settings/set/self/autoname.rb +2 -0
  216. data/mod/04_settings/set/self/captcha.rb +2 -0
  217. data/mod/04_settings/set/self/comment.rb +2 -0
  218. data/mod/04_settings/set/self/create.rb +2 -0
  219. data/mod/04_settings/set/self/default.rb +2 -0
  220. data/mod/04_settings/set/self/delete.rb +2 -0
  221. data/mod/04_settings/set/self/help.rb +2 -0
  222. data/mod/04_settings/set/self/input.rb +2 -0
  223. data/mod/04_settings/set/self/layout.rb +2 -0
  224. data/mod/04_settings/set/self/on_create.rb +2 -0
  225. data/mod/04_settings/set/self/on_delete.rb +2 -0
  226. data/mod/04_settings/set/self/on_update.rb +2 -0
  227. data/mod/04_settings/set/self/options.rb +2 -0
  228. data/mod/04_settings/set/self/options_label.rb +2 -0
  229. data/mod/04_settings/set/self/read.rb +2 -0
  230. data/mod/04_settings/set/self/script.rb +2 -0
  231. data/mod/04_settings/set/self/structure.rb +2 -0
  232. data/mod/04_settings/set/self/style.rb +2 -0
  233. data/mod/04_settings/set/self/table_of_contents.rb +2 -0
  234. data/mod/04_settings/set/self/thanks.rb +2 -0
  235. data/mod/04_settings/set/self/update.rb +2 -0
  236. data/mod/{standard → 04_settings}/set/type/setting.rb +8 -14
  237. data/{spec/mod/standard → mod/04_settings/spec}/set/right/add_help_spec.rb +0 -0
  238. data/{spec/mod/standard → mod/04_settings/spec}/set/right/comment_spec.rb +5 -5
  239. data/{spec/mod/standard → mod/04_settings/spec}/set/right/create_spec.rb +0 -0
  240. data/{spec/mod/standard → mod/04_settings/spec}/set/right/default_spec.rb +0 -0
  241. data/{spec/mod/standard → mod/04_settings/spec}/set/right/delete_spec.rb +0 -0
  242. data/{spec/mod/standard → mod/04_settings/spec}/set/right/help_spec.rb +0 -0
  243. data/{spec/mod/standard → mod/04_settings/spec}/set/right/read_spec.rb +0 -0
  244. data/{spec/mod/standard → mod/04_settings/spec}/set/right/script_spec.rb +0 -0
  245. data/{spec/mod/standard → mod/04_settings/spec}/set/right/structure_spec.rb +4 -2
  246. data/{spec/mod/standard → mod/04_settings/spec}/set/right/style_spec.rb +1 -1
  247. data/{spec/mod/standard → mod/04_settings/spec}/set/right/update_spec.rb +0 -0
  248. data/{spec/mod/standard → mod/04_settings/spec}/set/type/setting_spec.rb +0 -0
  249. data/mod/{standard → 05_standard}/file/103/icon-6566.ico +0 -0
  250. data/mod/{standard → 05_standard}/file/103/large-6566.ico +0 -0
  251. data/mod/{standard → 05_standard}/file/103/medium-6566.ico +0 -0
  252. data/mod/{standard → 05_standard}/file/103/original-6566.ico +0 -0
  253. data/mod/{standard → 05_standard}/file/103/small-6566.ico +0 -0
  254. data/mod/{standard → 05_standard}/file/79/icon-6556.png +0 -0
  255. data/mod/{standard → 05_standard}/file/79/large-6556.png +0 -0
  256. data/mod/{standard → 05_standard}/file/79/medium-6556.png +0 -0
  257. data/mod/{standard → 05_standard}/file/79/original-6556.png +0 -0
  258. data/mod/{standard → 05_standard}/file/79/small-6556.png +0 -0
  259. data/mod/{standard → 05_standard}/file/790/icon-6419.png +0 -0
  260. data/mod/{standard → 05_standard}/file/790/large-6419.png +0 -0
  261. data/mod/{standard → 05_standard}/file/790/medium-6419.png +0 -0
  262. data/mod/{standard → 05_standard}/file/790/original-6419.png +0 -0
  263. data/mod/{standard → 05_standard}/file/790/small-6419.png +0 -0
  264. data/mod/{standard → 05_standard}/format/css_format.rb +0 -0
  265. data/mod/{standard → 05_standard}/format/csv_format.rb +0 -0
  266. data/mod/{standard → 05_standard}/format/file_format.rb +0 -0
  267. data/mod/{standard → 05_standard}/format/js_format.rb +0 -0
  268. data/mod/{standard → 05_standard}/format/json_format.rb +0 -0
  269. data/mod/{standard → 05_standard}/format/rss_format.rb +0 -0
  270. data/mod/{standard → 05_standard}/format/xml_format.rb +0 -0
  271. data/mod/{standard → 05_standard}/set/all/account.rb +0 -0
  272. data/mod/{standard → 05_standard}/set/all/all_css.rb +0 -0
  273. data/mod/{standard → 05_standard}/set/all/all_csv.rb +1 -1
  274. data/mod/05_standard/set/all/all_js.rb +7 -0
  275. data/mod/{standard → 05_standard}/set/all/attach.rb +33 -33
  276. data/mod/{standard → 05_standard}/set/all/base.rb +0 -0
  277. data/mod/{standard → 05_standard}/set/all/comment.rb +0 -0
  278. data/mod/{standard → 05_standard}/set/all/event_viz.rb +0 -0
  279. data/mod/{standard → 05_standard}/set/all/file.rb +0 -0
  280. data/mod/05_standard/set/all/follow.rb +51 -0
  281. data/mod/05_standard/set/all/history.rb +294 -0
  282. data/mod/{standard → 05_standard}/set/all/json.rb +2 -1
  283. data/mod/05_standard/set/all/observer.rb +27 -0
  284. data/mod/{standard → 05_standard}/set/all/rich_html.rb +21 -28
  285. data/mod/{standard → 05_standard}/set/all/rss.rb +0 -0
  286. data/mod/{standard → 05_standard}/set/all/text.rb +0 -0
  287. data/mod/{standard → 05_standard}/set/right/account.rb +53 -7
  288. data/mod/{standard → 05_standard}/set/right/email.rb +0 -1
  289. data/mod/{standard → 05_standard}/set/right/password.rb +1 -1
  290. data/mod/{standard → 05_standard}/set/right/salt.rb +0 -0
  291. data/mod/{standard → 05_standard}/set/right/stats.rb +1 -1
  292. data/mod/{standard → 05_standard}/set/right/status.rb +0 -0
  293. data/mod/{standard → 05_standard}/set/right/token.rb +0 -0
  294. data/mod/{standard → 05_standard}/set/right/when_created.rb +0 -0
  295. data/mod/{standard → 05_standard}/set/right/when_last_edited.rb +0 -0
  296. data/mod/{standard → 05_standard}/set/rstar/rules.rb +8 -7
  297. data/mod/{standard → 05_standard}/set/self/account_links.rb +0 -0
  298. data/mod/{standard → 05_standard}/set/self/alerts.rb +0 -0
  299. data/mod/{standard → 05_standard}/set/self/all.rb +1 -1
  300. data/mod/{standard → 05_standard}/set/self/foot.rb +0 -0
  301. data/mod/{standard → 05_standard}/set/self/head.rb +21 -6
  302. data/mod/{standard → 05_standard}/set/self/navbox.rb +0 -0
  303. data/mod/{standard → 05_standard}/set/self/now.rb +0 -0
  304. data/mod/{standard → 05_standard}/set/self/recent.rb +0 -0
  305. data/mod/{standard → 05_standard}/set/self/search.rb +0 -0
  306. data/mod/{standard → 05_standard}/set/self/signin.rb +1 -1
  307. data/mod/{standard → 05_standard}/set/self/stats.rb +2 -2
  308. data/mod/{standard → 05_standard}/set/self/version.rb +0 -0
  309. data/mod/{standard → 05_standard}/set/type/basic.rb +0 -0
  310. data/mod/{standard → 05_standard}/set/type/cardtype.rb +4 -6
  311. data/mod/{standard → 05_standard}/set/type/date.rb +0 -0
  312. data/mod/{standard → 05_standard}/set/type/file.rb +0 -0
  313. data/mod/{standard → 05_standard}/set/type/html.rb +0 -0
  314. data/mod/{standard → 05_standard}/set/type/image.rb +7 -6
  315. data/mod/{standard → 05_standard}/set/type/layout_type.rb +0 -0
  316. data/mod/{standard → 05_standard}/set/type/number.rb +0 -0
  317. data/mod/{standard → 05_standard}/set/type/phrase.rb +0 -0
  318. data/mod/{standard → 05_standard}/set/type/search_type.rb +6 -3
  319. data/mod/{standard → 05_standard}/set/type/set.rb +16 -9
  320. data/mod/{standard → 05_standard}/set/type/signup.rb +16 -17
  321. data/mod/{standard → 05_standard}/set/type/toggle.rb +0 -0
  322. data/mod/{standard → 05_standard}/set/type/user.rb +10 -11
  323. data/{spec/mod/standard → mod/05_standard/spec}/chunk/include_spec.rb +39 -39
  324. data/mod/05_standard/spec/chunk/link_spec.rb +61 -0
  325. data/{spec/mod/standard → mod/05_standard/spec}/format/css_format_spec.rb +0 -0
  326. data/{spec/mod/standard → mod/05_standard/spec}/format/csv_format_spec.rb +0 -0
  327. data/{spec/mod/standard → mod/05_standard/spec}/format/email_html_format_spec.rb +0 -0
  328. data/{spec/mod/standard → mod/05_standard/spec}/format/file_format_spec.rb +0 -0
  329. data/{spec/mod/standard → mod/05_standard/spec}/format/js_format_spec.rb +0 -0
  330. data/{spec/mod/standard → mod/05_standard/spec}/format/json_format_spec.rb +0 -0
  331. data/{spec/mod/standard → mod/05_standard/spec}/format/rss_format_spec.rb +0 -0
  332. data/{spec/mod/standard → mod/05_standard/spec}/format/xml_format_spec.rb +0 -0
  333. data/{spec/mod/standard → mod/05_standard/spec}/set/all/account_spec.rb +16 -16
  334. data/{spec/mod/standard → mod/05_standard/spec}/set/all/all_css_spec.rb +1 -1
  335. data/{spec/mod/standard → mod/05_standard/spec}/set/all/all_csv_spec.rb +1 -1
  336. data/{spec/mod/standard → mod/05_standard/spec}/set/all/attach_spec.rb +1 -1
  337. data/{spec/mod/standard → mod/05_standard/spec}/set/all/base_spec.rb +10 -10
  338. data/{spec/mod/standard → mod/05_standard/spec}/set/all/comment_spec.rb +0 -0
  339. data/mod/05_standard/spec/set/all/email_html_spec.rb +15 -0
  340. data/{spec/mod/standard → mod/05_standard/spec}/set/all/event_viz_spec.rb +1 -1
  341. data/{spec/mod/standard → mod/05_standard/spec}/set/all/file_spec.rb +0 -0
  342. data/mod/05_standard/spec/set/all/follow_spec.rb +83 -0
  343. data/mod/05_standard/spec/set/all/history_spec.rb +161 -0
  344. data/{spec/mod/standard → mod/05_standard/spec}/set/all/json_spec.rb +4 -4
  345. data/mod/05_standard/spec/set/all/observer_spec.rb +74 -0
  346. data/{spec/mod/standard → mod/05_standard/spec}/set/all/rich_html_spec.rb +14 -14
  347. data/{spec/mod/standard → mod/05_standard/spec}/set/all/rss_spec.rb +1 -1
  348. data/{spec/mod/standard → mod/05_standard/spec}/set/all/text_spec.rb +0 -0
  349. data/mod/05_standard/spec/set/right/account_spec.rb +162 -0
  350. data/{spec/mod/standard → mod/05_standard/spec}/set/right/email_spec.rb +7 -7
  351. data/{spec/mod/standard → mod/05_standard/spec}/set/right/password_spec.rb +7 -7
  352. data/{spec/mod/standard → mod/05_standard/spec}/set/right/salt_spec.rb +0 -0
  353. data/{spec/mod/standard → mod/05_standard/spec}/set/right/stats_spec.rb +0 -0
  354. data/{spec/mod/standard → mod/05_standard/spec}/set/right/status_spec.rb +0 -0
  355. data/{spec/mod/standard → mod/05_standard/spec}/set/right/token_spec.rb +0 -0
  356. data/{spec/mod/standard → mod/05_standard/spec}/set/right/when_created_spec.rb +1 -1
  357. data/{spec/mod/standard → mod/05_standard/spec}/set/right/when_last_edited_spec.rb +1 -1
  358. data/{spec/mod/standard → mod/05_standard/spec}/set/rstar/rules_spec.rb +4 -4
  359. data/{spec/mod/standard → mod/05_standard/spec}/set/self/account_links_spec.rb +0 -0
  360. data/{spec/mod/standard → mod/05_standard/spec}/set/self/alerts_spec.rb +0 -0
  361. data/{spec/mod/standard → mod/05_standard/spec}/set/self/all_spec.rb +7 -6
  362. data/{spec/mod/standard → mod/05_standard/spec}/set/self/foot_spec.rb +0 -0
  363. data/{spec/mod/standard → mod/05_standard/spec}/set/self/head_spec.rb +0 -0
  364. data/{spec/mod/standard → mod/05_standard/spec}/set/self/navbox_spec.rb +0 -0
  365. data/{spec/mod/standard → mod/05_standard/spec}/set/self/now_spec.rb +1 -1
  366. data/{spec/mod/standard → mod/05_standard/spec}/set/self/recent_spec.rb +0 -0
  367. data/{spec/mod/standard → mod/05_standard/spec}/set/self/search_spec.rb +0 -0
  368. data/{spec/mod/standard → mod/05_standard/spec}/set/self/signin_spec.rb +12 -12
  369. data/{spec/mod/standard → mod/05_standard/spec}/set/self/stats_spec.rb +0 -0
  370. data/{spec/mod/standard → mod/05_standard/spec}/set/self/version_spec.rb +1 -1
  371. data/{spec/mod/standard → mod/05_standard/spec}/set/type/basic_spec.rb +0 -0
  372. data/{spec/mod/standard → mod/05_standard/spec}/set/type/cardtype_spec.rb +0 -0
  373. data/{spec/mod/standard → mod/05_standard/spec}/set/type/date_spec.rb +0 -0
  374. data/mod/05_standard/spec/set/type/email_template_spec.rb +130 -0
  375. data/{spec/mod/standard → mod/05_standard/spec}/set/type/file_spec.rb +0 -0
  376. data/{spec/mod/standard → mod/05_standard/spec}/set/type/html_spec.rb +3 -3
  377. data/{spec/mod/standard → mod/05_standard/spec}/set/type/image_spec.rb +1 -1
  378. data/{spec/mod/standard → mod/05_standard/spec}/set/type/layout_type_spec.rb +1 -1
  379. data/{spec/mod/standard → mod/05_standard/spec}/set/type/number_spec.rb +0 -0
  380. data/{spec/mod/standard → mod/05_standard/spec}/set/type/phrase_spec.rb +0 -0
  381. data/mod/05_standard/spec/set/type/search_type_spec.rb +27 -0
  382. data/mod/05_standard/spec/set/type/set_spec.rb +26 -0
  383. data/mod/05_standard/spec/set/type/signup_spec.rb +209 -0
  384. data/{spec/mod/standard → mod/05_standard/spec}/set/type/toggle_spec.rb +2 -2
  385. data/{spec/mod/standard → mod/05_standard/spec}/set/type/user_spec.rb +0 -0
  386. data/mod/{standard → 06_email}/format/email_html_format.rb +0 -0
  387. data/mod/06_email/format/email_text_format.rb +7 -0
  388. data/mod/06_email/set/all/email_html.rb +9 -0
  389. data/mod/{standard/set/all/email_html.rb → 06_email/set/all/email_text.rb} +2 -1
  390. data/mod/06_email/set/right/bcc.rb +31 -0
  391. data/mod/06_email/set/right/cc.rb +2 -0
  392. data/mod/06_email/set/right/from.rb +2 -0
  393. data/mod/06_email/set/right/html_message.rb +3 -0
  394. data/mod/06_email/set/right/to.rb +2 -0
  395. data/mod/06_email/set/type/email_template.rb +99 -0
  396. data/spec/controllers/card_controller_spec.rb +34 -46
  397. data/spec/lib/card/action_spec.rb +14 -0
  398. data/spec/lib/card/chunk_spec.rb +3 -3
  399. data/spec/lib/card/codename_spec.rb +5 -5
  400. data/spec/lib/card/content_spec.rb +25 -25
  401. data/spec/lib/card/diff_spec.rb +107 -107
  402. data/spec/lib/card/format_spec.rb +11 -11
  403. data/spec/lib/card/loader_spec.rb +35 -29
  404. data/spec/lib/card/name_spec.rb +82 -82
  405. data/spec/lib/card/query_spec.rb +83 -82
  406. data/spec/lib/card/reference_spec.rb +30 -30
  407. data/spec/lib/card/set_pattern_spec.rb +1 -1
  408. data/spec/lib/card/set_spec.rb +86 -82
  409. data/spec/lib/wagn/cache_spec.rb +24 -24
  410. data/spec/mailers/mailer_spec.rb +41 -30
  411. data/spec/models/card/cardtype_spec.rb +19 -19
  412. data/spec/models/card/create_spec.rb +14 -14
  413. data/spec/models/card/trash_spec.rb +37 -36
  414. data/spec/models/card/type_transition_spec.rb +13 -13
  415. data/spec/models/card/validation_spec.rb +6 -6
  416. data/spec/models/card_spec.rb +40 -39
  417. data/spec/spec_helper.rb +37 -11
  418. data/test/fixtures/card_actions.yml +4726 -0
  419. data/test/fixtures/card_acts.yml +589 -0
  420. data/test/fixtures/card_changes.yml +12644 -0
  421. data/test/fixtures/card_references.yml +976 -591
  422. data/test/fixtures/cards.yml +4544 -2781
  423. data/test/seed.rb +14 -13
  424. data/wagn.gemspec +4 -0
  425. metadata +404 -403
  426. data/db/bootstrap/card_revisions.yml +0 -3379
  427. data/lib/card/flexmail.rb +0 -53
  428. data/lib/card/mailer/change_notice.html.erb +0 -32
  429. data/lib/card/mailer/confirmation_email.html.erb +0 -12
  430. data/lib/card/mailer/flexmail.html.erb +0 -6
  431. data/lib/card/mailer/password_reset.html.erb +0 -9
  432. data/lib/card/mailer/signup_alert.html.erb +0 -14
  433. data/lib/card/revision.rb +0 -47
  434. data/lib/wagn/migration_helper.rb +0 -34
  435. data/mod/core/set/all/attribute_tracking.rb +0 -85
  436. data/mod/core/set/all/content.rb +0 -94
  437. data/mod/standard/set/all/flexmail.rb +0 -3
  438. data/mod/standard/set/all/follow.rb +0 -119
  439. data/mod/standard/set/all/history.rb +0 -107
  440. data/mod/standard/set/right/add_help.rb +0 -3
  441. data/mod/standard/set/right/default.rb +0 -3
  442. data/mod/standard/set/right/help.rb +0 -3
  443. data/spec/lib/card/flexmail_spec.rb +0 -209
  444. data/spec/lib/card/revision_spec.rb +0 -30
  445. data/spec/mod/core/chunk/literal_spec.rb +0 -14
  446. data/spec/mod/core/set/all/attribute_tracking_spec.rb +0 -21
  447. data/spec/mod/core/set/all/collection_spec.rb +0 -45
  448. data/spec/mod/core/set/all/content_spec.rb +0 -14
  449. data/spec/mod/core/set/all/rules_spec.rb +0 -98
  450. data/spec/mod/standard/chunk/link_spec.rb +0 -59
  451. data/spec/mod/standard/set/all/email_html_spec.rb +0 -13
  452. data/spec/mod/standard/set/all/flexmail_spec.rb +0 -5
  453. data/spec/mod/standard/set/all/follow_spec.rb +0 -95
  454. data/spec/mod/standard/set/all/history_spec.rb +0 -10
  455. data/spec/mod/standard/set/right/account_spec.rb +0 -90
  456. data/spec/mod/standard/set/type/search_type_spec.rb +0 -27
  457. data/spec/mod/standard/set/type/set_spec.rb +0 -26
  458. data/spec/mod/standard/set/type/signup_spec.rb +0 -169
  459. data/test/fixtures/card_revisions.yml +0 -4560
@@ -8,9 +8,10 @@ class Card
8
8
 
9
9
  if c = args[:controller]
10
10
  self[:controller] = c
11
- self[:session] = c.request.session
12
- self[:params] = c.request.params
13
- self[:ajax] = c.request.xhr? || c.request.params[:simulate_xhr]
11
+ self[:session] = c.request.session
12
+ self[:params] = c.request.params
13
+ self[:ip] = c.request.remote_ip
14
+ self[:ajax] = c.request.xhr? || c.request.params[:simulate_xhr]
14
15
  self[:host] = Wagn.config.override_host || c.request.env['HTTP_HOST']
15
16
  self[:protocol] = Wagn.config.override_protocol || c.request.protocol
16
17
 
@@ -207,7 +207,7 @@ class Card
207
207
  when api_option == :hide ; false
208
208
  # default
209
209
  else ; default==:show
210
- end
210
+ end
211
211
  end
212
212
 
213
213
  def show_views args
@@ -285,15 +285,13 @@ class Card
285
285
  content = card.raw_content || '' if content.nil?
286
286
 
287
287
  obj_content = Card::Content===content ? content : Card::Content.new( content, format=self, opts.delete(:content_opts) )
288
-
289
288
  card.update_references( obj_content, refresh=true ) if card.references_expired # I thik we need this generalized
290
-
291
289
  obj_content.process_content_object do |chunk_opts|
292
290
  prepare_nest chunk_opts.merge(opts) { yield }
293
291
  end
294
292
  end
295
293
 
296
- def ok_view view, args={}
294
+ def ok_view view, args={}
297
295
  return view if args.delete :skip_permissions
298
296
  approved_view = case
299
297
  when @depth >= @@max_depth ; :too_deep # prevent recursion. @depth tracks subformats
@@ -435,7 +433,6 @@ class Card
435
433
  when @mode == :closed ; !nested_card.known? ? :closed_missing : :closed_content
436
434
  else ; view
437
435
  end
438
-
439
436
  sub.render view, opts
440
437
  #end
441
438
  end
@@ -1,7 +1,10 @@
1
1
 
2
2
  Description:
3
- Generates a migration of database content
4
-
3
+ Generates a migration of database content.
4
+
5
+ To import database content from a json file move your json file to db/migrate_cards/data
6
+ and choose as migration name import_<filename>.
7
+
5
8
  Example:
6
9
  wagn generate card_migration better_commented_search_cards
7
10
 
@@ -9,4 +12,13 @@ Example:
9
12
 
10
13
  db/migrate_cards/(migration_number)_(name).rb
11
14
 
12
- ...which is set up to use methods in lib/wagn/migration_helper.rb
15
+ ...which is set up to use methods in lib/wagn/migration.rb
16
+
17
+
18
+ wagn generate card_migration import_better_search_cards
19
+
20
+ This will create:
21
+
22
+ db/migrate_cards/(migration_number)_(name).rb
23
+
24
+ ...which is set up to import data from db/migrate_cards/data/better_search_cards.json
@@ -3,8 +3,28 @@ require 'rails/generators/active_record'
3
3
 
4
4
  class CardMigrationGenerator < ActiveRecord::Generators::Base
5
5
  source_root File.expand_path('../templates', __FILE__)
6
+
7
+ class_option 'core', :type => :boolean, aliases: '-c', :default => false, :group => :runtime,
8
+ desc: "Create card migration for wagn core"
6
9
 
7
10
  def create_migration_file
8
- migration_template "card_migration.erb", "db/migrate_cards/#{file_name}.rb"
11
+ root = options['core'] ? Wagn::Migration.card_migration_paths.first : Wagn::Migration.deck_card_migration_paths.first
12
+ set_local_assigns!
13
+ migration_template @migration_template, File.join( root, "#{file_name}.rb")
9
14
  end
10
- end
15
+
16
+ protected
17
+
18
+ # sets the default migration template that is being used for the generation of the migration
19
+ # depending on the arguments which would be sent out in the command line, the migration template
20
+ # and the table name instance variables are setup.
21
+
22
+ def set_local_assigns!
23
+ @migration_template = "card_migration.erb"
24
+ case file_name
25
+ when /^(import)_(.*)(?:\.json)?/
26
+ @migration_action = $1
27
+ @json_filename = "#{$2}.json"
28
+ end
29
+ end
30
+ end
@@ -1,10 +1,9 @@
1
1
  # -*- encoding : utf-8 -*-
2
2
 
3
- class <%= migration_class_name %> < ActiveRecord::Migration
4
- include Wagn::MigrationHelper
3
+ class <%= migration_class_name %> < Wagn::Migration
5
4
  def up
6
- contentedly do
7
-
8
- end
5
+ <% if @migration_action == 'import' -%>
6
+ import_json "<%= @json_filename %>"
7
+ <% end -%>
9
8
  end
10
9
  end
@@ -5,5 +5,5 @@ Example:
5
5
  rails generate format backup
6
6
 
7
7
  This will create:
8
- mods/standard/formats/backup_format.rb
9
- spec/mods/standard/formats/backup_format_spec.rb
8
+ mods/05_standard/formats/backup_format.rb
9
+ spec/mods/05_standard/formats/backup_format_spec.rb
@@ -2,7 +2,7 @@ class FormatGenerator < Rails::Generators::NamedBase
2
2
  source_root File.expand_path('../templates', __FILE__)
3
3
 
4
4
  def create_files
5
- template 'format_template.erb', "mod/standard/format/#{file_name}_format.rb"
6
- template 'format_spec_template.erb', "spec/mod/standard/format/#{file_name}_format_spec.rb"
5
+ template 'format_template.erb', "mod/05_standard/format/#{file_name}_format.rb"
6
+ template 'format_spec_template.erb', "spec/mod/05_standard/format/#{file_name}_format_spec.rb"
7
7
  end
8
8
  end
@@ -5,5 +5,5 @@ Example:
5
5
  wagn generate set standard type tshirt
6
6
 
7
7
  This will create:
8
- mods/standard/sets/type/tshirt.rb
9
- spec/mods/standard/sets/type/tshirt_spec.rb
8
+ mods/05_standard/sets/type/tshirt.rb
9
+ spec/mods/05_standard/sets/type/tshirt_spec.rb
@@ -1,6 +1,7 @@
1
1
  # -*- encoding : utf-8 -*-
2
2
  require 'open-uri'
3
3
 
4
+
4
5
  class Card
5
6
  class Mailer < ActionMailer::Base
6
7
 
@@ -11,108 +12,28 @@ class Card
11
12
  default @@defaults
12
13
 
13
14
  include Wagn::Location
14
-
15
-
16
- def confirmation_email account
17
- @site = Card.setting :title
18
- @token = account.token
19
- @link = wagn_url "/update/#{ account.left.cardname.url_key }?token=#{ @token }"
20
- @expiry = Wagn.config.token_expiry
21
-
22
- confirm_from = token_emails_from(account)
23
- mail_from( { :to=>account.email, :subject=>"verification link for #{@site}" }, confirm_from )
24
- end
25
-
26
- def password_reset account
27
- @site = Card.setting :title
28
- @link = wagn_url "/update/#{account.cardname.url_key}?reset_token=#{account.token_card.refresh(true).content}"
29
- @expiry = Wagn.config.token_expiry
30
-
31
- reset_from = token_emails_from(account)
32
- mail_from( { :to=>account.email, :subject=>"verification link for #{@site}" }, reset_from )
33
- end
34
-
35
- def signup_alert invite_request
36
- @site = Card.setting :title
37
- @card = invite_request
38
- @email= invite_request.account.email
39
- @name = invite_request.name
40
- @content = invite_request.content
41
- @request_url = wagn_url invite_request
42
- @requests_url = wagn_url Card[:signup]
43
-
44
- args = {
45
- :to => Card.setting('*request+*to'),
46
- :subject => "#{invite_request.name} signed up for #{@site}",
47
- :content_type => 'text/html',
48
- }
49
- mail_from args, Card.setting('*request+*from') || "#{@name} <#{@email}>"
50
- end
51
-
52
-
53
- def change_notice cd_with_acct, card, action, watched, subedits=[], updated_card=nil
54
- cd_with_acct = Card[cd_with_acct] unless Card===cd_with_acct
55
- email = cd_with_acct.account.email
56
- #warn "change_notice( #{cd_with_acct}, #{email}, #{card.inspect}, #{action.inspect}, #{watched.inspect} Uc:#{updated_card.inspect}...)"
57
-
58
- updated_card ||= card
59
- @card = card
60
- @updater = updated_card.updater.name
61
- @action = action
62
- @subedits = subedits
63
- @card_url = wagn_url card
64
- @change_url = wagn_url "card/changes/#{card.cardname.url_key}"
65
- @unwatch_url = wagn_url "card/watch/#{watched.to_name.url_key}?toggle=off"
66
- @udpater_url = wagn_url card.updater
67
- @watched = (watched == card.cardname ? "#{watched}" : "#{watched} cards")
68
-
69
- args = {
70
- :to => email,
71
- :subject => "[#{Card.setting :title} notice] #{@updater} #{action} \"#{card.name}\"" ,
72
- :content_type => 'text/html',
73
- }
74
- mail_from args, Card[Card::WagnBotID].account.email
75
- end
76
-
77
- def flexmail config
78
- @message = config.delete(:message)
79
-
80
- if attachment_list = config.delete(:attach) and !attachment_list.empty?
81
- attachment_list.each_with_index do |cardname, i|
82
- if c = Card[ cardname ] and c.respond_to?(:attach)
83
- attachments["attachment-#{i + 1}.#{c.attach_extension}"] = File.read( c.attach.path )
84
- end
85
- end
15
+
16
+ class << self
17
+ def new_mail(*args, &block)
18
+ mail = Mail.new(args, &block)
19
+ method = Card::Mailer.delivery_method
20
+ mail.delivery_method(method, Card::Mailer.send(:"#{method}_settings"))
21
+ mail.perform_deliveries = Card::Mailer.perform_deliveries
22
+ mail.raise_delivery_errors = Card::Mailer.raise_delivery_errors
23
+ mail
86
24
  end
87
-
88
- mail_from config, config[:from]
89
- end
90
-
91
- private
92
-
93
- def token_emails_from account
94
- Card.setting( '*invite+*from' ) || begin
95
- from_card_id = Auth.current_id
96
- from_card_id = WagnBotID if [ AnonymousID, account.left_id ].member? from_card_id
97
- from_card = Card[from_card_id]
98
- "#{from_card.name} <#{from_card.account.email}>"
99
- end
100
- end
101
-
102
- def mail_from args, from
103
- from_name, from_email = (from =~ /(.*)\<(.*)>/) ? [$1.strip, $2] : [nil, from]
104
-
105
- if default_from=@@defaults[:from]
106
- args[:from] = !from_email ? default_from : "#{from_name || from_email} <#{default_from}>"
107
- args[:reply_to] ||= from
108
- else
109
- args[:from] = from
25
+
26
+ def layout message
27
+ %{
28
+ <!DOCTYPE html>
29
+ <html>
30
+ <body>
31
+ #{message}
32
+ </body>
33
+ </html>
34
+ }
110
35
  end
111
-
112
- args[:template_path] = 'mailer'
113
- mail args
114
36
  end
115
-
116
37
  end
117
-
118
38
  end
39
+
@@ -1,11 +1,11 @@
1
- # -*- encoding : utf-8 -*-
1
+ # -*- encoding : utf-8 -*-
2
2
  require 'smart_name'
3
3
 
4
4
  class Card
5
5
  class Name < SmartName
6
6
 
7
7
  self.params = Card::Env # yuck!
8
- self.session = proc { Auth.current.name }
8
+ self.session = proc { Card::Auth.current.name }
9
9
  self.banned_array = ['/']
10
10
 
11
11
  def star?
@@ -32,7 +32,8 @@ class Card
32
32
  end
33
33
 
34
34
  def trait tag_code
35
- trait_name( tag_code ).s
35
+ name = trait_name( tag_code )
36
+ name ? name.s : ( raise Wagn::NotFound, "unknown codename: #{tag_code}" )
36
37
  end
37
38
  end
38
39
  end
@@ -58,10 +58,10 @@ class Card::Query
58
58
 
59
59
 
60
60
  class SqlStatement
61
- attr_accessor :fields, :relevance_fields, :tables, :joins, :conditions, :group, :order, :limit, :offset
61
+ attr_accessor :fields, :tables, :joins, :conditions, :group, :order, :limit, :offset
62
62
 
63
63
  def initialize
64
- @fields, @relevance_fields, @joins, @conditions = [],[],[],[]
64
+ @fields, @joins, @conditions = [],[],[],[]
65
65
  @tables, @group, @order, @limit, @offset = "","","","",""
66
66
  end
67
67
 
@@ -4,7 +4,7 @@ class Card
4
4
  class CardSpec < Spec
5
5
 
6
6
  ATTRIBUTES = {
7
- :basic => %w{ name type_id content id key updater_id left_id right_id creator_id updater_id codename },
7
+ :basic => %w{ name type_id content id key updater_id left_id right_id creator_id updater_id codename },
8
8
  :relational => %w{ type part left right editor_of edited_by last_editor_of last_edited_by creator_of created_by member_of member },
9
9
  :plus_relational => %w{ plus left_plus right_plus },
10
10
  :ref_relational => %w{ refer_to referred_to_by link_to linked_to_by include included_by },
@@ -200,15 +200,15 @@ class Card
200
200
  def right val
201
201
  merge field(:right_id) => id_or_subspec(val)
202
202
  end
203
-
203
+
204
204
  def editor_of val
205
- revision_spec :creator_id, :card_id, val
205
+ action_spec :actor_id, "card_actions.card_id", val
206
206
  end
207
207
 
208
208
  def edited_by val
209
- revision_spec :card_id, :creator_id, val
209
+ action_spec "card_actions.card_id", :actor_id, val
210
210
  end
211
-
211
+
212
212
  def last_editor_of val
213
213
  merge field(:id) => subspec(val, :return=>'updater_id')
214
214
  end
@@ -291,7 +291,7 @@ class Card
291
291
 
292
292
  def sort val
293
293
  return nil if @parent
294
- val[:return] = val[:return] ? safe_sql(val[:return]) : 'content'
294
+ val[:return] = val[:return] ? safe_sql(val[:return]) : 'db_content'
295
295
  @mods[:sort] = "t_sort.#{val[:return]}"
296
296
  item = val.delete(:item) || 'left'
297
297
 
@@ -326,10 +326,8 @@ class Card
326
326
 
327
327
 
328
328
  cond = begin
329
- join_alias = add_revision_join
330
- # FIXME: OMFG this is ugly
331
329
  val_list = val.split(/\s+/).map do |v|
332
- name_or_content = ["replace(#{self.table_alias}.name,'+',' ')","#{join_alias}.content"].map do |field|
330
+ name_or_content = ["replace(#{self.table_alias}.name,'+',' ')","#{self.table_alias}.db_content"].map do |field|
333
331
  %{#{field} #{ cxn.match quote("[[:<:]]#{v}[[:>:]]") }}
334
332
  end
335
333
  "(#{name_or_content.join ' OR '})"
@@ -374,10 +372,6 @@ class Card
374
372
  join_alias
375
373
  end
376
374
 
377
- def add_revision_join
378
- add_join(:rev, :card_revisions, :current_revision_id, :id)
379
- end
380
-
381
375
  def field name
382
376
  @fields ||= {}
383
377
  @fields[name] ||= 0
@@ -394,13 +388,19 @@ class Card
394
388
  cardspec = CardSpec.build( args )
395
389
  merge field(:cond) => cardspec.merge(val)
396
390
  self.joins.merge! cardspec.joins
397
- self.sql.relevance_fields += cardspec.sql.relevance_fields
398
391
  end
399
392
 
400
-
401
- def revision_spec(field, linkfield, val)
393
+ # def revision_spec(field, linkfield, val)
394
+ # card_select = CardSpec.build(:_parent=>self, :return=>'id').merge(val).to_sql
395
+ # add_join :ed, "(select distinct #{field} from card_revisions where #{linkfield} in #{card_select})", :id, field
396
+ # end
397
+
398
+
399
+ def action_spec(field, linkfield, val)
402
400
  card_select = CardSpec.build(:_parent=>self, :return=>'id').merge(val).to_sql
403
- add_join :ed, "(select distinct #{field} from card_revisions where #{linkfield} in #{card_select})", :id, field
401
+ sql = "(SELECT DISTINCT #{field} AS join_card_id FROM card_acts INNER JOIN card_actions ON card_acts.id = card_act_id "
402
+ sql += " WHERE #{linkfield} IN #{card_select} AND (draft=0 OR draft IS NULL))"
403
+ add_join :ac, sql, :id, :join_card_id
404
404
  end
405
405
 
406
406
 
@@ -472,9 +472,7 @@ class Card
472
472
  when :raw; "#{table_alias}.*"
473
473
  when :card; "#{table_alias}.name"
474
474
  when :count; "coalesce(count(*),0) as count"
475
- when :content
476
- join_alias = add_revision_join
477
- "#{join_alias}.content"
475
+ when :content; "#{table_alias}.db_content"
478
476
  else
479
477
  ATTRIBUTES[field.to_sym]==:basic ? "#{table_alias}.#{field}" : safe_sql(field)
480
478
  end
@@ -500,16 +498,8 @@ class Card
500
498
  when "update"; "#{table_alias}.updated_at"
501
499
  when "create"; "#{table_alias}.created_at"
502
500
  when /^(name|alpha)$/; "LOWER( #{table_alias}.key )"
503
- when 'content'
504
- join_alias = add_revision_join
505
- "lower(#{join_alias}.content)"
506
- when "relevance"
507
- if !sql.relevance_fields.empty?
508
- sql.fields << sql.relevance_fields
509
- "name_rank desc, content_rank"
510
- else
511
- "#{table_alias}.updated_at"
512
- end
501
+ when 'content'; "#{table_alias}.db_content"
502
+ when "relevance"; "#{table_alias}.updated_at" #deprecated
513
503
  else
514
504
  safe_sql(key)
515
505
  end
@@ -49,12 +49,11 @@ class Card::Query
49
49
  field, v = case field
50
50
  when "cond"; return "(#{sqlize(v)})"
51
51
  when "name"; ["#{table}.key", [v].flatten.map(&:to_name).map(&:key)]
52
- when "content"; join_alias = @cardspec.add_revision_join
53
- ["#{join_alias}.content", v]
52
+ when "content"; ["#{table}.db_content", v]
54
53
  else; ["#{table}.#{safe_sql(field)}", v]
55
54
  end
56
55
 
57
- v = v[0] if Array===v && v.length==1
56
+ v = v[0] if Array===v && v.length==1 && op != 'in'
58
57
  if op=='~'
59
58
  cxn, v = match_prep(v,@cardspec)
60
59
  %{#{field} #{cxn.match(sqlize(v))}}