fat_free_crm 0.18.1 → 0.20.0

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of fat_free_crm might be problematic. Click here for more details.

Files changed (385) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/brakeman-analysis.yml +46 -0
  3. data/.github/workflows/rubocop-analysis.yml +40 -0
  4. data/.github/workflows/ruby.yml +52 -0
  5. data/.rubocop_todo.yml +80 -173
  6. data/.travis.yml +17 -20
  7. data/CHANGELOG.md +63 -3
  8. data/CONTRIBUTORS.md +1 -0
  9. data/Dockerfile +45 -14
  10. data/Gemfile +21 -11
  11. data/Gemfile.lock +315 -263
  12. data/Procfile +1 -1
  13. data/README.md +6 -5
  14. data/Rakefile +1 -1
  15. data/SECURITY.md +11 -0
  16. data/app/assets/javascripts/application.js.erb +3 -0
  17. data/app/assets/stylesheets/application.css.erb +1 -0
  18. data/app/assets/stylesheets/base.scss +9 -2
  19. data/app/assets/stylesheets/bootstrap-custom.scss +206 -0
  20. data/app/assets/stylesheets/common.scss +88 -68
  21. data/app/assets/stylesheets/header.scss +0 -8
  22. data/app/controllers/admin/application_controller.rb +1 -1
  23. data/app/controllers/admin/field_groups_controller.rb +2 -4
  24. data/app/controllers/admin/fields_controller.rb +1 -1
  25. data/app/controllers/admin/groups_controller.rb +1 -1
  26. data/app/controllers/admin/tags_controller.rb +3 -5
  27. data/app/controllers/admin/users_controller.rb +7 -9
  28. data/app/controllers/application_controller.rb +21 -45
  29. data/app/controllers/comments_controller.rb +3 -6
  30. data/{config/initializers/authlogic.rb → app/controllers/confirmations_controller.rb} +4 -2
  31. data/app/controllers/emails_controller.rb +0 -2
  32. data/app/controllers/entities/accounts_controller.rb +2 -4
  33. data/app/controllers/entities/campaigns_controller.rb +2 -4
  34. data/app/controllers/entities/contacts_controller.rb +4 -24
  35. data/app/controllers/entities/leads_controller.rb +7 -10
  36. data/app/controllers/entities/opportunities_controller.rb +4 -14
  37. data/app/controllers/entities_controller.rb +21 -7
  38. data/app/controllers/home_controller.rb +5 -5
  39. data/app/controllers/lists_controller.rb +1 -1
  40. data/app/controllers/passwords_controller.rb +3 -59
  41. data/{spec/features/support/maintain_sessions.rb → app/controllers/registrations_controller.rb} +12 -5
  42. data/{lib/development_tasks/gem.rake → app/controllers/sessions_controller.rb} +6 -6
  43. data/app/controllers/tasks_controller.rb +11 -20
  44. data/app/controllers/users_controller.rb +11 -30
  45. data/app/helpers/accounts_helper.rb +12 -0
  46. data/app/helpers/admin/users_helper.rb +1 -1
  47. data/app/helpers/application_helper.rb +30 -37
  48. data/app/helpers/campaigns_helper.rb +1 -1
  49. data/app/helpers/contacts_helper.rb +1 -3
  50. data/app/helpers/opportunities_helper.rb +4 -12
  51. data/app/helpers/tasks_helper.rb +3 -3
  52. data/app/helpers/users_helper.rb +1 -3
  53. data/{config/initializers/paper_trail.rb → app/mailers/devise_mailer.rb} +5 -1
  54. data/app/mailers/user_mailer.rb +0 -9
  55. data/app/models/entities/account.rb +11 -11
  56. data/app/models/entities/account_contact.rb +1 -1
  57. data/app/models/entities/account_opportunity.rb +1 -1
  58. data/app/models/entities/campaign.rb +5 -7
  59. data/app/models/entities/contact.rb +25 -13
  60. data/app/models/entities/lead.rb +8 -8
  61. data/app/models/entities/opportunity.rb +8 -10
  62. data/app/models/fields/custom_field.rb +1 -0
  63. data/app/models/fields/custom_field_date_pair.rb +2 -0
  64. data/app/models/fields/custom_field_pair.rb +2 -2
  65. data/app/models/fields/field.rb +1 -3
  66. data/app/models/list.rb +1 -1
  67. data/app/models/observers/entity_observer.rb +3 -7
  68. data/app/models/observers/lead_observer.rb +2 -4
  69. data/app/models/observers/opportunity_observer.rb +3 -5
  70. data/app/models/observers/task_observer.rb +1 -1
  71. data/app/models/polymorphic/address.rb +1 -1
  72. data/app/models/polymorphic/comment.rb +1 -1
  73. data/app/models/polymorphic/email.rb +3 -3
  74. data/app/models/polymorphic/task.rb +14 -10
  75. data/app/models/polymorphic/version.rb +3 -2
  76. data/app/models/setting.rb +5 -1
  77. data/app/models/users/permission.rb +3 -3
  78. data/app/models/users/preference.rb +4 -3
  79. data/app/models/users/user.rb +67 -42
  80. data/app/views/accounts/_edit.html.haml +2 -2
  81. data/app/views/accounts/_new.html.haml +2 -2
  82. data/app/views/accounts/_sidebar_index.html.haml +2 -2
  83. data/app/views/accounts/_sidebar_show.html.haml +19 -19
  84. data/app/views/accounts/_top_section.html.haml +1 -1
  85. data/app/views/accounts/create.js.haml +1 -2
  86. data/app/views/accounts/destroy.js.haml +1 -1
  87. data/app/views/accounts/edit.js.haml +1 -1
  88. data/app/views/accounts/show.html.haml +1 -0
  89. data/app/views/accounts/update.js.haml +4 -5
  90. data/app/views/admin/field_groups/create.js.haml +0 -1
  91. data/app/views/admin/field_groups/destroy.js.haml +0 -1
  92. data/app/views/admin/field_groups/update.js.haml +0 -1
  93. data/app/views/admin/fields/create.js.haml +0 -1
  94. data/app/views/admin/fields/destroy.js.haml +0 -1
  95. data/app/views/admin/fields/update.js.haml +0 -1
  96. data/app/views/admin/groups/create.js.haml +0 -1
  97. data/app/views/admin/groups/destroy.js.haml +0 -1
  98. data/app/views/admin/groups/update.js.haml +0 -1
  99. data/app/views/admin/tags/create.js.haml +0 -1
  100. data/app/views/admin/tags/destroy.js.haml +0 -1
  101. data/app/views/admin/tags/update.js.haml +0 -1
  102. data/app/views/admin/users/_user.html.haml +4 -4
  103. data/app/views/admin/users/create.js.haml +0 -1
  104. data/app/views/admin/users/destroy.js.haml +0 -1
  105. data/app/views/admin/users/update.js.haml +0 -1
  106. data/app/views/campaigns/_edit.html.haml +1 -1
  107. data/app/views/campaigns/_new.html.haml +1 -1
  108. data/app/views/campaigns/_sidebar_index.html.haml +2 -2
  109. data/app/views/campaigns/_sidebar_show.html.haml +68 -67
  110. data/app/views/campaigns/create.js.haml +1 -2
  111. data/app/views/campaigns/destroy.js.haml +1 -1
  112. data/app/views/campaigns/show.html.haml +1 -0
  113. data/app/views/campaigns/update.js.haml +3 -4
  114. data/app/views/comments/_edit.html.haml +1 -1
  115. data/app/views/comments/_new.html.haml +1 -1
  116. data/app/views/comments/update.js.haml +0 -1
  117. data/app/views/contacts/_edit.html.haml +1 -1
  118. data/app/views/contacts/_index_brief.html.haml +1 -1
  119. data/app/views/contacts/_index_full.html.haml +1 -1
  120. data/app/views/contacts/_index_long.html.haml +1 -1
  121. data/app/views/contacts/_new.html.haml +1 -1
  122. data/app/views/contacts/_sidebar_show.html.haml +18 -18
  123. data/app/views/contacts/create.js.haml +0 -1
  124. data/app/views/contacts/destroy.js.haml +1 -1
  125. data/app/views/contacts/show.html.haml +1 -0
  126. data/app/views/contacts/update.js.haml +2 -3
  127. data/app/views/devise/confirmations/new.html.haml +9 -0
  128. data/app/views/devise/mailer/confirmation_instructions.html.haml +4 -0
  129. data/app/views/devise/mailer/password_change.html.haml +3 -0
  130. data/app/views/devise/mailer/reset_password_instructions.html.haml +6 -0
  131. data/app/views/devise/passwords/edit.html.haml +18 -0
  132. data/app/views/devise/passwords/new.html.haml +10 -0
  133. data/app/views/devise/registrations/new.html.haml +21 -0
  134. data/app/views/devise/sessions/new.html.haml +32 -0
  135. data/app/views/entities/_title_bar.html.haml +1 -1
  136. data/app/views/entities/attach.js.haml +2 -2
  137. data/app/views/entities/discard.js.haml +2 -2
  138. data/app/views/home/_opportunity.html.haml +1 -1
  139. data/app/views/home/_task.html.haml +1 -1
  140. data/app/views/home/index.xls.builder +51 -0
  141. data/app/views/layouts/_about.html.haml +5 -5
  142. data/app/views/layouts/_header.html.haml +3 -3
  143. data/app/views/layouts/_sidebar.html.haml +2 -2
  144. data/app/views/layouts/_tabbed.html.haml +14 -11
  145. data/app/views/layouts/admin/_header.html.haml +1 -1
  146. data/app/views/layouts/application.html.haml +2 -2
  147. data/app/views/leads/_edit.html.haml +2 -2
  148. data/app/views/leads/_new.html.haml +2 -2
  149. data/app/views/leads/_sidebar_index.html.haml +2 -2
  150. data/app/views/leads/_sidebar_show.html.haml +30 -30
  151. data/app/views/leads/create.js.haml +2 -3
  152. data/app/views/leads/destroy.js.haml +2 -2
  153. data/app/views/leads/promote.js.haml +3 -4
  154. data/app/views/leads/reject.js.haml +3 -3
  155. data/app/views/leads/show.html.haml +1 -1
  156. data/app/views/leads/update.js.haml +4 -5
  157. data/app/views/lists/create.js.haml +0 -1
  158. data/app/views/opportunities/_edit.html.haml +1 -1
  159. data/app/views/opportunities/_index_brief.html.haml +1 -1
  160. data/app/views/opportunities/_index_long.html.haml +1 -1
  161. data/app/views/opportunities/_new.html.haml +1 -1
  162. data/app/views/opportunities/_sidebar_index.html.haml +2 -2
  163. data/app/views/opportunities/_sidebar_show.html.haml +47 -46
  164. data/app/views/opportunities/create.js.haml +3 -4
  165. data/app/views/opportunities/destroy.js.haml +3 -3
  166. data/app/views/opportunities/show.html.haml +1 -0
  167. data/app/views/opportunities/update.js.haml +5 -6
  168. data/app/views/shared/_address.html.haml +5 -5
  169. data/app/views/shared/_empty.html.haml +1 -1
  170. data/app/views/shared/_inline_styles.html.haml +0 -26
  171. data/app/views/shared/_paginate_with_per_page.html.haml +1 -0
  172. data/app/views/tasks/_assigned.html.haml +1 -1
  173. data/app/views/tasks/_completed.html.haml +1 -1
  174. data/app/views/tasks/_edit.html.haml +1 -1
  175. data/app/views/tasks/_new.html.haml +1 -1
  176. data/app/views/tasks/_pending.html.haml +1 -1
  177. data/app/views/tasks/_related.html.haml +1 -1
  178. data/app/views/tasks/_selector.html.haml +7 -8
  179. data/app/views/tasks/_sidebar_index.html.haml +2 -2
  180. data/app/views/tasks/_title.html.haml +1 -1
  181. data/app/views/tasks/complete.js.haml +1 -1
  182. data/app/views/tasks/create.js.haml +1 -2
  183. data/app/views/tasks/destroy.js.haml +1 -1
  184. data/app/views/tasks/uncomplete.js.haml +1 -2
  185. data/app/views/tasks/update.js.haml +0 -1
  186. data/app/views/users/_avatar.html.haml +1 -1
  187. data/app/views/users/change_password.js.haml +0 -1
  188. data/app/views/users/update.js.haml +0 -1
  189. data/app/views/users/upload_avatar.js.haml +0 -1
  190. data/app/views/versions/_version_item.html.haml +1 -1
  191. data/bin/bundle +1 -1
  192. data/bin/rails +1 -1
  193. data/bin/setup +38 -0
  194. data/bin/update +33 -0
  195. data/bin/yarn +13 -0
  196. data/config/application.rb +8 -6
  197. data/config/boot.rb +1 -1
  198. data/config/brakeman.ignore +2 -2
  199. data/config/database.postgres.docker.yml +5 -5
  200. data/config/environment.rb +2 -2
  201. data/config/environments/development.rb +1 -0
  202. data/config/environments/test.rb +7 -0
  203. data/config/initializers/action_mailer.rb +1 -3
  204. data/config/initializers/application_controller_renderer.rb +9 -0
  205. data/config/initializers/assets.rb +6 -11
  206. data/config/initializers/backtrace_silencers.rb +0 -6
  207. data/config/initializers/content_security_policy.rb +31 -0
  208. data/config/initializers/cookies_serializer.rb +3 -6
  209. data/config/initializers/devise.rb +289 -0
  210. data/config/initializers/filter_parameter_logging.rb +0 -5
  211. data/config/initializers/gravatar.rb +0 -1
  212. data/config/initializers/inflections.rb +0 -6
  213. data/config/initializers/mime_types.rb +1 -9
  214. data/config/initializers/new_framework_defaults_6_0.rb +46 -0
  215. data/config/initializers/relative_url_root.rb +1 -3
  216. data/config/initializers/session_store.rb +1 -3
  217. data/config/initializers/simple_form.rb +135 -55
  218. data/config/initializers/simple_form_bootstrap.rb +433 -0
  219. data/config/initializers/wrap_parameters.rb +4 -9
  220. data/config/locales/fat_free_crm.cs.yml +86 -47
  221. data/config/locales/fat_free_crm.en-GB.yml +5 -5
  222. data/config/locales/fat_free_crm.en-US.yml +5 -5
  223. data/config/locales/fat_free_crm.fr.yml +1 -1
  224. data/config/locales/fat_free_crm.ru.yml +2 -0
  225. data/config/routes.rb +20 -9
  226. data/config/settings.default.yml +0 -41
  227. data/db/demo/users.yml +62 -81
  228. data/db/migrate/20100928030620_remove_uuid.rb +1 -2
  229. data/db/migrate/20120316045804_activities_to_versions.rb +1 -0
  230. data/db/migrate/20120510025219_add_not_null_constraints_for_timestamp_columns.rb +1 -0
  231. data/db/migrate/20180107082701_authlogic_to_devise.rb +58 -0
  232. data/db/migrate/20200806004152_add_pattern_to_fields.rb +7 -0
  233. data/db/migrate/20200806004459_add_html5_to_fields.rb +10 -0
  234. data/db/schema.rb +58 -48
  235. data/docker-compose.yml +10 -0
  236. data/fat_free_crm.gemspec +13 -15
  237. data/lib/development_tasks/license.rake +2 -2
  238. data/lib/fat_free_crm/callback.rb +2 -2
  239. data/lib/fat_free_crm/comment_extensions.rb +2 -4
  240. data/lib/fat_free_crm/core_ext/string.rb +1 -1
  241. data/lib/fat_free_crm/core_ext.rb +1 -1
  242. data/lib/fat_free_crm/engine.rb +1 -1
  243. data/lib/fat_free_crm/errors.rb +1 -1
  244. data/lib/fat_free_crm/export_csv.rb +1 -0
  245. data/lib/fat_free_crm/exportable.rb +1 -1
  246. data/lib/fat_free_crm/fields.rb +1 -1
  247. data/lib/fat_free_crm/gem_dependencies.rb +1 -1
  248. data/lib/fat_free_crm/gem_ext.rb +0 -1
  249. data/lib/fat_free_crm/i18n.rb +2 -2
  250. data/lib/fat_free_crm/mail_processor/base.rb +4 -10
  251. data/lib/fat_free_crm/mail_processor/dropbox.rb +5 -15
  252. data/lib/fat_free_crm/permissions.rb +7 -4
  253. data/lib/fat_free_crm/sortable.rb +1 -1
  254. data/lib/fat_free_crm/tabs.rb +2 -2
  255. data/lib/fat_free_crm/version.rb +2 -2
  256. data/lib/gravatar_image_tag.rb +8 -9
  257. data/lib/missing_translation_detector.rb +1 -0
  258. data/lib/tasks/ffcrm/missing_translations.rake +1 -0
  259. data/lib/tasks/ffcrm/preference_update.rake +19 -0
  260. data/lib/tasks/ffcrm/setup.rake +11 -2
  261. data/lib/tasks/ffcrm/update_data.rake +2 -2
  262. data/lib/templates/erb/scaffold/_form.html.erb +4 -2
  263. data/script/rails +2 -2
  264. data/spec/controllers/admin/users_controller_spec.rb +0 -56
  265. data/spec/controllers/comments_controller_spec.rb +12 -12
  266. data/spec/controllers/entities/campaigns_controller_spec.rb +1 -1
  267. data/spec/controllers/entities/contacts_controller_spec.rb +2 -1
  268. data/spec/controllers/entities/leads_controller_spec.rb +2 -2
  269. data/spec/controllers/entities/opportunities_controller_spec.rb +1 -1
  270. data/spec/controllers/entities_controller_spec.rb +5 -0
  271. data/spec/controllers/home_controller_spec.rb +8 -8
  272. data/spec/controllers/tasks_controller_spec.rb +6 -4
  273. data/spec/controllers/users_controller_spec.rb +41 -99
  274. data/spec/factories/account_factories.rb +5 -5
  275. data/spec/factories/campaign_factories.rb +3 -3
  276. data/spec/factories/contact_factories.rb +8 -8
  277. data/spec/factories/field_factories.rb +4 -3
  278. data/spec/factories/lead_factories.rb +5 -5
  279. data/spec/factories/list_factories.rb +2 -2
  280. data/spec/factories/opportunity_factories.rb +3 -3
  281. data/spec/factories/setting_factories.rb +2 -2
  282. data/spec/factories/shared_factories.rb +11 -9
  283. data/spec/factories/task_factories.rb +7 -7
  284. data/spec/factories/user_factories.rb +21 -21
  285. data/spec/features/acceptance_helper.rb +1 -1
  286. data/spec/features/accounts_spec.rb +2 -2
  287. data/spec/features/admin/groups_spec.rb +2 -2
  288. data/spec/features/admin/users_spec.rb +4 -2
  289. data/spec/features/campaigns_spec.rb +3 -3
  290. data/spec/features/contacts_spec.rb +3 -6
  291. data/spec/features/dashboard_spec.rb +1 -1
  292. data/spec/features/devise/sign_in_spec.rb +58 -0
  293. data/spec/features/devise/sign_up_spec.rb +36 -0
  294. data/spec/features/leads_spec.rb +12 -8
  295. data/spec/features/opportunities_overview_spec.rb +1 -1
  296. data/spec/features/opportunities_spec.rb +7 -7
  297. data/spec/features/support/browser.rb +8 -3
  298. data/spec/features/support/selector_helpers.rb +10 -1
  299. data/spec/features/tasks_spec.rb +7 -7
  300. data/spec/helpers/accounts_helper_spec.rb +57 -0
  301. data/spec/helpers/admin/field_groups_helper_spec.rb +1 -1
  302. data/spec/helpers/users_helper_spec.rb +4 -4
  303. data/spec/lib/comment_extensions_spec.rb +10 -4
  304. data/spec/lib/errors_spec.rb +2 -2
  305. data/spec/lib/mail_processor/dropbox_spec.rb +1 -1
  306. data/spec/lib/mail_processor/sample_emails/dropbox.rb +8 -8
  307. data/spec/lib/permissions_spec.rb +8 -3
  308. data/spec/mailers/devise_mailer_spec.rb +35 -0
  309. data/spec/mailers/user_mailer_spec.rb +0 -26
  310. data/spec/models/entities/account_spec.rb +27 -0
  311. data/spec/models/entities/contact_spec.rb +96 -1
  312. data/spec/models/entities/opportunity_spec.rb +2 -2
  313. data/spec/models/fields/custom_field_date_pair_spec.rb +4 -2
  314. data/spec/models/fields/custom_field_pair_spec.rb +2 -2
  315. data/spec/models/fields/custom_field_spec.rb +4 -2
  316. data/spec/models/observers/entity_observer_spec.rb +4 -4
  317. data/spec/models/polymorphic/task_spec.rb +11 -11
  318. data/spec/models/polymorphic/version_spec.rb +9 -9
  319. data/spec/models/users/preference_spec.rb +1 -1
  320. data/spec/models/users/user_spec.rb +22 -26
  321. data/spec/routing/users_routing_spec.rb +30 -8
  322. data/spec/shared/controllers.rb +3 -9
  323. data/spec/spec_helper.rb +10 -2
  324. data/spec/support/assert_select.rb +1 -0
  325. data/spec/support/devise_helpers.rb +28 -0
  326. data/spec/{features/support/helpers.rb → support/feature_helpers.rb} +10 -10
  327. data/spec/support/macros.rb +4 -1
  328. data/spec/views/accounts/_edit.haml_spec.rb +1 -1
  329. data/spec/views/accounts/_new.haml_spec.rb +1 -1
  330. data/spec/views/accounts/create.js.haml_spec.rb +1 -2
  331. data/spec/views/accounts/update.js.haml_spec.rb +2 -5
  332. data/spec/views/admin/field_groups/create.js.haml_spec.rb +0 -1
  333. data/spec/views/admin/field_groups/update.js.haml_spec.rb +0 -1
  334. data/spec/views/admin/users/create.js.haml_spec.rb +0 -1
  335. data/spec/views/admin/users/destroy.js.haml_spec.rb +0 -6
  336. data/spec/views/admin/users/update.js.haml_spec.rb +1 -2
  337. data/spec/views/campaigns/_edit.haml_spec.rb +1 -1
  338. data/spec/views/campaigns/_new.haml_spec.rb +1 -1
  339. data/spec/views/campaigns/create.js.haml_spec.rb +1 -2
  340. data/spec/views/campaigns/destroy.js.haml_spec.rb +0 -1
  341. data/spec/views/campaigns/edit.js.haml_spec.rb +2 -2
  342. data/spec/views/campaigns/index.js.haml_spec.rb +1 -1
  343. data/spec/views/campaigns/update.js.haml_spec.rb +3 -7
  344. data/spec/views/contacts/_edit.haml_spec.rb +1 -1
  345. data/spec/views/contacts/_new.haml_spec.rb +1 -1
  346. data/spec/views/contacts/create.js.haml_spec.rb +1 -2
  347. data/spec/views/contacts/edit.js.haml_spec.rb +1 -1
  348. data/spec/views/contacts/index.js.html_spec.rb +1 -1
  349. data/spec/views/contacts/update.js.haml_spec.rb +6 -10
  350. data/spec/views/home/index.haml_spec.rb +2 -2
  351. data/spec/views/leads/_edit.haml_spec.rb +1 -1
  352. data/spec/views/leads/_new.haml_spec.rb +1 -1
  353. data/spec/views/leads/create.js.haml_spec.rb +0 -3
  354. data/spec/views/leads/destroy.js.haml_spec.rb +0 -2
  355. data/spec/views/leads/promote.js.haml_spec.rb +3 -11
  356. data/spec/views/leads/reject.js.haml_spec.rb +0 -3
  357. data/spec/views/leads/update.js.haml_spec.rb +3 -11
  358. data/spec/views/opportunities/_edit.haml_spec.rb +1 -1
  359. data/spec/views/opportunities/_new.haml_spec.rb +1 -1
  360. data/spec/views/opportunities/create.js.haml_spec.rb +0 -2
  361. data/spec/views/opportunities/destroy.js.haml_spec.rb +0 -3
  362. data/spec/views/opportunities/update.js.haml_spec.rb +4 -12
  363. data/spec/views/tasks/_edit.haml_spec.rb +1 -1
  364. data/spec/views/tasks/complete.js.haml_spec.rb +0 -1
  365. data/spec/views/tasks/create.js.haml_spec.rb +0 -2
  366. data/spec/views/tasks/destroy.js.haml_spec.rb +0 -1
  367. data/spec/views/tasks/uncomplete.js.haml_spec.rb +0 -1
  368. data/spec/views/tasks/update.js.haml_spec.rb +1 -4
  369. data/spec/views/users/change_password.js.haml_spec.rb +1 -2
  370. data/spec/views/users/update.js.haml_spec.rb +1 -2
  371. data/spec/views/users/upload_avatar.js.haml_spec.rb +1 -2
  372. metadata +63 -77
  373. data/app/controllers/authentications_controller.rb +0 -53
  374. data/app/models/users/authentication.rb +0 -56
  375. data/app/views/authentications/new.html.haml +0 -19
  376. data/app/views/passwords/edit.html.haml +0 -15
  377. data/app/views/passwords/new.html.haml +0 -10
  378. data/app/views/user_mailer/password_reset_instructions.html.haml +0 -6
  379. data/app/views/users/new.html.haml +0 -19
  380. data/lib/fat_free_crm/gem_ext/simple_form/action_view_extensions/form_helper.rb +0 -26
  381. data/spec/controllers/authentications_controller_spec.rb +0 -150
  382. data/spec/controllers/passwords_controller_spec.rb +0 -32
  383. data/spec/models/users/authentication_spec.rb +0 -19
  384. data/spec/support/auth_macros.rb +0 -49
  385. data/spec/views/authentications/new.haml_spec.rb +0 -31
data/docker-compose.yml CHANGED
@@ -5,13 +5,23 @@ services:
5
5
  links:
6
6
  - db
7
7
  ports:
8
+ - "3000:3000"
8
9
  - "80:80"
9
10
  volumes:
10
11
  - gems:/usr/local/rvm/gems
11
12
  environment:
12
13
  RAILS_ENV: 'production'
13
14
  PASSENGER_APP_ENV: 'production'
15
+ DB_DATABASE: 'fat_free_crm_production'
16
+ DB_USERNAME: 'postgres'
17
+ DB_PASSWORD: ''
18
+ DB_HOST: 'db'
19
+ DB_PORT: 5432
14
20
  db:
15
21
  image: postgres:9.5
22
+ restart: always
23
+ volumes:
24
+ - pgdata:/var/lib/postgresql/data
16
25
  volumes:
26
+ pgdata: {}
17
27
  gems: {}
data/fat_free_crm.gemspec CHANGED
@@ -1,32 +1,32 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- $LOAD_PATH.push File.expand_path('../vendor/gems/globby-0.1.2/lib', __FILE__)
3
+ $LOAD_PATH.push File.expand_path('vendor/gems/globby-0.1.2/lib', __dir__)
4
4
  require 'globby'
5
- rules = File.read("#{File.expand_path('..', __FILE__)}/.gitignore").split("\n")
5
+ rules = File.read("#{File.expand_path(__dir__)}/.gitignore").split("\n")
6
6
  rules << '.git'
7
7
  files = Globby.reject(rules)
8
8
 
9
- $LOAD_PATH.push File.expand_path('../lib', __FILE__)
9
+ $LOAD_PATH.push File.expand_path('lib', __dir__)
10
10
  require 'fat_free_crm/version'
11
11
 
12
12
  Gem::Specification.new do |gem|
13
13
  gem.name = 'fat_free_crm'
14
- gem.authors = ['Michael Dvorkin', 'Ben Tillman', 'Nathan Broadbent', 'Stephen Kenworthy', "Daniel O'Connor"]
14
+ gem.authors = ['Michael Dvorkin', 'Stephen Kenworthy', "Daniel O'Connor"]
15
15
  gem.summary = 'Fat Free CRM'
16
16
  gem.description = 'An open source, Ruby on Rails customer relationship management platform'
17
17
  gem.homepage = 'http://fatfreecrm.com'
18
- gem.email = ['mike@fatfreecrm.com', 'nathan@fatfreecrm.com', 'warp@fatfreecrm.com', 'steveyken@gmail.com', 'daniel.oconnor@gmail.com']
18
+ gem.email = ['mike@fatfreecrm.com', 'steveyken@gmail.com', 'daniel.oconnor@gmail.com']
19
19
  gem.files = files
20
20
  gem.version = FatFreeCRM::VERSION::STRING
21
21
  gem.required_ruby_version = '>= 2.4.0'
22
22
  gem.license = 'MIT'
23
23
 
24
- gem.add_dependency 'rails', '~> 5.1.0'
24
+ gem.add_dependency 'rails', '~> 6.0.0'
25
25
  gem.add_dependency 'rails-i18n'
26
26
  gem.add_dependency 'rails-observers'
27
27
  gem.add_dependency 'activemodel-serializers-xml'
28
28
  gem.add_dependency 'sprockets-rails', '>= 3.0.0'
29
- gem.add_dependency 'responders', '~> 2.0'
29
+ gem.add_dependency 'responders', '~> 3.0'
30
30
  gem.add_dependency 'jquery-rails'
31
31
  gem.add_dependency 'jquery-migrate-rails'
32
32
  gem.add_dependency 'jquery-ui-rails'
@@ -34,18 +34,17 @@ Gem::Specification.new do |gem|
34
34
  gem.add_dependency 'simple_form'
35
35
  gem.add_dependency 'will_paginate'
36
36
  gem.add_dependency 'paperclip'
37
- # Manually added paperclip gem dependency "cocaine" in order to fix load error: "no such file to load -- cocaine"
38
- gem.add_dependency 'cocaine'
39
- gem.add_dependency 'paper_trail', '~> 6.0.0'
40
- gem.add_dependency 'authlogic', '>= 3.4.4'
41
- gem.add_dependency 'acts_as_commentable'
37
+ gem.add_dependency 'paper_trail', '~> 12.0.0'
38
+ gem.add_dependency 'devise', '~> 4.6'
39
+ gem.add_dependency 'devise-encryptable', '~> 0.2.0'
40
+ gem.add_dependency 'acts_as_commentable', '~> 6.0.0'
42
41
  gem.add_dependency 'acts-as-taggable-on', '>= 3.4.3'
43
42
  gem.add_dependency 'dynamic_form'
44
43
  gem.add_dependency 'haml'
45
44
  gem.add_dependency 'sass'
46
45
  gem.add_dependency 'acts_as_list'
47
46
  gem.add_dependency 'ffaker', '>= 2'
48
- gem.add_dependency 'cancancan'
47
+ gem.add_dependency 'cancancan', '~> 3.0.0'
49
48
  gem.add_dependency 'font-awesome-rails'
50
49
  gem.add_dependency 'premailer'
51
50
  gem.add_dependency 'nokogiri'
@@ -58,7 +57,6 @@ Gem::Specification.new do |gem|
58
57
 
59
58
  # FatFreeCRM has released it's own versions of the following gems:
60
59
  #-----------------------------------------------------------------
61
- gem.add_dependency 'ransack_ui', '~> 1.3', '>= 1.3.1'
62
- gem.add_dependency 'ransack', '~> 1.7', '>= 1.6.2'
60
+ gem.add_dependency 'ransack', '>= 1.6.2'
63
61
  gem.add_dependency 'email_reply_parser_ffcrm'
64
62
  end
@@ -44,8 +44,8 @@ namespace :license do
44
44
  css: "/*\n" + LICENSE_RB.gsub(/^#/, ' *').sub(/---\n/, "---\n */\n") }
45
45
 
46
46
  REGEXPS = { ruby: /^# Copyright \(c\).*?\n(?:#.*\n)*?#-{10}-*\n/,
47
- js: /^\/\/ Copyright \(c\).*?\n(?:\/\/.*\n)*?\/\/-{10}-*\n/,
48
- css: /^\/\*\n \* Copyright \(c\).*?\n(?: \*.*\n)*? \*-{10}-*\n \*\/\n/ }
47
+ js: %r{^// Copyright \(c\).*?\n(?://.*\n)*?//-{10}-*\n},
48
+ css: %r{^/\*\n \* Copyright \(c\).*?\n(?: \*.*\n)*? \*-{10}-*\n \*/\n} }
49
49
 
50
50
  def expand_globs(globs)
51
51
  globs.map { |f| Dir.glob(f) }.flatten.uniq
@@ -143,5 +143,5 @@ module FatFreeCRM
143
143
  end
144
144
  end
145
145
 
146
- ActionView::Base.send(:include, FatFreeCRM::Callback::Helper)
147
- ActionController::Base.send(:include, FatFreeCRM::Callback::Helper)
146
+ ActionView::Base.include FatFreeCRM::Callback::Helper
147
+ ActionController::Base.include FatFreeCRM::Callback::Helper
@@ -13,9 +13,7 @@ module FatFreeCRM
13
13
 
14
14
  module ClassMethods
15
15
  def uses_comment_extensions
16
- unless included_modules.include?(InstanceMethods)
17
- include FatFreeCRM::CommentExtensions::InstanceMethods
18
- end
16
+ include FatFreeCRM::CommentExtensions::InstanceMethods unless included_modules.include?(InstanceMethods)
19
17
  end
20
18
  end
21
19
 
@@ -27,4 +25,4 @@ module FatFreeCRM
27
25
  end
28
26
  end
29
27
 
30
- ActiveRecord::Base.send(:include, FatFreeCRM::CommentExtensions)
28
+ ActiveRecord::Base.include FatFreeCRM::CommentExtensions
@@ -21,7 +21,7 @@ class String
21
21
  end
22
22
 
23
23
  def to_url
24
- match?(/^https?:\/\//) ? self : "http://#{self}"
24
+ match?(%r{^https?://}) ? self : "http://#{self}"
25
25
  end
26
26
 
27
27
  def true?
@@ -5,4 +5,4 @@
5
5
  # Fat Free CRM is freely distributable under the terms of MIT license.
6
6
  # See MIT-LICENSE file or http://www.opensource.org/licenses/mit-license.php
7
7
  #------------------------------------------------------------------------------
8
- Dir[File.dirname(__FILE__) + "/core_ext/*.rb"].each { |file| require(file) }
8
+ Dir[File.dirname(__FILE__) + "/core_ext/*.rb"].sort.each { |file| require(file) }
@@ -14,7 +14,7 @@ module FatFreeCRM
14
14
  task_observer entity_observer]
15
15
 
16
16
  initializer "model_core.factories", after: "factory_bot.set_factory_paths" do
17
- FactoryBot.definition_file_paths << File.expand_path('../../../spec/factories', __FILE__) if defined?(FactoryBot)
17
+ FactoryBot.definition_file_paths << File.expand_path('../../spec/factories', __dir__) if defined?(FactoryBot)
18
18
  end
19
19
 
20
20
  initializer :append_migrations do |app|
@@ -36,4 +36,4 @@ module FatFreeCRM
36
36
  end
37
37
  end
38
38
 
39
- ActiveModel::Errors.send(:include, FatFreeCRM::ActiveModel::Errors)
39
+ ActiveModel::Errors.include FatFreeCRM::ActiveModel::Errors
@@ -14,6 +14,7 @@ module FatFreeCRM
14
14
  #----------------------------------------------------------------------------
15
15
  def self.from_array(items = [])
16
16
  return '' if items.empty?
17
+
17
18
  # Infer column types from the first item in the array
18
19
  klass = items.first.class
19
20
  columns = klass.columns.map(&:name).reject { |column| column =~ /password|token/ }
@@ -48,4 +48,4 @@ module FatFreeCRM
48
48
  end
49
49
  end
50
50
 
51
- ActiveRecord::Base.send(:include, FatFreeCRM::Exportable)
51
+ ActiveRecord::Base.include FatFreeCRM::Exportable
@@ -92,4 +92,4 @@ module FatFreeCRM
92
92
  end
93
93
  end
94
94
 
95
- ActiveRecord::Base.send(:include, FatFreeCRM::Fields)
95
+ ActiveRecord::Base.include FatFreeCRM::Fields
@@ -22,7 +22,7 @@ require 'dynamic_form'
22
22
  require 'paperclip'
23
23
  require 'simple_form'
24
24
  require 'will_paginate'
25
- require 'authlogic'
25
+ require 'devise'
26
26
  require 'ransack'
27
27
  require 'ransack_ui'
28
28
  require 'paper_trail'
@@ -7,5 +7,4 @@
7
7
  #------------------------------------------------------------------------------
8
8
  require "fat_free_crm/gem_ext/active_support/buffered_logger"
9
9
  require "fat_free_crm/gem_ext/action_controller/base"
10
- require "fat_free_crm/gem_ext/simple_form/action_view_extensions/form_helper"
11
10
  require "fat_free_crm/gem_ext/rake/task" if defined?(Rake)
@@ -40,5 +40,5 @@ module FatFreeCRM
40
40
  end
41
41
  end
42
42
 
43
- ActionView::Base.send(:include, FatFreeCRM::I18n)
44
- ActionController::Base.send(:include, FatFreeCRM::I18n)
43
+ ActionView::Base.include FatFreeCRM::I18n
44
+ ActionController::Base.include FatFreeCRM::I18n
@@ -50,9 +50,7 @@ module FatFreeCRM
50
50
 
51
51
  #--------------------------------------------------------------------------------------
52
52
  def run(dry_run = false)
53
- if @dry_run = dry_run
54
- log "Not discarding or archiving any new messages..."
55
- end
53
+ log "Not discarding or archiving any new messages..." if @dry_run = dry_run
56
54
  connect! || (return nil)
57
55
  with_new_emails do |uid, email|
58
56
  # Subclasses must define a #process method that takes arguments: uid, email
@@ -127,9 +125,7 @@ module FatFreeCRM
127
125
  if @dry_run
128
126
  log "Not discarding message"
129
127
  else
130
- if @settings[:move_invalid_to_folder]
131
- @imap.uid_copy(uid, @settings[:move_invalid_to_folder])
132
- end
128
+ @imap.uid_copy(uid, @settings[:move_invalid_to_folder]) if @settings[:move_invalid_to_folder]
133
129
  @imap.uid_store(uid, "+FLAGS", [:Deleted])
134
130
  end
135
131
  @discarded += 1
@@ -141,9 +137,7 @@ module FatFreeCRM
141
137
  if @dry_run
142
138
  log "Not archiving message"
143
139
  else
144
- if @settings[:move_to_folder]
145
- @imap.uid_copy(uid, @settings[:move_to_folder])
146
- end
140
+ @imap.uid_copy(uid, @settings[:move_to_folder]) if @settings[:move_to_folder]
147
141
  @imap.uid_store(uid, "+FLAGS", [:Seen])
148
142
  end
149
143
  @archived += 1
@@ -171,7 +165,7 @@ module FatFreeCRM
171
165
  email: email_address.downcase
172
166
  )
173
167
  # Set the PaperTrail user for versions (if user is found)
174
- PaperTrail.whodunnit = @sender.id.to_s
168
+ PaperTrail.request.whodunnit = @sender.id.to_s
175
169
  end
176
170
  end
177
171
 
@@ -54,9 +54,7 @@ module FatFreeCRM
54
54
  #--------------------------------------------------------------------------------------
55
55
  def with_explicit_keyword(email)
56
56
  first_line = plain_text_body(email).split("\n").first
57
- if first_line =~ /(#{KEYWORDS.join('|')})[^a-zA-Z0-9]+(.+)$/i
58
- yield Regexp.last_match[1].capitalize, Regexp.last_match[2].strip
59
- end
57
+ yield Regexp.last_match[1].capitalize, Regexp.last_match[2].strip if first_line =~ /(#{KEYWORDS.join('|')})[^a-zA-Z0-9]+(.+)$/i
60
58
  end
61
59
 
62
60
  # Checks the email to detect assets on to/bcc addresses
@@ -68,9 +66,7 @@ module FatFreeCRM
68
66
 
69
67
  # Ignore the dropbox email address, and any address aliases
70
68
  ignored_addresses = [@settings[:address]]
71
- if @settings[:address_aliases].is_a?(Array)
72
- ignored_addresses += @settings[:address_aliases]
73
- end
69
+ ignored_addresses += @settings[:address_aliases] if @settings[:address_aliases].is_a?(Array)
74
70
  recipients -= ignored_addresses
75
71
 
76
72
  # Process each recipient until email has been attached
@@ -83,9 +79,7 @@ module FatFreeCRM
83
79
  # Checks the email to detect valid email address in body (first email), detect forwarded emails
84
80
  #----------------------------------------------------------------------------------------
85
81
  def with_forwarded_recipient(email, _options = {})
86
- if plain_text_body(email) =~ /\b([a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,4})\b/
87
- yield Regexp.last_match[1]
88
- end
82
+ yield Regexp.last_match[1] if plain_text_body(email) =~ /\b([a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,4})\b/
89
83
  end
90
84
 
91
85
  # Process pipe_separated_data or explicit keyword.
@@ -132,9 +126,7 @@ module FatFreeCRM
132
126
  asset = klass.where(["(lower(email) = ?)", recipient.downcase]).first
133
127
 
134
128
  # Leads and Contacts have an alt_email: try it if lookup by primary email has failed.
135
- if !asset && klass.column_names.include?("alt_email")
136
- asset = klass.where(["(lower(alt_email) = ?)", recipient.downcase]).first
137
- end
129
+ asset = klass.where(["(lower(alt_email) = ?)", recipient.downcase]).first if !asset && klass.column_names.include?("alt_email")
138
130
 
139
131
  if asset && sender_has_permissions_for?(asset)
140
132
  attach(email, asset)
@@ -176,9 +168,7 @@ module FatFreeCRM
176
168
  )
177
169
  asset.touch
178
170
 
179
- if asset.is_a?(Lead) && asset.status == "new"
180
- asset.update_attribute(:status, "contacted")
181
- end
171
+ asset.update_attribute(:status, "contacted") if asset.is_a?(Lead) && asset.status == "new"
182
172
 
183
173
  if @settings[:attach_to_account] && asset.respond_to?(:account) && asset.account
184
174
  Email.create(
@@ -34,7 +34,7 @@ module FatFreeCRM
34
34
  # Save shared permissions to the model, if any.
35
35
  #--------------------------------------------------------------------------
36
36
  %w[group user].each do |model|
37
- class_eval %{
37
+ class_eval(%{
38
38
  def #{model}_ids=(value)
39
39
  if access != 'Shared'
40
40
  remove_permissions
@@ -53,7 +53,7 @@ module FatFreeCRM
53
53
  def #{model}_ids
54
54
  permissions.map(&:#{model}_id).compact
55
55
  end
56
- }
56
+ }, __FILE__, __LINE__ - 19)
57
57
  end
58
58
 
59
59
  # Remove all shared permissions if no longer shared
@@ -73,7 +73,10 @@ module FatFreeCRM
73
73
  []
74
74
  end
75
75
 
76
- permissions_to_remove.each { |p| permissions.delete(p); p.destroy }
76
+ permissions_to_remove.each do |p|
77
+ permissions.delete(p)
78
+ p.destroy
79
+ end
77
80
  end
78
81
 
79
82
  # Save the model copying other model's permissions.
@@ -91,4 +94,4 @@ module FatFreeCRM
91
94
  end
92
95
  end
93
96
 
94
- ActiveRecord::Base.send(:include, FatFreeCRM::Permissions)
97
+ ActiveRecord::Base.include FatFreeCRM::Permissions
@@ -42,4 +42,4 @@ module FatFreeCRM
42
42
  end
43
43
  end
44
44
 
45
- ActiveRecord::Base.send(:include, FatFreeCRM::Sortable)
45
+ ActiveRecord::Base.include FatFreeCRM::Sortable
@@ -14,11 +14,11 @@ module FatFreeCRM
14
14
  #----------------------------------------------------------------------------
15
15
  class << self
16
16
  def main
17
- @@main ||= (Setting[:tabs] && Setting[:tabs].dup)
17
+ @@main ||= Setting[:tabs]&.dup
18
18
  end
19
19
 
20
20
  def admin
21
- @@admin ||= (Setting[:admin_tabs] && Setting[:admin_tabs].dup)
21
+ @@admin ||= Setting[:admin_tabs]&.dup
22
22
  end
23
23
  end
24
24
  end
@@ -8,8 +8,8 @@
8
8
  module FatFreeCRM
9
9
  module VERSION #:nodoc:
10
10
  MAJOR = 0
11
- MINOR = 18
12
- TINY = 1
11
+ MINOR = 20
12
+ TINY = 0
13
13
  PRE = nil
14
14
 
15
15
  STRING = [MAJOR, MINOR, TINY, PRE].compact.join('.')
@@ -14,7 +14,7 @@ module GravatarImageTag
14
14
  end
15
15
 
16
16
  class Configuration
17
- attr_accessor :default_image, :filetype, :rating, :size, :secure
17
+ attr_accessor :default_image, :filetype, :rating, :size
18
18
  end
19
19
 
20
20
  def self.included(base)
@@ -25,6 +25,7 @@ module GravatarImageTag
25
25
  module InstanceMethods
26
26
  def gravatar_image_tag(email, options = {})
27
27
  raise ArgumentError, "Options must be a hash, got #{options.inspect}" unless options.is_a? Hash
28
+
28
29
  options[:alt] ||= 'Gravatar'
29
30
  image_tag(GravatarImageTag.gravatar_url(email, options.delete(:gravatar)), options)
30
31
  end
@@ -36,16 +37,13 @@ module GravatarImageTag
36
37
  default: GravatarImageTag.configuration.default_image,
37
38
  filetype: GravatarImageTag.configuration.filetype,
38
39
  rating: GravatarImageTag.configuration.rating,
39
- secure: GravatarImageTag.configuration.secure,
40
40
  size: GravatarImageTag.configuration.size
41
41
  }.merge(overrides).delete_if { |_key, value| value.nil? }
42
- "#{gravatar_url_base(gravatar_params.delete(:secure))}/#{gravatar_id(email, gravatar_params.delete(:filetype))}#{url_params(gravatar_params)}"
42
+ "#{gravatar_url_base}/#{gravatar_id(email, gravatar_params.delete(:filetype))}#{url_params(gravatar_params)}"
43
43
  end
44
44
 
45
- private
46
-
47
- def self.gravatar_url_base(secure = false)
48
- 'http' + (!!secure ? 's://secure.' : '://') + 'gravatar.com/avatar'
45
+ def self.gravatar_url_base
46
+ 'https://gravatar.com/avatar'
49
47
  end
50
48
 
51
49
  def self.gravatar_id(email, filetype = nil)
@@ -54,8 +52,9 @@ module GravatarImageTag
54
52
 
55
53
  def self.url_params(gravatar_params)
56
54
  return nil if gravatar_params.keys.empty?
57
- "?#{gravatar_params.map { |key, value| "#{key}=#{URI.escape(value.is_a?(String) ? value : value.to_s, Regexp.new("[^#{URI::PATTERN::UNRESERVED}]"))}" }.join('&amp;')}"
55
+
56
+ "?#{gravatar_params.map { |key, value| "#{key}=#{CGI.escape(value.is_a?(String) ? value : value.to_s)}" }.join('&amp;')}"
58
57
  end
59
58
  end
60
59
 
61
- ActionView::Base.send(:include, GravatarImageTag) if defined?(ActionView::Base)
60
+ ActionView::Base.include GravatarImageTag if defined?(ActionView::Base)
@@ -39,6 +39,7 @@ class MissingTranslationDetector
39
39
 
40
40
  keys.each do |key|
41
41
  return true if !h.is_a?(Hash) || !h.key?(key)
42
+
42
43
  h = h[key]
43
44
  end
44
45
 
@@ -22,6 +22,7 @@ namespace :ffcrm do
22
22
  detector.detect
23
23
 
24
24
  next unless detector.missing_translations?
25
+
25
26
  puts
26
27
  puts "Detected missing translations within \"config/locales/#{locale_file_names.last}.yml\":"
27
28
  puts
@@ -0,0 +1,19 @@
1
+ # frozen_string_literal: true
2
+
3
+ # Copyright (c) 2008-2013 Michael Dvorkin and contributors.
4
+ #
5
+ # Fat Free CRM is freely distributable under the terms of MIT license.
6
+ # See MIT-LICENSE file or http://www.opensource.org/licenses/mit-license.php
7
+ #------------------------------------------------------------------------------
8
+ namespace :ffcrm do
9
+ namespace :preference_update do
10
+ desc "Take all Marshal serialized database entries and convert them into JSON serialized"
11
+ task run: :environment do
12
+ preferences = Preference.all
13
+ preferences.each do |preference|
14
+ val = JSON.parse(Base64.decode64(preference.value), symbolize_name: true)
15
+ preference.value = Base64.encode64(val.to_json)
16
+ end
17
+ end
18
+ end
19
+ end
@@ -44,7 +44,12 @@ namespace :ffcrm do
44
44
 
45
45
  password ||= "manager"
46
46
  print "Password [#{password}]: "
47
- echo = ->(toggle) { return if RUBY_PLATFORM.match?(/mswin/); system(toggle ? "stty echo && echo" : "stty -echo") }
47
+ echo = lambda { |toggle|
48
+ return if RUBY_PLATFORM.match?(/mswin/)
49
+
50
+ system(toggle ? "stty echo && echo" : "stty -echo")
51
+ }
52
+
48
53
  begin
49
54
  echo.call(false)
50
55
  reply = STDIN.gets.strip
@@ -69,6 +74,7 @@ namespace :ffcrm do
69
74
  break unless reply.blank?
70
75
  end
71
76
  break if reply.match?(/y(?:es)*/i)
77
+
72
78
  redo if reply.match?(/no*/i)
73
79
  puts "No admin user was created."
74
80
  exit
@@ -76,7 +82,10 @@ namespace :ffcrm do
76
82
  end
77
83
  User.reset_column_information # Reload the class since we've added new fields in migrations.
78
84
  user = User.find_by_username(username) || User.new
79
- user.update_attributes(username: username, password: password, email: email)
85
+ user.skip_confirmation!
86
+ user.confirm
87
+ user.update(username: username, password: password, email: email)
88
+ user.update_attribute(:confirmed_at, Time.now.utc) # Skip confirmation
80
89
  user.update_attribute(:admin, true) # Mass assignments don't work for :admin because of the attr_protected
81
90
  user.update_attribute(:suspended_at, nil) # Mass assignments don't work for :suspended_at because of the attr_protected
82
91
  puts "Admin user has been created."
@@ -114,7 +114,7 @@ in a console and continue. This is strongly discouraged. You have been warned!
114
114
  %w[Guam GQ GU],
115
115
  %w[Guernsey GK GG],
116
116
  %w[Guinea GV GN],
117
- ["Guinea-Bissau", "PU", "GW"],
117
+ %w[Guinea-Bissau PU GW],
118
118
  %w[Haiti HA HT],
119
119
  ["Holy See (Vatican City State)", "VT", "VA"],
120
120
  %w[Honduras HO HN],
@@ -184,7 +184,7 @@ in a console and continue. This is strongly discouraged. You have been warned!
184
184
  %w[Sweden SW SE],
185
185
  %w[Switzerland SZ CH],
186
186
  %w[Tajikistan TI TJ],
187
- ["Timor-Leste", "TT", "TL"],
187
+ %w[Timor-Leste TT TL],
188
188
  %w[Togo TO TG],
189
189
  %w[Tokelau TL TK],
190
190
  %w[Tonga TN TO],
@@ -1,13 +1,15 @@
1
+ <%# frozen_string_literal: true %>
1
2
  <%%= simple_form_for(@<%= singular_table_name %>) do |f| %>
2
3
  <%%= f.error_notification %>
4
+ <%%= f.error_notification message: f.object.errors[:base].to_sentence if f.object.errors[:base].present? %>
3
5
 
4
- <div class="inputs">
6
+ <div class="form-inputs">
5
7
  <%- attributes.each do |attribute| -%>
6
8
  <%%= f.<%= attribute.reference? ? :association : :input %> :<%= attribute.name %> %>
7
9
  <%- end -%>
8
10
  </div>
9
11
 
10
- <div class="actions">
12
+ <div class="form-actions">
11
13
  <%%= f.button :submit %>
12
14
  </div>
13
15
  <%% end %>
data/script/rails CHANGED
@@ -3,6 +3,6 @@
3
3
 
4
4
  # This command will automatically be run when you run "rails" with Rails 3 gems installed from the root of your application.
5
5
 
6
- APP_PATH = File.expand_path('../../config/application', __FILE__)
7
- require File.expand_path('../../config/boot', __FILE__)
6
+ APP_PATH = File.expand_path('../config/application', __dir__)
7
+ require File.expand_path('../config/boot', __dir__)
8
8
  require 'rails/commands'
@@ -50,17 +50,6 @@ describe Admin::UsersController do
50
50
  end
51
51
  end
52
52
 
53
- # GET /admin/users/new
54
- # GET /admin/users/new.xml AJAX
55
- #----------------------------------------------------------------------------
56
- describe "GET new" do
57
- it "assigns a new user as @user and renders [new] template" do
58
- get :new, xhr: true
59
- expect(assigns[:user]).to be_new_record
60
- expect(response).to render_template("admin/users/new")
61
- end
62
- end
63
-
64
53
  # GET /admin/users/1/edit AJAX
65
54
  #----------------------------------------------------------------------------
66
55
  describe "GET edit" do
@@ -102,51 +91,6 @@ describe Admin::UsersController do
102
91
  end
103
92
  end
104
93
 
105
- # POST /admin/users
106
- # POST /admin/users.xml AJAX
107
- #----------------------------------------------------------------------------
108
- describe "POST create" do
109
- describe "with valid params" do
110
- before(:each) do
111
- @username = "none"
112
- @email = @username + "@example.com"
113
- @password = "secret"
114
- end
115
-
116
- it "assigns a newly created user as @user and renders [create] template" do
117
- @user = build(:user, username: @username, email: @email)
118
- allow(User).to receive(:new).and_return(@user)
119
-
120
- post :create, params: { user: { username: @username, email: @email, password: @password, password_confirmation: @password } }, xhr: true
121
- expect(assigns[:user]).to eq(@user)
122
- expect(response).to render_template("admin/users/create")
123
- end
124
-
125
- it "creates admin user when requested so" do
126
- post :create, params: { user: { username: @username, email: @email, admin: "1", password: @password, password_confirmation: @password } }, xhr: true
127
- expect(assigns[:user].admin).to eq(true)
128
- expect(response).to render_template("admin/users/create")
129
- end
130
-
131
- it "doesn't create admin user unless requested so" do
132
- post :create, params: { user: { username: @username, email: @email, admin: "0", password: @password, password_confirmation: @password } }, xhr: true
133
- expect(assigns[:user].admin).to eq(false)
134
- expect(response).to render_template("admin/users/create")
135
- end
136
- end
137
-
138
- describe "with invalid params" do
139
- it "assigns a newly created but unsaved user as @user and re-renders [create] template" do
140
- @user = build(:user, username: "", email: "")
141
- allow(User).to receive(:new).and_return(@user)
142
-
143
- post :create, params: { user: {} }, xhr: true
144
- expect(assigns[:user]).to eq(@user)
145
- expect(response).to render_template("admin/users/create")
146
- end
147
- end
148
- end
149
-
150
94
  # PUT /admin/users/1
151
95
  # PUT /admin/users/1.xml AJAX
152
96
  #----------------------------------------------------------------------------