locomotive_cms 2.0.0.rc12 → 2.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (519) hide show
  1. data/Gemfile +35 -28
  2. data/LICENSE +1 -1
  3. data/README.textile +9 -4
  4. data/app/assets/images/locomotive/icons/flags/de.png +0 -0
  5. data/app/assets/images/locomotive/icons/flags/en.png +0 -0
  6. data/app/assets/images/locomotive/icons/flags/es.png +0 -0
  7. data/app/assets/images/locomotive/icons/flags/et.png +0 -0
  8. data/app/assets/images/locomotive/icons/flags/fr.png +0 -0
  9. data/app/assets/images/locomotive/icons/flags/it.png +0 -0
  10. data/app/assets/images/locomotive/icons/flags/nb.png +0 -0
  11. data/app/assets/images/locomotive/icons/flags/nl.png +0 -0
  12. data/app/assets/images/locomotive/icons/flags/pl.png +0 -0
  13. data/app/assets/images/locomotive/icons/flags/pt-BR.png +0 -0
  14. data/app/assets/images/locomotive/icons/flags/ru.png +0 -0
  15. data/app/assets/javascripts/aloha/plugins/custom/locomotive_media/css/image.css +1 -1
  16. data/app/assets/javascripts/aloha/plugins/custom/locomotive_media/lib/locomotive_media-plugin.js +10 -21
  17. data/app/assets/javascripts/locomotive/models/content_entry.js.coffee +1 -1
  18. data/app/assets/javascripts/locomotive/models/content_type.js.coffee +6 -0
  19. data/app/assets/javascripts/locomotive/models/translation.js.coffee +5 -0
  20. data/app/assets/javascripts/locomotive/utils/aloha_settings.js.coffee +20 -2
  21. data/app/assets/javascripts/locomotive/utils/tinymce_settings.js.coffee +6 -6
  22. data/app/assets/javascripts/locomotive/views/application_view.js.coffee +4 -4
  23. data/app/assets/javascripts/locomotive/views/content_assets/picker_item_view.js.coffee +1 -1
  24. data/app/assets/javascripts/locomotive/views/content_entries/_form_view.js.coffee +10 -3
  25. data/app/assets/javascripts/locomotive/views/content_entries/_popup_form_view.js.coffee +7 -6
  26. data/app/assets/javascripts/locomotive/views/content_entries/index_view.js.coffee +1 -1
  27. data/app/assets/javascripts/locomotive/views/content_types/_form_view.js.coffee +4 -1
  28. data/app/assets/javascripts/locomotive/views/content_types/custom_field_entry_view.js.coffee +2 -2
  29. data/app/assets/javascripts/locomotive/views/content_types/custom_fields_view.coffee +5 -0
  30. data/app/assets/javascripts/locomotive/views/content_types/edit_view.coffee +1 -1
  31. data/app/assets/javascripts/locomotive/views/content_types/select_options_view.js.coffee +6 -6
  32. data/app/assets/javascripts/locomotive/views/current_site/edit_view.js.coffee +2 -1
  33. data/app/assets/javascripts/locomotive/views/editable_elements/edit_all_view.js.coffee +1 -1
  34. data/app/assets/javascripts/locomotive/views/editable_elements/file_view.js.coffee +2 -2
  35. data/app/assets/javascripts/locomotive/views/inline_editor/application_view.js.coffee +36 -15
  36. data/app/assets/javascripts/locomotive/views/inline_editor/toolbar_view.js.coffee +30 -14
  37. data/app/assets/javascripts/locomotive/views/pages/_form_view.js.coffee +24 -11
  38. data/app/assets/javascripts/locomotive/views/pages/edit_view.js.coffee +1 -1
  39. data/app/assets/javascripts/locomotive/views/pages/list_view.js.coffee +2 -2
  40. data/app/assets/javascripts/locomotive/views/shared/fields/file_view.js.coffee +5 -4
  41. data/app/assets/javascripts/locomotive/views/shared/fields/has_many_view.js.coffee +2 -1
  42. data/app/assets/javascripts/locomotive/views/shared/fields/many_to_many_view.js.coffee +1 -1
  43. data/app/assets/javascripts/locomotive/views/shared/fields/select_view.js.coffee +6 -2
  44. data/app/assets/javascripts/locomotive/views/shared/form_view.js.coffee +17 -12
  45. data/app/assets/javascripts/locomotive/views/shared/list_item_view.js.coffee +1 -1
  46. data/app/assets/javascripts/locomotive/views/sites/membership_entry_view.js.coffee +2 -1
  47. data/app/assets/javascripts/locomotive/views/snippets/_form_view.js.coffee +19 -3
  48. data/app/assets/javascripts/locomotive/views/theme_assets/index_view.js.coffee +8 -1
  49. data/app/assets/javascripts/locomotive/views/translations/_form_view.js.coffee +20 -0
  50. data/app/assets/javascripts/locomotive/views/translations/edit_view.js.coffee +6 -0
  51. data/app/assets/javascripts/locomotive/views/translations/new_view.js.coffee +8 -0
  52. data/app/assets/javascripts/tinymce/plugins/jqueryinlinepopups/editor_plugin.js +2 -2
  53. data/app/assets/javascripts/tinymce/plugins/locomotive_media/editor_plugin.js +1 -0
  54. data/app/assets/javascripts/tinymce/plugins/locomotive_media/langs/en.js +1 -0
  55. data/app/assets/javascripts/tinymce/plugins/locomotive_media/langs/fr.js +1 -0
  56. data/app/assets/javascripts/tinymce/plugins/locomotive_media/langs/ru.js +1 -0
  57. data/app/assets/stylesheets/locomotive.css +2 -1
  58. data/app/assets/stylesheets/locomotive/backoffice/_box.css.scss +3 -13
  59. data/app/assets/stylesheets/locomotive/backoffice/_buttons.css.scss +39 -16
  60. data/app/assets/stylesheets/locomotive/backoffice/application.css.scss +45 -56
  61. data/app/assets/stylesheets/locomotive/backoffice/codemirror_changes.css.scss +2 -0
  62. data/app/assets/stylesheets/locomotive/backoffice/content_assets.css.scss +5 -8
  63. data/app/assets/stylesheets/locomotive/backoffice/datepicker.css.scss +23 -9
  64. data/app/assets/stylesheets/locomotive/backoffice/formtastic_changes.css.scss +36 -32
  65. data/app/assets/stylesheets/locomotive/backoffice/layout.css.scss +2 -1
  66. data/app/assets/stylesheets/locomotive/backoffice/menu/_colors.css.scss +2 -1
  67. data/app/assets/stylesheets/locomotive/backoffice/menu/default.css.scss +4 -39
  68. data/app/assets/stylesheets/locomotive/backoffice/menu/main.css.scss +1 -1
  69. data/app/assets/stylesheets/locomotive/backoffice/menu/sub.css.scss +28 -36
  70. data/app/assets/stylesheets/locomotive/inline_editor.css +2 -1
  71. data/app/assets/stylesheets/locomotive/inline_editor/_buttons.css.scss +1 -11
  72. data/app/assets/stylesheets/locomotive/inline_editor/toolbar.css.scss +3 -4
  73. data/app/assets/stylesheets/locomotive/not_logged_in.css +1 -0
  74. data/app/assets/stylesheets/locomotive/not_logged_in/layout.css.scss +17 -8
  75. data/app/assets/stylesheets/locomotive/shared/_helpers.css.scss +21 -41
  76. data/app/assets/stylesheets/locomotive/shared/common.css.scss +2 -1
  77. data/app/assets/stylesheets/locomotive/shared/content_locale_picker.css.scss +11 -13
  78. data/app/cells/locomotive/content_locale_picker/show.html.haml +2 -2
  79. data/app/cells/locomotive/content_locale_picker_cell.rb +6 -2
  80. data/app/cells/locomotive/global_actions_cell.rb +1 -1
  81. data/app/cells/locomotive/main_menu/show.html.haml +1 -1
  82. data/app/cells/locomotive/main_menu_cell.rb +2 -2
  83. data/app/cells/locomotive/settings_menu_cell.rb +1 -0
  84. data/app/controllers/locomotive/api/accounts_controller.rb +70 -0
  85. data/app/controllers/locomotive/api/base_controller.rb +8 -0
  86. data/app/controllers/locomotive/api/content_assets_controller.rb +7 -9
  87. data/app/controllers/locomotive/api/content_entries_controller.rb +18 -14
  88. data/app/controllers/locomotive/api/content_types_controller.rb +56 -9
  89. data/app/controllers/locomotive/api/current_site_controller.rb +47 -1
  90. data/app/controllers/locomotive/api/documentation_controller.rb +15 -0
  91. data/app/controllers/locomotive/api/memberships_controller.rb +49 -14
  92. data/app/controllers/locomotive/api/my_account_controller.rb +19 -2
  93. data/app/controllers/locomotive/api/pages_controller.rb +56 -9
  94. data/app/controllers/locomotive/api/sites_controller.rb +62 -14
  95. data/app/controllers/locomotive/api/snippets_controller.rb +56 -9
  96. data/app/controllers/locomotive/api/theme_assets_controller.rb +7 -9
  97. data/app/controllers/locomotive/api/tokens_controller.rb +32 -5
  98. data/app/controllers/locomotive/api/translations_controller.rb +33 -0
  99. data/app/controllers/locomotive/public/base_controller.rb +1 -1
  100. data/app/controllers/locomotive/public/content_entries_controller.rb +13 -12
  101. data/app/controllers/locomotive/public/pages_controller.rb +3 -1
  102. data/app/controllers/locomotive/public/robots_controller.rb +2 -2
  103. data/app/controllers/locomotive/public/sitemaps_controller.rb +2 -2
  104. data/app/controllers/locomotive/sites_controller.rb +2 -2
  105. data/app/controllers/locomotive/snippets_controller.rb +6 -1
  106. data/app/controllers/locomotive/translations_controller.rb +39 -0
  107. data/app/helpers/locomotive/accounts_helper.rb +1 -1
  108. data/app/helpers/locomotive/base_helper.rb +68 -2
  109. data/app/helpers/locomotive/content_entries_helper.rb +27 -1
  110. data/app/helpers/locomotive/custom_fields_helper.rb +2 -2
  111. data/app/helpers/locomotive/pages_helper.rb +30 -2
  112. data/app/helpers/locomotive/snippets_helper.rb +20 -0
  113. data/app/helpers/locomotive/translations_helper.rb +19 -0
  114. data/app/inputs/locomotive/code_input.rb +29 -7
  115. data/app/inputs/locomotive/file_input.rb +5 -1
  116. data/app/inputs/locomotive/locale_input.rb +3 -2
  117. data/app/inputs/locomotive/locales_input.rb +3 -2
  118. data/app/mailers/locomotive/notifications.rb +7 -1
  119. data/app/models/locomotive/ability.rb +9 -3
  120. data/app/models/locomotive/account.rb +11 -5
  121. data/app/models/locomotive/content_asset.rb +2 -7
  122. data/app/models/locomotive/content_entry.rb +26 -20
  123. data/app/models/locomotive/content_type.rb +56 -28
  124. data/app/models/locomotive/editable_control.rb +0 -4
  125. data/app/models/locomotive/editable_element.rb +15 -4
  126. data/app/models/locomotive/editable_file.rb +11 -5
  127. data/app/models/locomotive/editable_long_text.rb +1 -7
  128. data/app/models/locomotive/editable_short_text.rb +12 -3
  129. data/app/models/locomotive/extensions/content_type/default_values.rb +2 -4
  130. data/app/models/locomotive/extensions/page/editable_elements.rb +22 -3
  131. data/app/models/locomotive/extensions/page/listed.rb +1 -1
  132. data/app/models/locomotive/extensions/page/parse.rb +18 -12
  133. data/app/models/locomotive/extensions/page/redirect.rb +6 -4
  134. data/app/models/locomotive/extensions/page/render.rb +1 -1
  135. data/app/models/locomotive/extensions/page/templatized.rb +48 -19
  136. data/app/models/locomotive/extensions/page/tree.rb +14 -2
  137. data/app/models/locomotive/extensions/site/locales.rb +11 -3
  138. data/app/models/locomotive/extensions/site/subdomain_domains.rb +7 -2
  139. data/app/models/locomotive/membership.rb +0 -4
  140. data/app/models/locomotive/page.rb +5 -13
  141. data/app/models/locomotive/site.rb +16 -23
  142. data/app/models/locomotive/snippet.rb +1 -9
  143. data/app/models/locomotive/theme_asset.rb +24 -28
  144. data/app/models/locomotive/translation.rb +35 -0
  145. data/app/presenters/locomotive/account_presenter.rb +12 -4
  146. data/app/presenters/locomotive/base_presenter.rb +122 -20
  147. data/app/presenters/locomotive/content_asset_presenter.rb +22 -11
  148. data/app/presenters/locomotive/content_entry_presenter.rb +151 -36
  149. data/app/presenters/locomotive/content_field_presenter.rb +76 -0
  150. data/app/presenters/locomotive/content_type_presenter.rb +66 -8
  151. data/app/presenters/locomotive/editable_control_presenter.rb +9 -8
  152. data/app/presenters/locomotive/editable_element_presenter.rb +26 -7
  153. data/app/presenters/locomotive/editable_file_presenter.rb +26 -5
  154. data/app/presenters/locomotive/editable_short_text_presenter.rb +21 -4
  155. data/app/presenters/locomotive/membership_presenter.rb +14 -16
  156. data/app/presenters/locomotive/page_presenter.rb +60 -14
  157. data/app/presenters/locomotive/site_presenter.rb +23 -8
  158. data/app/presenters/locomotive/snippet_presenter.rb +10 -8
  159. data/app/presenters/locomotive/theme_asset_presenter.rb +32 -15
  160. data/app/presenters/locomotive/translation_presenter.rb +9 -0
  161. data/app/uploaders/locomotive/editable_file_uploader.rb +4 -0
  162. data/app/views/locomotive/content_assets/_asset.html.haml +1 -1
  163. data/app/views/locomotive/content_assets/_picker.html.haml +1 -1
  164. data/app/views/locomotive/content_entries/_form.html.haml +2 -2
  165. data/app/views/locomotive/content_entries/_list.html.haml +1 -2
  166. data/app/views/locomotive/content_entries/edit.html.haml +6 -3
  167. data/app/views/locomotive/content_entries/index.html.haml +2 -2
  168. data/app/views/locomotive/content_entries/new.html.haml +5 -2
  169. data/app/views/locomotive/content_types/edit.html.haml +2 -2
  170. data/app/views/locomotive/current_site/edit.html.haml +1 -1
  171. data/app/views/locomotive/custom_fields/_form.html.haml +4 -4
  172. data/app/views/locomotive/custom_fields/_select_templates.html.haml +2 -2
  173. data/app/views/locomotive/custom_fields/types/_has_many.html.haml +6 -34
  174. data/app/views/locomotive/custom_fields/types/_has_many_form.html.haml +31 -0
  175. data/app/views/locomotive/custom_fields/types/_many_to_many.html.haml +2 -3
  176. data/app/views/locomotive/layouts/not_logged_in.html.haml +1 -1
  177. data/app/views/locomotive/my_account/edit.html.haml +2 -2
  178. data/app/views/locomotive/pages/_form.html.haml +8 -4
  179. data/app/views/locomotive/pages/_page.html.haml +7 -1
  180. data/app/views/locomotive/pages/edit.html.haml +1 -1
  181. data/app/views/locomotive/pages/index.html.haml +1 -1
  182. data/app/views/locomotive/public/pages/show_toolbar.html.haml +2 -3
  183. data/app/views/locomotive/public/sitemaps/show.xml.builder +4 -4
  184. data/app/views/locomotive/shared/_head.html.haml +3 -2
  185. data/app/views/locomotive/shared/_locale_picker_link.html.haml +3 -4
  186. data/app/views/locomotive/shared/actions/_contents.html.haml +3 -1
  187. data/app/views/locomotive/shared/menu/_contents.html.haml +14 -3
  188. data/app/views/locomotive/sites/_domains.html.haml +1 -1
  189. data/app/views/locomotive/sites/_form.html.haml +5 -5
  190. data/app/views/locomotive/sites/_memberships.html.haml +4 -2
  191. data/app/views/locomotive/snippets/_form.html.haml +2 -2
  192. data/app/views/locomotive/snippets/_snippet.html.haml +1 -1
  193. data/app/views/locomotive/snippets/edit.html.haml +1 -1
  194. data/app/views/locomotive/theme_assets/_asset.html.haml +1 -1
  195. data/app/views/locomotive/theme_assets/_form.html.haml +6 -2
  196. data/app/views/locomotive/theme_assets/edit.html.haml +1 -1
  197. data/app/views/locomotive/theme_assets/index.html.haml +15 -11
  198. data/app/views/locomotive/translations/_form.html.haml +12 -0
  199. data/app/views/locomotive/translations/edit.html.haml +15 -0
  200. data/app/views/locomotive/translations/index.html.haml +28 -0
  201. data/app/views/locomotive/translations/new.html.haml +12 -0
  202. data/config/initializers/deny_phantomjs_ttf.rb +29 -0
  203. data/config/locales/admin_ui.de.yml +1 -0
  204. data/config/locales/admin_ui.en.yml +22 -2
  205. data/config/locales/admin_ui.es.yml +1 -0
  206. data/config/locales/admin_ui.et.yml +14 -0
  207. data/config/locales/admin_ui.fr.yml +36 -14
  208. data/config/locales/admin_ui.it.yml +1 -0
  209. data/config/locales/admin_ui.nb.yml +1 -0
  210. data/config/locales/admin_ui.pl.yml +319 -0
  211. data/config/locales/admin_ui.pt-BR.yml +38 -6
  212. data/config/locales/admin_ui.ru.yml +1 -0
  213. data/config/locales/carrierwave.pl.yml +4 -0
  214. data/config/locales/default.fr.yml +3 -1
  215. data/config/locales/default.pl.yml +317 -0
  216. data/config/locales/devise.de.yml +1 -0
  217. data/config/locales/devise.en.yml +1 -0
  218. data/config/locales/devise.es.yml +1 -0
  219. data/config/locales/devise.et.yml +1 -0
  220. data/config/locales/devise.fr.yml +3 -2
  221. data/config/locales/devise.it.yml +1 -0
  222. data/config/locales/devise.nb.yml +1 -0
  223. data/config/locales/devise.nl.yml +1 -0
  224. data/config/locales/devise.pl.yml +64 -0
  225. data/config/locales/devise.pt-BR.yml +1 -0
  226. data/config/locales/devise.ru.yml +1 -0
  227. data/config/locales/flash.en.yml +9 -0
  228. data/config/locales/flash.pl.yml +106 -0
  229. data/config/locales/formtastic.en.yml +2 -0
  230. data/config/locales/formtastic.fr.yml +3 -1
  231. data/config/locales/formtastic.pl.yml +105 -0
  232. data/config/routes.rb +46 -38
  233. data/features/api/accounts.feature +25 -0
  234. data/features/api/authentication.feature +19 -0
  235. data/features/api/authorization/accounts.feature +125 -0
  236. data/features/api/authorization/content_assets.feature +147 -0
  237. data/features/api/authorization/content_entries.feature +202 -0
  238. data/features/api/authorization/content_types.feature +237 -0
  239. data/features/api/authorization/current_site.feature +30 -0
  240. data/features/api/authorization/memberships.feature +225 -0
  241. data/features/api/authorization/pages.feature +187 -0
  242. data/features/api/authorization/sites.feature +213 -0
  243. data/features/api/authorization/snippets.feature +179 -0
  244. data/features/api/authorization/theme_assets.feature +185 -0
  245. data/features/api/authorization/translations.feature +253 -0
  246. data/features/api/content_entries.feature +169 -0
  247. data/features/api/content_types.feature +156 -0
  248. data/features/api/editable_elements.feature +190 -0
  249. data/features/api/entries_custom_fields.feature +150 -0
  250. data/features/api/pages.feature +72 -0
  251. data/features/backoffice/authorization/account_settings.feature +28 -0
  252. data/features/backoffice/authorization/content_type.feature +35 -0
  253. data/features/backoffice/authorization/current_site.feature +53 -0
  254. data/features/backoffice/authorization/inline_front_end_editing.feature +46 -0
  255. data/features/backoffice/authorization/pages.feature +95 -0
  256. data/features/backoffice/authorization/theme_assets.feature +50 -0
  257. data/features/backoffice/content_types/edit.feature +20 -0
  258. data/features/backoffice/content_types/has_many.feature +60 -0
  259. data/features/backoffice/content_types/many_to_many.feature +42 -0
  260. data/features/backoffice/contents.feature +70 -0
  261. data/features/backoffice/editable_elements.feature +22 -0
  262. data/features/backoffice/login.feature +33 -0
  263. data/features/backoffice/mounting.feature +13 -0
  264. data/features/backoffice/pages.feature +35 -0
  265. data/features/backoffice/site.feature +45 -0
  266. data/features/backoffice/snippets.feature +39 -0
  267. data/features/backoffice/theme_assets.feature +72 -0
  268. data/features/backoffice/translations.feature +44 -0
  269. data/features/public/basic.feature +30 -0
  270. data/features/public/contact_form.feature +78 -0
  271. data/features/public/content_entries.feature +56 -0
  272. data/features/public/editable_elements.feature +138 -0
  273. data/features/public/has_many.feature +8 -0
  274. data/features/public/inheritance.feature +157 -0
  275. data/features/public/inline_front_end_editing.feature +26 -0
  276. data/features/public/many_to_many.feature +64 -0
  277. data/features/public/pagination.feature +8 -0
  278. data/features/public/robots.feature +22 -0
  279. data/features/public/sitemap.feature +74 -0
  280. data/features/public/snippets.feature +21 -0
  281. data/features/public/tablerow.feature +42 -0
  282. data/features/step_definitions/api_steps.rb +176 -0
  283. data/features/step_definitions/backoffice/mounting_steps.rb +22 -0
  284. data/features/step_definitions/backoffice_steps.rb +43 -0
  285. data/features/step_definitions/content_assets_steps.rb +12 -0
  286. data/features/step_definitions/content_types_steps.rb +106 -0
  287. data/features/step_definitions/current_site_steps.rb +43 -0
  288. data/features/step_definitions/editable_elements_steps.rb +24 -0
  289. data/features/step_definitions/membership_steps.rb +19 -0
  290. data/features/step_definitions/more_web_steps.rb +96 -0
  291. data/features/step_definitions/page_steps.rb +110 -0
  292. data/features/step_definitions/pagination_steps.rb +35 -0
  293. data/features/step_definitions/pickle_steps.rb +100 -0
  294. data/features/step_definitions/relationships_steps.rb +107 -0
  295. data/features/step_definitions/site_steps.rb +100 -0
  296. data/features/step_definitions/snippet_steps.rb +37 -0
  297. data/features/step_definitions/theme_asset_steps.rb +64 -0
  298. data/features/step_definitions/translation_steps.rb +7 -0
  299. data/features/step_definitions/web_steps.rb +197 -0
  300. data/features/step_definitions/within_steps.rb +14 -0
  301. data/features/support/cleaner.rb +4 -0
  302. data/features/support/env.rb +82 -0
  303. data/features/support/factory_girl.rb +2 -0
  304. data/features/support/http.rb +22 -0
  305. data/features/support/paths.rb +62 -0
  306. data/features/support/pickle.rb +24 -0
  307. data/features/support/selectors.rb +57 -0
  308. data/lib/generators/locomotive/install/install_generator.rb +5 -0
  309. data/lib/generators/locomotive/install/templates/dragonfly.rb +2 -3
  310. data/lib/generators/locomotive/install/templates/locomotive.rb +2 -2
  311. data/lib/locomotive.rb +13 -2
  312. data/lib/locomotive/action_controller/locale_helpers.rb +1 -1
  313. data/lib/locomotive/action_controller/public_responder.rb +17 -1
  314. data/lib/locomotive/action_controller/responder.rb +3 -2
  315. data/lib/locomotive/action_controller/url_helpers.rb +1 -1
  316. data/lib/locomotive/cancan.rb +22 -0
  317. data/lib/locomotive/carrierwave.rb +2 -0
  318. data/lib/locomotive/carrierwave/asset.rb +17 -7
  319. data/lib/locomotive/configuration.rb +6 -2
  320. data/lib/locomotive/core_ext.rb +5 -4
  321. data/lib/locomotive/custom_fields.rb +11 -0
  322. data/lib/locomotive/dependencies.rb +3 -3
  323. data/lib/locomotive/dragonfly.rb +1 -1
  324. data/lib/locomotive/engine.rb +24 -8
  325. data/lib/locomotive/formtastic.rb +26 -1
  326. data/lib/locomotive/liquid/drops/current_user.rb +2 -2
  327. data/lib/locomotive/liquid/drops/page.rb +5 -1
  328. data/lib/locomotive/liquid/filters/date.rb +19 -0
  329. data/lib/locomotive/liquid/filters/html.rb +7 -7
  330. data/lib/locomotive/liquid/filters/misc.rb +5 -7
  331. data/lib/locomotive/liquid/filters/text.rb +11 -0
  332. data/lib/locomotive/liquid/filters/translate.rb +16 -0
  333. data/lib/locomotive/liquid/patches.rb +21 -0
  334. data/lib/locomotive/liquid/tags/consume.rb +13 -2
  335. data/lib/locomotive/liquid/tags/csrf.rb +3 -3
  336. data/lib/locomotive/liquid/tags/editable/base.rb +11 -4
  337. data/lib/locomotive/liquid/tags/inline_editor.rb +5 -2
  338. data/lib/locomotive/liquid/tags/locale_switcher.rb +12 -4
  339. data/lib/locomotive/liquid/tags/nav.rb +1 -1
  340. data/lib/locomotive/liquid/tags/paginate.rb +4 -1
  341. data/lib/locomotive/liquid/tags/seo.rb +2 -2
  342. data/lib/locomotive/liquid/tags/snippet.rb +10 -2
  343. data/lib/locomotive/liquid/tags/with_scope.rb +11 -0
  344. data/lib/locomotive/middlewares.rb +2 -1
  345. data/lib/locomotive/middlewares/fonts.rb +2 -2
  346. data/lib/locomotive/middlewares/permalink.rb +22 -0
  347. data/lib/locomotive/misc/api_documentation.rb +114 -0
  348. data/lib/locomotive/misc/api_documentation/bootstrap.html.haml +196 -0
  349. data/lib/locomotive/mongoid.rb +2 -1
  350. data/lib/locomotive/mongoid/document.rb +3 -2
  351. data/lib/locomotive/mongoid/liquid.rb +39 -0
  352. data/lib/locomotive/mongoid/presenter.rb +73 -0
  353. data/lib/locomotive/presentable.rb +216 -0
  354. data/lib/locomotive/render.rb +76 -24
  355. data/lib/locomotive/routing/site_dispatcher.rb +15 -4
  356. data/lib/locomotive/version.rb +1 -1
  357. data/lib/tasks/development.rake +29 -0
  358. data/lib/tasks/locomotive.rake +58 -7
  359. data/spec/cells/locomotive/global_actions_spec.rb +98 -0
  360. data/spec/cells/locomotive/main_menu_cell_spec.rb +99 -0
  361. data/spec/cells/locomotive/settings_menu_cell_spec.rb +107 -0
  362. data/spec/dummy/Rakefile +7 -0
  363. data/spec/dummy/app/assets/javascripts/application.js +9 -0
  364. data/spec/dummy/app/assets/javascripts/locomotive_misc.js.coffee +2 -0
  365. data/spec/dummy/app/assets/stylesheets/application.css +7 -0
  366. data/spec/dummy/app/cells/locomotive/main_menu_cell.rb +9 -0
  367. data/spec/dummy/app/controllers/application_controller.rb +3 -0
  368. data/spec/dummy/app/controllers/foo_controller.rb +10 -0
  369. data/spec/dummy/app/helpers/application_helper.rb +2 -0
  370. data/spec/dummy/app/models/foo.rb +7 -0
  371. data/spec/dummy/app/views/foo/index.html.haml +1 -0
  372. data/spec/dummy/app/views/layouts/application.html.erb +14 -0
  373. data/spec/dummy/app/views/locomotive/shared/_main_app_head.html.haml +1 -0
  374. data/spec/dummy/config.ru +4 -0
  375. data/spec/dummy/config/application.rb +57 -0
  376. data/spec/dummy/config/boot.rb +20 -0
  377. data/spec/dummy/config/environment.rb +5 -0
  378. data/spec/dummy/config/environments/development.rb +38 -0
  379. data/spec/dummy/config/environments/production.rb +60 -0
  380. data/spec/dummy/config/environments/test.rb +39 -0
  381. data/spec/dummy/config/initializers/carrierwave.rb +8 -0
  382. data/spec/dummy/config/initializers/devise.rb +190 -0
  383. data/spec/dummy/config/initializers/dragonfly.rb +21 -0
  384. data/spec/dummy/config/initializers/formtastic.rb +5 -0
  385. data/spec/dummy/config/initializers/haml.rb +2 -0
  386. data/spec/dummy/config/initializers/locomotive.rb +80 -0
  387. data/spec/dummy/config/initializers/secret_token.rb +7 -0
  388. data/spec/dummy/config/initializers/session_store.rb +8 -0
  389. data/spec/dummy/config/initializers/wrap_parameters.rb +14 -0
  390. data/spec/dummy/config/locales/en.yml +10 -0
  391. data/spec/dummy/config/locales/fr.yml +10 -0
  392. data/spec/dummy/config/mongoid.yml +23 -0
  393. data/spec/dummy/config/routes.rb +9 -0
  394. data/spec/dummy/public/404.html +26 -0
  395. data/spec/dummy/public/422.html +26 -0
  396. data/spec/dummy/public/500.html +26 -0
  397. data/spec/dummy/script/rails +6 -0
  398. data/spec/fixtures/assets/5k.png +0 -0
  399. data/spec/fixtures/assets/5k_2.png +0 -0
  400. data/spec/fixtures/assets/application.js +1 -0
  401. data/spec/fixtures/assets/main.css +1 -0
  402. data/spec/fixtures/assets/wrong.txt +1 -0
  403. data/spec/fixtures/images/logo1.jpg +0 -0
  404. data/spec/fixtures/images/logo2.jpg +0 -0
  405. data/spec/lib/core_ext_spec.rb +37 -0
  406. data/spec/lib/locomotive/configuration_spec.rb +26 -0
  407. data/spec/lib/locomotive/httparty/webservice_spec.rb +33 -0
  408. data/spec/lib/locomotive/liquid/drops/content_entry_spec.rb +46 -0
  409. data/spec/lib/locomotive/liquid/drops/current_user.rb +63 -0
  410. data/spec/lib/locomotive/liquid/drops/page_spec.rb +143 -0
  411. data/spec/lib/locomotive/liquid/drops/site_spec.rb +32 -0
  412. data/spec/lib/locomotive/liquid/filters/date_spec.rb +68 -0
  413. data/spec/lib/locomotive/liquid/filters/html_spec.rb +224 -0
  414. data/spec/lib/locomotive/liquid/filters/misc_spec.rb +56 -0
  415. data/spec/lib/locomotive/liquid/filters/resize_spec.rb +61 -0
  416. data/spec/lib/locomotive/liquid/filters/text_spec.rb +32 -0
  417. data/spec/lib/locomotive/liquid/filters/translate_spec.rb +50 -0
  418. data/spec/lib/locomotive/liquid/tags/consume_spec.rb +52 -0
  419. data/spec/lib/locomotive/liquid/tags/csrf_spec.rb +26 -0
  420. data/spec/lib/locomotive/liquid/tags/editable/short_text_spec.rb +46 -0
  421. data/spec/lib/locomotive/liquid/tags/extends_spec.rb +58 -0
  422. data/spec/lib/locomotive/liquid/tags/locale_switcher_spec.rb +47 -0
  423. data/spec/lib/locomotive/liquid/tags/nav_spec.rb +142 -0
  424. data/spec/lib/locomotive/liquid/tags/paginate_spec.rb +139 -0
  425. data/spec/lib/locomotive/liquid/tags/seo_spec.rb +135 -0
  426. data/spec/lib/locomotive/liquid/tags/with_scope_spec.rb +49 -0
  427. data/spec/lib/locomotive/presentable_spec.rb +184 -0
  428. data/spec/lib/locomotive/render_spec.rb +209 -0
  429. data/spec/lib/locomotive/routing/site_dispatcher_spec.rb +258 -0
  430. data/spec/mailers/locomotive/notifications_spec.rb +57 -0
  431. data/spec/models/locomotive/ability_spec.rb +132 -0
  432. data/spec/models/locomotive/account_spec.rb +87 -0
  433. data/spec/models/locomotive/content_asset_spec.rb +46 -0
  434. data/spec/models/locomotive/content_entry_spec.rb +269 -0
  435. data/spec/models/locomotive/content_type_spec.rb +391 -0
  436. data/spec/models/locomotive/editable_control_spec.rb +70 -0
  437. data/spec/models/locomotive/editable_file_spec.rb +95 -0
  438. data/spec/models/locomotive/editable_long_text_spec.rb +50 -0
  439. data/spec/models/locomotive/editable_short_text_spec.rb +174 -0
  440. data/spec/models/locomotive/extensions/page/editable_elements_spec.rb +67 -0
  441. data/spec/models/locomotive/extensions/page/redirect_spec.rb +28 -0
  442. data/spec/models/locomotive/extensions/page/render_spec.rb +88 -0
  443. data/spec/models/locomotive/extensions/site/locales_spec.rb +52 -0
  444. data/spec/models/locomotive/extensions/site/subdomain_domains_spec.rb +25 -0
  445. data/spec/models/locomotive/membership_spec.rb +61 -0
  446. data/spec/models/locomotive/page_spec.rb +427 -0
  447. data/spec/models/locomotive/site_spec.rb +176 -0
  448. data/spec/models/locomotive/snippet_spec.rb +77 -0
  449. data/spec/models/locomotive/theme_asset_spec.rb +128 -0
  450. data/spec/requests/seo_trailing_slash_spec.rb +25 -0
  451. data/spec/support/carrierwave.rb +50 -0
  452. data/spec/support/cells.rb +3 -0
  453. data/spec/support/controller.rb +32 -0
  454. data/spec/support/factories.rb +156 -0
  455. data/spec/support/locomotive.rb +37 -0
  456. data/spec/support/matchers.rb +127 -0
  457. data/spec/support/middlewares.rb +0 -0
  458. data/vendor/assets/fonts/locomotive/fontawesome-webfont.eot +0 -0
  459. data/vendor/assets/fonts/locomotive/fontawesome-webfont.svg +255 -0
  460. data/vendor/assets/fonts/locomotive/fontawesome-webfont.ttf +0 -0
  461. data/vendor/assets/fonts/locomotive/fontawesome-webfont.woff +0 -0
  462. data/vendor/assets/javascripts/locomotive/backbone.modelbinding.js +34 -9
  463. data/vendor/assets/javascripts/locomotive/backbone.sync.js +2 -2
  464. data/vendor/assets/javascripts/locomotive/form_submit_notification.js +2 -2
  465. data/vendor/assets/javascripts/locomotive/growl.js +10 -10
  466. data/vendor/assets/javascripts/locomotive/menu_toggler.js +8 -4
  467. data/vendor/assets/javascripts/locomotive/slugify.js +21 -5
  468. data/vendor/assets/stylesheets/locomotive/font-awesome.scss +329 -0
  469. data/vendor/assets/stylesheets/locomotive/jquery/{ui.css → ui.css.scss} +19 -19
  470. metadata +538 -195
  471. data/app/assets/images/locomotive/background/light.png +0 -0
  472. data/app/assets/images/locomotive/datepicker/ui-widget-left-icon.png +0 -0
  473. data/app/assets/images/locomotive/datepicker/ui-widget-right-icon.png +0 -0
  474. data/app/assets/images/locomotive/form/folded-arrow-off.png +0 -0
  475. data/app/assets/images/locomotive/form/folded-arrow-on.png +0 -0
  476. data/app/assets/images/locomotive/form/icons/drag.png +0 -0
  477. data/app/assets/images/locomotive/form/icons/edit.png +0 -0
  478. data/app/assets/images/locomotive/form/icons/error.png +0 -0
  479. data/app/assets/images/locomotive/form/icons/spinner.gif +0 -0
  480. data/app/assets/images/locomotive/form/icons/trash.png +0 -0
  481. data/app/assets/images/locomotive/form/pen.png +0 -0
  482. data/app/assets/images/locomotive/form/spinner.gif +0 -0
  483. data/app/assets/images/locomotive/icons/actions.png +0 -0
  484. data/app/assets/images/locomotive/icons/asset_add.png +0 -0
  485. data/app/assets/images/locomotive/icons/asset_switch.png +0 -0
  486. data/app/assets/images/locomotive/icons/membership_edit.png +0 -0
  487. data/app/assets/images/locomotive/icons/membership_lock.png +0 -0
  488. data/app/assets/images/locomotive/inline_editor/back.png +0 -0
  489. data/app/assets/images/locomotive/list/icons/cross.png +0 -0
  490. data/app/assets/images/locomotive/list/icons/drag.png +0 -0
  491. data/app/assets/images/locomotive/list/icons/move.png +0 -0
  492. data/app/assets/images/locomotive/list/icons/move_off.png +0 -0
  493. data/app/assets/images/locomotive/list/icons/node_closed.png +0 -0
  494. data/app/assets/images/locomotive/list/icons/node_open.png +0 -0
  495. data/app/assets/images/locomotive/list/icons/pencil.png +0 -0
  496. data/app/assets/images/locomotive/list/icons/pencil_off.png +0 -0
  497. data/app/assets/images/locomotive/list/icons/popup.png +0 -0
  498. data/app/assets/images/locomotive/list/icons/popup_off.png +0 -0
  499. data/app/assets/images/locomotive/list/icons/redirect.png +0 -0
  500. data/app/assets/images/locomotive/list/icons/states.png +0 -0
  501. data/app/assets/images/locomotive/list/icons/template.png +0 -0
  502. data/app/assets/images/locomotive/list/icons/toggle.png +0 -0
  503. data/app/assets/images/locomotive/list/icons/toggle_off.png +0 -0
  504. data/app/assets/images/locomotive/list/icons/trash.png +0 -0
  505. data/app/assets/images/locomotive/list/icons/trash_off.png +0 -0
  506. data/app/assets/images/locomotive/menu/icons.png +0 -0
  507. data/app/assets/images/locomotive/menu/popup/add.png +0 -0
  508. data/app/assets/images/locomotive/menu/popup/bottom-right-corner.png +0 -0
  509. data/app/assets/images/locomotive/menu/popup/bullet.png +0 -0
  510. data/app/assets/images/locomotive/plugins/selectmenu/arrow.png +0 -0
  511. data/app/assets/images/locomotive/plugins/selectmenu/background.png +0 -0
  512. data/app/assets/images/locomotive/plugins/sites_picker_entry_bg.png +0 -0
  513. data/app/assets/images/locomotive/simple/light_bg.png +0 -0
  514. data/app/assets/images/locomotive/simple/wrapper_bg.png +0 -0
  515. data/app/assets/stylesheets/locomotive/backoffice/menu/_icons.css.scss +0 -30
  516. data/app/uploaders/locomotive/theme_uploader.rb +0 -19
  517. data/lib/locomotive/mongoid/model_extensions.rb +0 -1
  518. data/lib/tasks/cucumber.rake +0 -66
  519. data/vendor/assets/stylesheets/locomotive/jquery.css +0 -3
@@ -0,0 +1,25 @@
1
+ Feature: Accounts
2
+ In order to manage accounts programmatically
3
+ As an API user
4
+ I will be able to create and update content entries
5
+
6
+ Background:
7
+ Given I have the site: "test site" set up with id: "4f832c2cb0d86d3f42fffffb"
8
+
9
+ Scenario: Creating a new account
10
+ Given I have an "admin" API token
11
+ When I do an API POST to accounts.json with:
12
+ """
13
+ {
14
+ "account": {
15
+ "name": "New User",
16
+ "email": "new-user4@a.com",
17
+ "password": "asimpleone",
18
+ "password_confirmation": "asimpleone"
19
+ }
20
+ }
21
+ """
22
+ When I do an API GET request to accounts.json
23
+ Then the JSON response should be an array
24
+ And the JSON response should have 2 entries
25
+ And the JSON response at "1/name" should be "New User"
@@ -0,0 +1,19 @@
1
+ Feature: Authentication
2
+ In order to consume the API
3
+ As an admin
4
+ I need to get an authentication token
5
+
6
+ Background:
7
+ Given I have the site: "test site" set up
8
+
9
+ Scenario: Fail to get a token without an email and a password
10
+ When I post to "/locomotive/api/tokens.json"
11
+ Then the JSON response at "message" should be "The request must contain the user email and password."
12
+
13
+ Scenario: Get a token
14
+ When I post to "/locomotive/api/tokens.json" with:
15
+ """
16
+ { "email": "admin@locomotiveapp.org", "password": "easyone" }
17
+ """
18
+ Then the JSON response at "token" should be a string
19
+ And the JSON response should not have "message"
@@ -0,0 +1,125 @@
1
+ Feature: Accounts
2
+ In order to ensure accounts are not tampered with
3
+ As an admin, designer or author
4
+ I will be restricted based on my role
5
+
6
+ Background:
7
+ Given I have the site: "test site" set up with id: "4f832c2cb0d86d3f42fffffb"
8
+ And I have a designer and an author
9
+ And I have accounts:
10
+ | email | id |
11
+ | new-user1@a.com | 4f832c2cb0d86d3f42fffffc |
12
+ | new-user2@a.com | 4f832c2cb0d86d3f42fffffd |
13
+ | new-user3@a.com | 4f832c2cb0d86d3f42fffffe |
14
+
15
+ Scenario: As an unauthenticated user
16
+ Given I am not authenticated
17
+ When I do an API GET request to accounts.json
18
+ Then the JSON response at "error" should be "You need to sign in or sign up before continuing."
19
+
20
+ # listing accounts
21
+
22
+ Scenario: Accessing accounts as an Admin
23
+ Given I have an "admin" API token
24
+ When I do an API GET request to accounts.json
25
+ Then the JSON response should be an array
26
+ And the JSON response should have 6 entries
27
+
28
+ Scenario: Accessing accounts as a Designer
29
+ Given I have a "designer" API token
30
+ When I do an API GET request to accounts.json
31
+ Then an access denied error should occur
32
+
33
+ Scenario: Accessing accounts as an Author
34
+ Given I have an "author" API token
35
+ When I do an API GET request to accounts.json
36
+ Then an access denied error should occur
37
+
38
+ # showing account
39
+
40
+ Scenario: Accessing account as an Admin
41
+ Given I have an "admin" API token
42
+ When I do an API GET request to accounts/4f832c2cb0d86d3f42fffffc.json
43
+ Then the JSON response at "email" should be "new-user1@a.com"
44
+ When I do an API GET request to accounts/4f832c2cb0d86d3f42fffffd.json
45
+ Then the JSON response at "email" should be "new-user2@a.com"
46
+ When I do an API GET request to accounts/4f832c2cb0d86d3f42fffffe.json
47
+ Then the JSON response at "email" should be "new-user3@a.com"
48
+
49
+ Scenario: Accessing account as a Designer
50
+ Given I have a "designer" API token
51
+ When I do an API GET request to accounts/4f832c2cb0d86d3f42fffffc.json
52
+ Then an access denied error should occur
53
+
54
+ Scenario: Accessing account as an Author
55
+ Given I have an "author" API token
56
+ When I do an API GET request to accounts/4f832c2cb0d86d3f42fffffc.json
57
+ Then an access denied error should occur
58
+
59
+ # create account
60
+
61
+ Scenario: Creating new account as an Admin
62
+ Given I have an "admin" API token
63
+ When I do an API POST to accounts.json with:
64
+ """
65
+ {
66
+ "account": {
67
+ "name": "New User",
68
+ "email": "new-user4@a.com",
69
+ "password": "changeme"
70
+ }
71
+ }
72
+ """
73
+ When I do an API GET request to accounts.json
74
+ Then the JSON response should be an array
75
+ And the JSON response should have 7 entries
76
+
77
+ Scenario: Creating new account as a Designer
78
+ Given I have a "designer" API token
79
+ When I do an API POST to accounts.json with:
80
+ """
81
+ {
82
+ "account": {
83
+ "name": "New User",
84
+ "email": "new-user4@a.com",
85
+ "password": "changeme"
86
+ }
87
+ }
88
+ """
89
+ Then an access denied error should occur
90
+
91
+ Scenario: Creating new account as an Author
92
+ Given I have an "author" API token
93
+ When I do an API POST to accounts.json with:
94
+ """
95
+ {
96
+ "account": {
97
+ "name": "New User",
98
+ "email": "new-user4@a.com",
99
+ "password": "changeme"
100
+ }
101
+ }
102
+ """
103
+ Then an access denied error should occur
104
+
105
+ # destroy account
106
+
107
+ Scenario: Destroying account as an Admin
108
+ Given I have an "admin" API token
109
+ When I do an API GET request to accounts.json
110
+ Then the JSON response should be an array
111
+ And the JSON response should have 6 entries
112
+ When I do an API DELETE to accounts/4f832c2cb0d86d3f42fffffe.json
113
+ When I do an API GET request to accounts.json
114
+ Then the JSON response should be an array
115
+ And the JSON response should have 5 entries
116
+
117
+ Scenario: Destroying account as a Designer
118
+ Given I have a "designer" API token
119
+ When I do an API DELETE to accounts/4f832c2cb0d86d3f42fffffe.json
120
+ Then an access denied error should occur
121
+
122
+ Scenario: Deleting account as an Author
123
+ Given I have a "author" API token
124
+ When I do an API DELETE to accounts/4f832c2cb0d86d3f42fffffe.json
125
+ Then an access denied error should occur
@@ -0,0 +1,147 @@
1
+ Feature: Content Assets
2
+ In order to ensure content assets are not tampered with
3
+ As an admin, designer or author
4
+ I will be restricted based on my role
5
+
6
+ Background:
7
+ Given I have the site: "test site" set up
8
+ And I have the following content assets:
9
+ | id | file |
10
+ | 4f832c2cb0d86d3f42fffffe | 5k.png |
11
+ | 4f832c2cb0d86d3f42ffffff | 5k_2.png |
12
+ And I have a designer and an author
13
+
14
+ Scenario: As an unauthenticated user
15
+ Given I am not authenticated
16
+ When I do an API GET to content_assets.json
17
+ Then the JSON response at "error" should be "You need to sign in or sign up before continuing."
18
+
19
+ # listing content assets
20
+
21
+ Scenario: Accessing content assets as an Admin
22
+ Given I have an "admin" API token
23
+ When I do an API GET request to content_assets.json
24
+ Then the JSON response should be an array
25
+ And the JSON response should have 2 entries
26
+
27
+ Scenario: Accessing content assets as a Designer
28
+ Given I have a "designer" API token
29
+ When I do an API GET request to content_assets.json
30
+ Then the JSON response should be an array
31
+ And the JSON response should have 2 entries
32
+
33
+ Scenario: Accessing content assets as an Author
34
+ Given I have an "author" API token
35
+ When I do an API GET request to content_assets.json
36
+ Then the JSON response should be an array
37
+ And the JSON response should have 2 entries
38
+
39
+ # showing content asset
40
+
41
+ Scenario: Accessing content asset as an Admin
42
+ Given I have an "admin" API token
43
+ When I do an API GET request to content_assets/4f832c2cb0d86d3f42fffffe.json
44
+ Then the JSON response at "filename" should be "5k.png"
45
+
46
+ Scenario: Accessing content asset as a Designer
47
+ Given I have a "designer" API token
48
+ When I do an API GET request to content_assets/4f832c2cb0d86d3f42fffffe.json
49
+ Then the JSON response at "filename" should be "5k.png"
50
+
51
+ Scenario: Accessing content asset as an Author
52
+ Given I have an "author" API token
53
+ When I do an API GET request to content_assets/4f832c2cb0d86d3f42fffffe.json
54
+ Then the JSON response at "filename" should be "5k.png"
55
+
56
+ # create content asset
57
+
58
+ Scenario: Creating new content asset as an Admin
59
+ Given I have an "admin" API token
60
+ When I do an API GET request to content_assets.json
61
+ Then the JSON response should be an array
62
+ And the JSON response should have 2 entries
63
+ When I do a multipart API POST to content_assets.json with base key "content_asset" and:
64
+ | source | assets/application.js |
65
+ When I do an API GET request to content_assets.json
66
+ Then the JSON response should be an array
67
+ And the JSON response should have 3 entries
68
+ And the JSON at "2/filename" should be "application.js"
69
+
70
+ Scenario: Creating new content asset as a Designer
71
+ Given I have a "designer" API token
72
+ When I do an API GET request to content_assets.json
73
+ Then the JSON response should be an array
74
+ And the JSON response should have 2 entries
75
+ When I do a multipart API POST to content_assets.json with base key "content_asset" and:
76
+ | source | assets/application.js |
77
+ When I do an API GET request to content_assets.json
78
+ Then the JSON response should be an array
79
+ And the JSON response should have 3 entries
80
+ And the JSON at "2/filename" should be "application.js"
81
+
82
+ Scenario: Creating new content asset as an Author
83
+ Given I have an "author" API token
84
+ When I do an API GET request to content_assets.json
85
+ Then the JSON response should be an array
86
+ And the JSON response should have 2 entries
87
+ When I do a multipart API POST to content_assets.json with base key "content_asset" and:
88
+ | source | assets/application.js |
89
+ When I do an API GET request to content_assets.json
90
+ Then the JSON response should be an array
91
+ And the JSON response should have 3 entries
92
+ And the JSON at "2/filename" should be "application.js"
93
+
94
+ # update content asset
95
+
96
+ Scenario: Updating content asset as an Admin
97
+ Given I have an "admin" API token
98
+ When I do a multipart API PUT to content_assets/4f832c2cb0d86d3f42fffffe.json with base key "content_asset" and:
99
+ | source | assets/main.css |
100
+ When I do an API GET request to content_assets/4f832c2cb0d86d3f42fffffe.json
101
+ Then the JSON response at "filename" should be "main.css"
102
+
103
+ Scenario: Updating content asset as a Designer
104
+ Given I have a "designer" API token
105
+ When I do a multipart API PUT to content_assets/4f832c2cb0d86d3f42fffffe.json with base key "content_asset" and:
106
+ | source | assets/main.css |
107
+ When I do an API GET request to content_assets/4f832c2cb0d86d3f42fffffe.json
108
+ Then the JSON response at "filename" should be "main.css"
109
+
110
+ Scenario: Updating content asset as an Author
111
+ Given I have a "author" API token
112
+ When I do a multipart API PUT to content_assets/4f832c2cb0d86d3f42fffffe.json with base key "content_asset" and:
113
+ | source | assets/main.css |
114
+ When I do an API GET request to content_assets/4f832c2cb0d86d3f42fffffe.json
115
+ Then the JSON response at "filename" should be "main.css"
116
+
117
+ # destroy content asset
118
+
119
+ Scenario: Destroying content asset as an Admin
120
+ Given I have an "admin" API token
121
+ When I do an API GET request to content_assets.json
122
+ Then the JSON response should be an array
123
+ And the JSON response should have 2 entries
124
+ When I do an API DELETE to content_assets/4f832c2cb0d86d3f42fffffe.json
125
+ When I do an API GET request to content_assets.json
126
+ Then the JSON response should be an array
127
+ And the JSON response should have 1 entry
128
+
129
+ Scenario: Destroying content asset as a Designer
130
+ Given I have a "designer" API token
131
+ When I do an API GET request to content_assets.json
132
+ Then the JSON response should be an array
133
+ And the JSON response should have 2 entries
134
+ When I do an API DELETE to content_assets/4f832c2cb0d86d3f42fffffe.json
135
+ When I do an API GET request to content_assets.json
136
+ Then the JSON response should be an array
137
+ And the JSON response should have 1 entry
138
+
139
+ Scenario: Deleting content asset as an Author
140
+ Given I have a "author" API token
141
+ When I do an API GET request to content_assets.json
142
+ Then the JSON response should be an array
143
+ And the JSON response should have 2 entries
144
+ When I do an API DELETE to content_assets/4f832c2cb0d86d3f42fffffe.json
145
+ When I do an API GET request to content_assets.json
146
+ Then the JSON response should be an array
147
+ And the JSON response should have 1 entry
@@ -0,0 +1,202 @@
1
+ Feature: Content Entries
2
+ In order to ensure content entries are not tampered with
3
+ As an admin, designer or author
4
+ I will be restricted based on my role
5
+
6
+ Background:
7
+ Given I have the site: "test site" set up
8
+ And I have a custom model named "Projects" with
9
+ | label | type | required |
10
+ | Name | string | true |
11
+ | Description | text | false |
12
+ And I have entries for "Projects" with
13
+ | id | name | description |
14
+ | 4f832c2cb0d86d3f42fffffe | Project 1 | The first project |
15
+ | 4f832c2cb0d86d3f42ffffff | Project 2 | The second project |
16
+ And I have a designer and an author
17
+
18
+ Scenario: As an unauthenticated user
19
+ Given I am not authenticated
20
+ When I do an API GET to content_types/projects/entries.json
21
+ Then the JSON response at "error" should be "You need to sign in or sign up before continuing."
22
+
23
+ # listing content entries
24
+
25
+ Scenario: Accessing content entries as an Admin
26
+ Given I have an "admin" API token
27
+ When I do an API GET request to content_types/projects/entries.json
28
+ Then the JSON response should be an array
29
+ And the JSON response should have 2 entries
30
+
31
+ Scenario: Accessing content entries as a Designer
32
+ Given I have a "designer" API token
33
+ When I do an API GET request to content_types/projects/entries.json
34
+ Then the JSON response should be an array
35
+ And the JSON response should have 2 entries
36
+
37
+ Scenario: Accessing content entries as an Author
38
+ Given I have an "author" API token
39
+ When I do an API GET request to content_types/projects/entries.json
40
+ Then the JSON response should be an array
41
+ And the JSON response should have 2 entries
42
+
43
+ # showing content entry
44
+
45
+ Scenario: Accessing content entry as an Admin
46
+ Given I have an "admin" API token
47
+ When I do an API GET request to content_types/projects/entries/4f832c2cb0d86d3f42fffffe.json
48
+ Then the JSON response at "id" should be "4f832c2cb0d86d3f42fffffe"
49
+ And the JSON response at "name" should be "Project 1"
50
+
51
+ Scenario: Accessing content entry as a Designer
52
+ Given I have a "designer" API token
53
+ When I do an API GET request to content_types/projects/entries/4f832c2cb0d86d3f42fffffe.json
54
+ Then the JSON response at "id" should be "4f832c2cb0d86d3f42fffffe"
55
+ And the JSON response at "name" should be "Project 1"
56
+
57
+ Scenario: Accessing content entry as an Author
58
+ Given I have an "author" API token
59
+ When I do an API GET request to content_types/projects/entries/4f832c2cb0d86d3f42fffffe.json
60
+ Then the JSON response at "id" should be "4f832c2cb0d86d3f42fffffe"
61
+ And the JSON response at "name" should be "Project 1"
62
+
63
+ # create content entry
64
+
65
+ Scenario: Creating new content entry as an Admin
66
+ Given I have an "admin" API token
67
+ When I do an API GET request to content_types/projects/entries.json
68
+ Then the JSON response should be an array
69
+ And the JSON response should have 2 entries
70
+ When I do an API POST to content_types/projects/entries.json with:
71
+ """
72
+ {
73
+ "content_entry": {
74
+ "name": "Project 3",
75
+ "description": "The third..."
76
+ }
77
+ }
78
+ """
79
+ When I do an API GET request to content_types/projects/entries.json
80
+ Then the JSON response should be an array
81
+ And the JSON response should have 3 entries
82
+ And the JSON should have the following:
83
+ | 2/name | "Project 3" |
84
+ | 2/description | "The third..." |
85
+
86
+ Scenario: Creating new content entry as a Designer
87
+ Given I have a "designer" API token
88
+ When I do an API GET request to content_types/projects/entries.json
89
+ Then the JSON response should be an array
90
+ And the JSON response should have 2 entries
91
+ When I do an API POST to content_types/projects/entries.json with:
92
+ """
93
+ {
94
+ "content_entry": {
95
+ "name": "Project 3",
96
+ "description": "The third..."
97
+ }
98
+ }
99
+ """
100
+ When I do an API GET request to content_types/projects/entries.json
101
+ Then the JSON response should be an array
102
+ And the JSON response should have 3 entries
103
+ And the JSON should have the following:
104
+ | 2/name | "Project 3" |
105
+ | 2/description | "The third..." |
106
+
107
+ Scenario: Creating new content entry as an Author
108
+ Given I have an "author" API token
109
+ When I do an API GET request to content_types/projects/entries.json
110
+ Then the JSON response should be an array
111
+ And the JSON response should have 2 entries
112
+ When I do an API POST to content_types/projects/entries.json with:
113
+ """
114
+ {
115
+ "content_entry": {
116
+ "name": "Project 3",
117
+ "description": "The third..."
118
+ }
119
+ }
120
+ """
121
+ When I do an API GET request to content_types/projects/entries.json
122
+ Then the JSON response should be an array
123
+ And the JSON response should have 3 entries
124
+ And the JSON should have the following:
125
+ | 2/name | "Project 3" |
126
+ | 2/description | "The third..." |
127
+
128
+ # update content entry
129
+
130
+ Scenario: Updating content entry as an Admin
131
+ Given I have an "admin" API token
132
+ When I do an API PUT to content_types/projects/entries/4f832c2cb0d86d3f42fffffe.json with:
133
+ """
134
+ {
135
+ "content_entry": {
136
+ "description": "The awesomest project ever!"
137
+ }
138
+ }
139
+ """
140
+ When I do an API GET request to content_types/projects/entries/4f832c2cb0d86d3f42fffffe.json
141
+ Then the JSON response at "name" should be "Project 1"
142
+ And the JSON response at "description" should be "The awesomest project ever!"
143
+
144
+ Scenario: Updating content entry as a Designer
145
+ Given I have a "designer" API token
146
+ When I do an API PUT to content_types/projects/entries/4f832c2cb0d86d3f42fffffe.json with:
147
+ """
148
+ {
149
+ "content_entry": {
150
+ "description": "The awesomest project ever!"
151
+ }
152
+ }
153
+ """
154
+ When I do an API GET request to content_types/projects/entries/4f832c2cb0d86d3f42fffffe.json
155
+ Then the JSON response at "name" should be "Project 1"
156
+ And the JSON response at "description" should be "The awesomest project ever!"
157
+
158
+ Scenario: Updating content entry as an Author
159
+ Given I have a "author" API token
160
+ When I do an API PUT to content_types/projects/entries/4f832c2cb0d86d3f42fffffe.json with:
161
+ """
162
+ {
163
+ "content_entry": {
164
+ "description": "The awesomest project ever!"
165
+ }
166
+ }
167
+ """
168
+ When I do an API GET request to content_types/projects/entries/4f832c2cb0d86d3f42fffffe.json
169
+ Then the JSON response at "name" should be "Project 1"
170
+ And the JSON response at "description" should be "The awesomest project ever!"
171
+
172
+ # destroy content entry
173
+
174
+ Scenario: Destroying content entry as an Admin
175
+ Given I have an "admin" API token
176
+ When I do an API GET request to content_types/projects/entries.json
177
+ Then the JSON response should be an array
178
+ And the JSON response should have 2 entries
179
+ When I do an API DELETE to content_types/projects/entries/4f832c2cb0d86d3f42fffffe.json
180
+ When I do an API GET request to content_types/projects/entries.json
181
+ Then the JSON response should be an array
182
+ And the JSON response should have 1 entry
183
+
184
+ Scenario: Destroying content entry as a Designer
185
+ Given I have a "designer" API token
186
+ When I do an API GET request to content_types/projects/entries.json
187
+ Then the JSON response should be an array
188
+ And the JSON response should have 2 entries
189
+ When I do an API DELETE to content_types/projects/entries/4f832c2cb0d86d3f42fffffe.json
190
+ When I do an API GET request to content_types/projects/entries.json
191
+ Then the JSON response should be an array
192
+ And the JSON response should have 1 entry
193
+
194
+ Scenario: Deleting content entry as an Author
195
+ Given I have a "author" API token
196
+ When I do an API GET request to content_types/projects/entries.json
197
+ Then the JSON response should be an array
198
+ And the JSON response should have 2 entries
199
+ When I do an API DELETE to content_types/projects/entries/4f832c2cb0d86d3f42fffffe.json
200
+ When I do an API GET request to content_types/projects/entries.json
201
+ Then the JSON response should be an array
202
+ And the JSON response should have 1 entry