jinda 0.7.7.2 → 0.7.7.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (226) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +12 -1
  3. data/app/config/routes.rb +44 -0
  4. data/lib/generators/jinda/templates/README.md +3 -1
  5. data/lib/generators/jinda/templates/app/assets/stylesheets/application.css.scss +2 -2
  6. data/lib/generators/jinda/templates/app/assets/stylesheets/jinda_jqm.css.scss +32 -0
  7. data/lib/generators/jinda/templates/app/mailers/{application_mailer.rb → application_mailer.rb-org} +0 -0
  8. data/lib/generators/jinda/templates/config/mongoid.yml +3 -3
  9. data/lib/jinda/version.rb +1 -1
  10. data/test/Gemfile +2 -0
  11. data/test/dummy/Dockerfile +26 -0
  12. data/test/dummy/Gemfile +99 -0
  13. data/test/dummy/Gemfile.lock +515 -0
  14. data/test/dummy/{db/development.sqlite3 → README.md} +0 -0
  15. data/test/dummy/README.md.bak +24 -0
  16. data/test/dummy/Rakefile +1 -1
  17. data/test/dummy/app/assets/config/manifest.js +2 -1
  18. data/test/dummy/app/assets/config/manifest.js-rails +2 -0
  19. data/test/dummy/app/assets/javascripts/application.js +15 -0
  20. data/test/dummy/app/assets/stylesheets/{application.css → application.css.bak} +3 -3
  21. data/test/dummy/app/assets/stylesheets/application.css.scss +15 -0
  22. data/test/dummy/app/assets/stylesheets/jinda_jqm.css.scss +32 -0
  23. data/test/dummy/app/controllers/admins_controller.rb +6 -0
  24. data/test/dummy/app/controllers/api/v1/notes_controller.rb +81 -0
  25. data/test/dummy/app/controllers/application_controller.rb +39 -0
  26. data/test/dummy/app/controllers/application_controller.rb.bak +2 -0
  27. data/test/dummy/app/controllers/articles_controller.rb +110 -0
  28. data/test/dummy/app/controllers/comments_controller.rb +31 -0
  29. data/test/dummy/app/controllers/docs_controller.rb +56 -0
  30. data/test/dummy/app/controllers/identities_controller.rb +5 -0
  31. data/test/dummy/app/controllers/notes_controller.rb +84 -0
  32. data/test/dummy/app/controllers/password_resets.rb +28 -0
  33. data/test/dummy/app/controllers/password_resets_controller.rb +34 -0
  34. data/test/dummy/app/controllers/sessions_controller.rb +44 -0
  35. data/test/dummy/app/controllers/sitemap_controller.rb +12 -0
  36. data/test/dummy/app/controllers/users_controller.rb +35 -0
  37. data/test/dummy/app/helpers/admins_helper.rb +2 -0
  38. data/test/dummy/app/helpers/application_helper.rb +31 -0
  39. data/test/dummy/app/helpers/application_helper.rb.bak +2 -0
  40. data/test/dummy/app/helpers/articles_helper.rb +2 -0
  41. data/test/dummy/app/helpers/basic_helper.rb +2 -0
  42. data/test/dummy/app/helpers/comments_helper.rb +2 -0
  43. data/test/dummy/app/helpers/ctrs_helper.rb +2 -0
  44. data/test/dummy/app/helpers/devs_helper.rb +2 -0
  45. data/test/dummy/app/helpers/pictures_helper.rb +2 -0
  46. data/test/dummy/app/helpers/sitemap_helper.rb +2 -0
  47. data/test/dummy/app/helpers/users_helper.rb +2 -0
  48. data/test/dummy/app/jinda/index.mm +486 -0
  49. data/test/dummy/app/jinda/template/index.mm +366 -0
  50. data/test/dummy/app/jinda/template/linkview.haml +21 -0
  51. data/test/dummy/app/jinda/template/view.html.erb +34 -0
  52. data/test/dummy/app/mailers/application_mailer.rb +2 -2
  53. data/test/dummy/app/mailers/application_mailer.rb-org +4 -0
  54. data/test/dummy/app/mailers/jinda_mailer.rb +7 -0
  55. data/test/dummy/app/mailers/note_mailer.rb +10 -0
  56. data/test/dummy/app/mailers/user_mailer.rb +15 -0
  57. data/test/dummy/app/models/address.rb +14 -0
  58. data/test/dummy/app/models/article.rb +14 -0
  59. data/test/dummy/app/models/comment.rb +14 -0
  60. data/test/dummy/app/models/identity.rb +18 -0
  61. data/test/dummy/app/models/jinda/doc.rb +36 -0
  62. data/test/dummy/app/models/jinda/module.rb +11 -0
  63. data/test/dummy/app/models/jinda/notice.rb +14 -0
  64. data/test/dummy/app/models/jinda/role.rb +8 -0
  65. data/test/dummy/app/models/jinda/runseq.rb +24 -0
  66. data/test/dummy/app/models/jinda/service.rb +17 -0
  67. data/test/dummy/app/models/jinda/xmain.rb +38 -0
  68. data/test/dummy/app/models/note.rb +22 -0
  69. data/test/dummy/app/models/param.rb +41 -0
  70. data/test/dummy/app/models/person.rb +14 -0
  71. data/test/dummy/app/models/user.rb +66 -0
  72. data/test/dummy/app/views/adminbsbs/content.haml +241 -0
  73. data/test/dummy/app/views/admins/edit_role/edit_role.html.erb +7 -0
  74. data/test/dummy/app/views/admins/edit_role/select_user.html.erb +4 -0
  75. data/test/dummy/app/views/api/v1/note.haml +0 -0
  76. data/test/dummy/app/views/articles/_report.haml +35 -0
  77. data/test/dummy/app/views/articles/edit.haml +23 -0
  78. data/test/dummy/app/views/articles/edit_article/edit_article.html.erb +15 -0
  79. data/test/dummy/app/views/articles/edit_article/select_article.html.erb +12 -0
  80. data/test/dummy/app/views/articles/index.haml +5 -0
  81. data/test/dummy/app/views/articles/my.haml +5 -0
  82. data/test/dummy/app/views/articles/new_article/form_article.html.erb +16 -0
  83. data/test/dummy/app/views/articles/show.html.haml +58 -0
  84. data/test/dummy/app/views/articles/xedit_article/edit_article.html.erb +13 -0
  85. data/test/dummy/app/views/ctrs/vfolder1/viewfile1.html.erb +23 -0
  86. data/test/dummy/app/views/ctrs/vfolder1/viewfile2.html.erb +23 -0
  87. data/test/dummy/app/views/ctrs/vfolder2/viewfile2.html.erb +23 -0
  88. data/test/dummy/app/views/custom/_adsense.haml +6 -0
  89. data/test/dummy/app/views/docs/doc_edit/doc_edit.html.erb +21 -0
  90. data/test/dummy/app/views/docs/doc_edit/doc_select.html.erb +14 -0
  91. data/test/dummy/app/views/docs/doc_new/doc_form.html.erb +32 -0
  92. data/test/dummy/app/views/docs/doc_new/doc_form.md +36 -0
  93. data/test/dummy/app/views/docs/doc_xedit/doc_edit.html.erb +21 -0
  94. data/test/dummy/app/views/docs/edit/select_note.html.erb +14 -0
  95. data/test/dummy/app/views/docs/index.haml +21 -0
  96. data/test/dummy/app/views/docs/my.haml +27 -0
  97. data/test/dummy/app/views/identities/new.html.haml +32 -0
  98. data/test/dummy/app/views/jinda/_activity.md +10 -0
  99. data/test/dummy/app/views/jinda/_menu.haml +27 -0
  100. data/test/dummy/app/views/jinda/_menu_mm.haml +44 -0
  101. data/test/dummy/app/views/jinda/_model.md +5 -0
  102. data/test/dummy/app/views/jinda/_modul.md +9 -0
  103. data/test/dummy/app/views/jinda/_pending_home.haml +5 -0
  104. data/test/dummy/app/views/jinda/_pending_page.haml +24 -0
  105. data/test/dummy/app/views/jinda/_service.md +24 -0
  106. data/test/dummy/app/views/jinda/_static.haml +13 -0
  107. data/test/dummy/app/views/jinda/doc-thai.md +37 -0
  108. data/test/dummy/app/views/jinda/doc.md +36 -0
  109. data/test/dummy/app/views/jinda/error_logs.haml +22 -0
  110. data/test/dummy/app/views/jinda/feed.rss.builder +27 -0
  111. data/test/dummy/app/views/jinda/help.haml +20 -0
  112. data/test/dummy/app/views/jinda/index.html.haml +53 -0
  113. data/test/dummy/app/views/jinda/logs.haml +22 -0
  114. data/test/dummy/app/views/jinda/notice_logs.haml +18 -0
  115. data/test/dummy/app/views/jinda/pending.haml +1 -0
  116. data/test/dummy/app/views/jinda/run_form.haml +42 -0
  117. data/test/dummy/app/views/jinda/run_output.haml +38 -0
  118. data/test/dummy/app/views/jinda/search.haml +20 -0
  119. data/test/dummy/app/views/jinda/status.haml +61 -0
  120. data/test/dummy/app/views/jinda_mailer/gmail.html.erb +9 -0
  121. data/test/dummy/app/views/layouts/_head.html.erb +10 -0
  122. data/test/dummy/app/views/layouts/_meta_tag.html.erb +19 -0
  123. data/test/dummy/app/views/layouts/application.haml +4 -0
  124. data/test/dummy/app/views/layouts/{application.html.erb → application.html.erb.bak} +2 -1
  125. data/test/dummy/app/views/layouts/bsb/_footer.haml +7 -0
  126. data/test/dummy/app/views/layouts/bsb/_header.haml +147 -0
  127. data/test/dummy/app/views/layouts/bsb/_menu.haml +47 -0
  128. data/test/dummy/app/views/layouts/bsb/_menu_mm.haml +34 -0
  129. data/test/dummy/app/views/layouts/bsb/_rightbar.haml +123 -0
  130. data/test/dummy/app/views/layouts/bsb/_sidebar.haml +155 -0
  131. data/test/dummy/app/views/layouts/bsb/application.haml-bsb +47 -0
  132. data/test/dummy/app/views/layouts/gmail.html.erb +9 -0
  133. data/test/dummy/app/views/layouts/jqm/_full.haml +33 -0
  134. data/test/dummy/app/views/layouts/jqm/_page.haml +16 -0
  135. data/test/dummy/app/views/layouts/jqm/application.haml-jqm +4 -0
  136. data/test/dummy/app/views/layouts/mailer.html.haml +3 -0
  137. data/test/dummy/app/views/layouts/mailer.text.haml +1 -0
  138. data/test/dummy/app/views/layouts/mobile.html.erb +13 -0
  139. data/test/dummy/app/views/layouts/mobilejq.html.erb +31 -0
  140. data/test/dummy/app/views/layouts/print.html.erb +22 -0
  141. data/test/dummy/app/views/layouts/utf8.html.erb +22 -0
  142. data/test/dummy/app/views/note_mailer/gmail.html.haml +7 -0
  143. data/test/dummy/app/views/note_mailer/gmail.text.haml +8 -0
  144. data/test/dummy/app/views/notes/delete/select_note.html.erb +14 -0
  145. data/test/dummy/app/views/notes/edit/edit_note.html.erb +10 -0
  146. data/test/dummy/app/views/notes/edit/select_note.html.erb +14 -0
  147. data/test/dummy/app/views/notes/index.haml +71 -0
  148. data/test/dummy/app/views/notes/mail/display_mail.html.erb +20 -0
  149. data/test/dummy/app/views/notes/mail/select_note.html.erb +19 -0
  150. data/test/dummy/app/views/notes/mail/show.html.haml +13 -0
  151. data/test/dummy/app/views/notes/my.haml +21 -0
  152. data/test/dummy/app/views/notes/new/new_note.html.erb +13 -0
  153. data/test/dummy/app/views/notes/show.haml +10 -0
  154. data/test/dummy/app/views/notes/xedit/edit_note.html.erb +10 -0
  155. data/test/dummy/app/views/password_resets/edit.html.erb +21 -0
  156. data/test/dummy/app/views/password_resets/new.html.haml +11 -0
  157. data/test/dummy/app/views/sessions/new.html.haml +22 -0
  158. data/test/dummy/app/views/sitemap/index.xml.haml +10 -0
  159. data/test/dummy/app/views/user_mailer/password_reset.html.haml +3 -0
  160. data/test/dummy/app/views/user_mailer/password_reset.text.erb +3 -0
  161. data/test/dummy/app/views/user_mailer/password_reset.text.haml +3 -0
  162. data/test/dummy/app/views/users/index.haml +13 -0
  163. data/test/dummy/app/views/users/pwd/enter.html.erb +6 -0
  164. data/test/dummy/app/views/users/user/enter_user.html.erb +10 -0
  165. data/test/dummy/bin/rails +3 -3
  166. data/test/dummy/bin/rake +2 -2
  167. data/test/dummy/bin/setup +9 -17
  168. data/test/dummy/config/application.rb +51 -9
  169. data/test/dummy/config/boot.rb +3 -4
  170. data/test/dummy/config/cloudinary.yml +9 -0
  171. data/test/dummy/config/credentials.yml.enc +1 -0
  172. data/test/dummy/config/environment.rb +7 -1
  173. data/test/dummy/config/environments/development.rb +20 -20
  174. data/test/dummy/config/environments/production.rb +16 -40
  175. data/test/dummy/config/environments/test.rb +19 -11
  176. data/test/dummy/config/initializers/assets.rb +1 -1
  177. data/test/dummy/config/initializers/content_security_policy.rb +21 -24
  178. data/test/dummy/config/initializers/filter_parameter_logging.rb +6 -2
  179. data/test/dummy/config/initializers/fix_mongoid_generator.rb-org +14 -0
  180. data/test/dummy/config/initializers/inflections.rb +4 -4
  181. data/test/dummy/config/initializers/jinda.rb +14 -0
  182. data/test/dummy/config/initializers/mongoid.rb +10 -0
  183. data/test/dummy/config/initializers/omniauth.rb +17 -0
  184. data/test/dummy/config/initializers/permissions_policy.rb +11 -0
  185. data/test/dummy/config/locales/en.yml +3 -3
  186. data/test/dummy/config/mongoid.yml +196 -0
  187. data/test/dummy/config/mongoid.yml-docker +182 -0
  188. data/test/dummy/config/mongoid.yml-localhost +182 -0
  189. data/test/dummy/config/puma.rb +7 -2
  190. data/test/dummy/config/routes.rb +5 -1
  191. data/test/dummy/config.ru +2 -1
  192. data/test/dummy/db/seeds.rb +6 -0
  193. data/test/dummy/docker-compose.yml +19 -0
  194. data/test/dummy/dot/dot.env +2 -0
  195. data/test/dummy/entrypoint.sh +13 -0
  196. data/test/dummy/log/development.log +697 -6
  197. data/test/dummy/public/robots.txt +1 -0
  198. data/test/dummy/spec/controllers/api/v1_get_index_spec.rb +23 -0
  199. data/test/dummy/spec/controllers/api/v1_get_my_spec.rb +14 -0
  200. data/test/dummy/spec/controllers/api/v1_post_spec.rb +19 -0
  201. data/test/dummy/spec/controllers/sessions_controller_spec.rb +98 -0
  202. data/test/dummy/spec/features/userlogins_spec.rb +23 -0
  203. data/test/dummy/spec/mailers/note_spec.rb +24 -0
  204. data/test/dummy/spec/mailers/previews/note_preview.rb +9 -0
  205. data/test/dummy/spec/models/note_spec.rb +41 -0
  206. data/test/dummy/spec/models/user_spec.rb +12 -0
  207. data/test/dummy/spec/rails_helper.rb +42 -0
  208. data/test/dummy/spec/spec_helper.rb +80 -0
  209. data/test/dummy/spec/support/authentication_helper.rb +20 -0
  210. data/test/dummy/spec/support/databasecleaner.rb +13 -0
  211. data/test/dummy/spec/support/factory_bot.rb +12 -0
  212. data/test/dummy/spec/support/omniauth_macros.rb +38 -0
  213. data/test/dummy/spec/support/request_spec_helper.rb +8 -0
  214. data/test/dummy/spec/views/articles/_article.html.erb_spec.rbx +14 -0
  215. data/test/dummy/tmp/development_secret.txt +1 -1
  216. metadata +188 -17
  217. data/test/dummy/app/javascript/packs/application.js +0 -15
  218. data/test/dummy/app/models/application_record.rb +0 -3
  219. data/test/dummy/config/database.yml +0 -25
  220. data/test/dummy/config/initializers/application_controller_renderer.rb +0 -8
  221. data/test/dummy/config/initializers/backtrace_silencers.rb +0 -7
  222. data/test/dummy/config/initializers/cookies_serializer.rb +0 -5
  223. data/test/dummy/config/initializers/mime_types.rb +0 -4
  224. data/test/dummy/config/initializers/wrap_parameters.rb +0 -14
  225. data/test/dummy/config/spring.rb +0 -6
  226. data/test/dummy/config/storage.yml +0 -34
@@ -0,0 +1,81 @@
1
+ class Api::V1::NotesController < ApplicationController
2
+ before_action :load_note, only: [:show, :destroy]
3
+ # before_action :xload_current_ma_user, only: [:destroy]
4
+
5
+ def index
6
+ @notes = Note.desc(:created_at).page(params[:page]).per(10)
7
+ render json: @notes
8
+ end
9
+
10
+ def my
11
+ @notes = Note.where(user_id: current_ma_user).desc(:created_at).page(params[:page]).per(10)
12
+ render json: @notes
13
+ end
14
+
15
+ def show
16
+ end
17
+
18
+ def edit
19
+ @note = Note.find(params[:id])
20
+ @page_title = 'Edit Note'
21
+ end
22
+
23
+ def create
24
+ @note = Note.new(
25
+ title: params[:title],
26
+ body: params[:body],
27
+ user_id: params[:user])
28
+
29
+ @note.save!
30
+ render json: @note, status: :created
31
+ end
32
+
33
+
34
+ def update
35
+ # $xvars["select_note"] and $xvars["edit_note"]
36
+ # These are variables.
37
+ # They contain everything that we get their forms select_note and edit_note
38
+ note_id = $xvars["select_note"] ? $xvars["select_note"]["id"] : $xvars["p"]["note_id"]
39
+ @note = Note.find(note_id)
40
+ @note.update(title: $xvars["edit_note"]["title"],
41
+ body: $xvars["edit_note"]["body"])
42
+ redirect_to @note
43
+
44
+ end
45
+
46
+ def delete
47
+ # called by freemind
48
+ # Tobe called from other controller:jinda
49
+ @note_id = $xvars["select_note"] ? $xvars["select_note"]["id"] : $xvars["p"]["note_id"]
50
+ @note = Note.find(@note_id)
51
+ @note.destroy
52
+ end
53
+
54
+ def destroy
55
+ # called by rails menu my
56
+ if current_ma_user.role.upcase.split(',').include?("A") || current_ma_user == @note.user
57
+ @note.destroy
58
+ end
59
+ redirect_to :action=>'my'
60
+ end
61
+
62
+ def mail
63
+ NoteMailer.gmail(
64
+ $xvars["display_mail"]["body"],
65
+ $xvars["select_note"]["email"],
66
+ $xvars["display_mail"]["title"],
67
+ xload_current_ma_user.email)
68
+ end
69
+
70
+ private
71
+
72
+ # Tobe called from other controller:jinda
73
+ def xload_current_ma_user
74
+ @current_ma_user = User.find($xvars["user_id"])
75
+ end
76
+
77
+ def load_note
78
+ @note = Note.find(params[:id])
79
+ end
80
+
81
+ end
@@ -1,2 +1,41 @@
1
1
  class ApplicationController < ActionController::Base
2
+ before_action :prepare_meta_tags, if: -> { request.get? }
3
+ # CSRF protection is turned on with the protect_from_forgery method.
4
+ protect_from_forgery unless: -> { request.format.json? }
5
+ def prepare_meta_tags(options={})
6
+ site_name = DEFAULT_TITLE
7
+ title = [controller_name, action_name].join(" ")
8
+ description = DEFAULT_DESCRIPTION
9
+ image = options[:image] || href="/assets/images/logo.png"
10
+ keywords = DEFAULT_KEYWORDS
11
+ current_url = request.url
12
+
13
+ # Let's prepare a nice set of defaults
14
+ defaults = {
15
+ site: site_name,
16
+ title: title,
17
+ image: image,
18
+ description: description,
19
+ keywords: keywords,
20
+ twitter: {
21
+ site_name: site_name,
22
+ site: site_name,
23
+ card: 'summary',
24
+ description: description,
25
+ image: image
26
+ },
27
+ og: {
28
+ url: current_url,
29
+ site_name: site_name,
30
+ title: title,
31
+ image: image,
32
+ description: description,
33
+ type: 'website'
34
+ }
35
+ }
36
+
37
+ options.reverse_merge!(defaults)
38
+
39
+ set_meta_tags options
40
+ end
2
41
  end
@@ -0,0 +1,2 @@
1
+ class ApplicationController < ActionController::Base
2
+ end
@@ -0,0 +1,110 @@
1
+ class ArticlesController < ApplicationController
2
+ before_action :load_articles, except: [:destroy]
3
+ before_action :load_my_articles, only: [:my]
4
+ before_action :load_article, only: [:destroy, :edit]
5
+
6
+ def index
7
+ # before_action
8
+ end
9
+
10
+ def my
11
+ # before_action
12
+ end
13
+
14
+ def show
15
+ @article = Article.find(article_params)
16
+ @commentable = @article
17
+ @comments = @commentable.comments.desc(:created_at).page(params[:page]).per(10)
18
+ @user = User.find(@article.user_id)
19
+ @show = Hash.new
20
+ @show = {:article => @article, :comments => @comments, :user => @user}
21
+ prepare_meta_tags(title: @article.title,
22
+ description: @article.text,
23
+ keywords: @article.keywords)
24
+ end
25
+
26
+ def edit
27
+ @page_title = 'Edit Article'
28
+ end
29
+
30
+ def create
31
+ # Use Jinda $xvars
32
+ @article = Article.new(
33
+ title: $xvars["form_article"]["title"],
34
+ text: $xvars["form_article"]["text"],
35
+ keywords: $xvars["form_article"]["keywords"],
36
+ body: $xvars["form_article"]["body"],
37
+ user_id: $xvars["user_id"])
38
+ @article.save!
39
+ end
40
+
41
+ def update
42
+ @article = Article.find(params[:id])
43
+ @article.update(
44
+ title: params["article"]["title"],
45
+ text: params["article"]["text"],
46
+ keywords: params["article"]["keywords"],
47
+ body: params["article"]["body"]
48
+ )
49
+ redirect_to :action=> 'show', :article_id => @article.id
50
+ end
51
+
52
+ def j_update
53
+ # Use Jinda $xvars
54
+ @article_id = $xvars["select_article"] ? $xvars["select_article"]["title"] : $xvars["p"]["article_id"]
55
+ @article = Article.find_by :id => @article_id
56
+ @article.update(title: $xvars["edit_article"]["article"]["title"],
57
+ text: $xvars["edit_article"]["article"]["text"],
58
+ keywords: $xvars["edit_article"]["article"]["keywords"],
59
+ body: $xvars["edit_article"]["article"]["body"]
60
+ )
61
+ end
62
+
63
+ def destroy
64
+ # Use Rails
65
+ # before_action
66
+
67
+ if current_admin? || current_ma_user == @article.user
68
+ @article.destroy
69
+ end
70
+
71
+ action = (current_admin? ? 'index' : 'my')
72
+ redirect_to :action=> (current_admin? ? 'index' : 'my')
73
+ end
74
+
75
+ private
76
+
77
+ def current_admin?
78
+ if current_ma_user.role.upcase.split(',').include?("A")
79
+ return true
80
+ else
81
+ return false
82
+ end
83
+ end
84
+
85
+
86
+ def load_articles
87
+ @articles = Article.desc(:created_at).page(params[:page]).per(10)
88
+ end
89
+
90
+ def load_my_articles
91
+ @my_articles = @articles.where(user: current_ma_user)
92
+ end
93
+
94
+ def load_article
95
+ @article = Article.find(params[:article_id])
96
+ end
97
+
98
+ def article_params
99
+ [params[:article_id], params[:id]].detect { |p| !p.nil? }
100
+ end
101
+
102
+ def load_edit_article
103
+ @article = Article.find(params.require(:article).permit(:article_id))
104
+ end
105
+
106
+ def load_comments
107
+ @comments = @article.comments.find_all
108
+ end
109
+
110
+ end
@@ -0,0 +1,31 @@
1
+ class CommentsController < ApplicationController
2
+ before_action :comment_params, only: [:create]
3
+ before_action :load_commmentable
4
+
5
+ def index
6
+ @comments = @commentable.comments
7
+ end
8
+
9
+ def create
10
+ @comment = @commentable.comments.new comment_params
11
+ @comment.save!
12
+ redirect_to [@commentable], notice: "Comment created"
13
+ end
14
+
15
+ private
16
+
17
+ # def article_params
18
+ # params.require(:comment).permit(:article_id)
19
+ # end
20
+
21
+ def comment_params
22
+ resource = request.path.split('/')[1]
23
+ commentable_id = "#{resource.singularize.to_sym}_id" #:article_id
24
+ params.require(:comment).permit(:body, :user_id, commentable_id.to_sym)
25
+ end
26
+
27
+ def load_commmentable
28
+ resource, id = request.path.split('/')[1,2]
29
+ @commentable = resource.singularize.classify.constantize.find(id)
30
+ end
31
+ end
@@ -0,0 +1,56 @@
1
+ class DocsController < ApplicationController
2
+ before_action :load_doc, only: [:destroy]
3
+ before_action :load_doc_form, only: [:doc_update, :edit, :my]
4
+
5
+ def index
6
+ @documents = Jinda::Doc.desc(:created_at).page(params[:page]).per(10)
7
+ end
8
+
9
+ def edit
10
+ end
11
+
12
+ def my
13
+ @page_title = 'My Document'
14
+ end
15
+
16
+ def doc_update
17
+ # Instead of creaete, Doc record was created in form, when upload file
18
+
19
+ if Jinda::Doc.where(:runseq_id => $xvars["doc_form"]["runseq_id"]).exists?
20
+ @doc = Jinda::Doc.where(:runseq_id => $xvars["doc_form"]["runseq_id"]).first
21
+ @doc.update(description: $xvars["doc_form"]["description"],
22
+ category: $xvars["doc_form"]["jinda_doc"]["category"],
23
+ keywords: $xvars["doc_form"]["keywords"],
24
+ user_id: $xvars["user_id"]
25
+ )
26
+ else
27
+ # create here
28
+ # Todo
29
+ end
30
+ end
31
+
32
+ def destroy
33
+ # duplicated from jinda_controller
34
+ # Expected to use in jinda_controller
35
+ current_ma_user = User.where(:auth_token => cookies[:auth_token]).first if cookies[:auth_token]
36
+
37
+ if Rails.env.test? #Temp solution until fix test of current_ma_user
38
+ current_ma_user = $xvars["current_ma_user"]
39
+ #current_ma_user = @doc.user
40
+ end
41
+
42
+ if current_ma_user.role.upcase.split(',').include?("A") || current_ma_user == @doc.user
43
+ @doc.destroy
44
+ end
45
+ redirect_to :action=>'my'
46
+ end
47
+
48
+ private
49
+
50
+ def load_doc_form
51
+ @docs = Jinda::Doc.all.desc(:created_at).page(params[:page]).per(10)
52
+ end
53
+ def load_doc
54
+ @doc = Jinda::Doc.find(params[:doc_id])
55
+ end
56
+ end
@@ -0,0 +1,5 @@
1
+ class IdentitiesController < ApplicationController
2
+ def new
3
+ @identity =request.env['omniauth.identity']
4
+ end
5
+ end
@@ -0,0 +1,84 @@
1
+ class NotesController < ApplicationController
2
+ before_action :load_note, only: [:show, :destroy]
3
+ # before_action :xload_current_ma_user, only: [:destroy]
4
+
5
+ def index
6
+ # @notes = Note.desc(:created_at).page(params[:page]).per(10)
7
+ @notes = Note
8
+ end
9
+
10
+ def my
11
+ @notes = Note.where(user_id: current_ma_user).desc(:created_at).page(params[:page]).per(10)
12
+ end
13
+
14
+ def show
15
+ end
16
+
17
+ def edit
18
+ @note = Note.find(params[:id])
19
+ @page_title = 'Edit Note'
20
+ end
21
+
22
+ def create
23
+ @note = Note.new(
24
+ title: $xvars["new_note"]["note"]["title"],
25
+ body: $xvars["new_note"]["note"]["body"],
26
+ user_id: $xvars["user_id"])
27
+ @note.save!
28
+ # if @note.save!
29
+ # format.html { redirect_to @note, notice: 'Sample was successfully created.' }
30
+ # format.json { render :show, status: :created, location: @note }
31
+ # else
32
+ # format.html { render :new }
33
+ # format.json { render json: @note.errors, status: :unprocessable_entity }
34
+ # end
35
+
36
+ end
37
+
38
+
39
+ def update
40
+ # $xvars["select_note"] and $xvars["edit_note"]
41
+ # These are variables.
42
+ # They contain everything that we get their forms select_note and edit_note
43
+ note_id = $xvars["select_note"] ? $xvars["select_note"]["id"] : $xvars["p"]["note_id"]
44
+ @note = Note.find(note_id)
45
+ @note.update(title: $xvars["edit_note"]["note"]["title"],
46
+ body: $xvars["edit_note"]["note"]["body"])
47
+ end
48
+
49
+ def delete
50
+ # called by freemind
51
+ # Tobe called from other controller:jinda
52
+ @note_id = $xvars["select_note"] ? $xvars["select_note"]["id"] : $xvars["p"]["note_id"]
53
+ @note = Note.find(@note_id)
54
+ @note.destroy
55
+ end
56
+
57
+ def destroy
58
+ # called by rails menu my
59
+ if current_ma_user.role.upcase.split(',').include?("A") || current_ma_user == @note.user
60
+ @note.destroy
61
+ end
62
+ redirect_to :action=>'my'
63
+ end
64
+
65
+ def mail
66
+ NoteMailer.gmail(
67
+ $xvars["display_mail"]["body"],
68
+ $xvars["select_note"]["email"],
69
+ $xvars["display_mail"]["title"],
70
+ xload_current_ma_user.email)
71
+ end
72
+
73
+ private
74
+
75
+ # Tobe called from other controller:jinda
76
+ def xload_current_ma_user
77
+ @current_ma_user = User.find($xvars["user_id"])
78
+ end
79
+
80
+ def load_note
81
+ @note = Note.find(params[:id])
82
+ end
83
+
84
+ end
@@ -0,0 +1,28 @@
1
+ class PasswordResetsController < ApplicationController
2
+
3
+ def create
4
+ ##user = User.find_by_email(params[:email])
5
+ user = User.where(:email => params[:email]).first
6
+
7
+ user.send_password_reset if user
8
+ redirect_to root_url, :notice => "Email sent with password reset instructions."
9
+ end
10
+
11
+ def edit
12
+ ##@user = User.find_by_password_reset_token!(params[:id])
13
+ @user = User.where(:password_reset_token => params[:id]).first
14
+ end
15
+
16
+ def update
17
+ ##@user = User.find_by_password_reset_token!(params[:id])
18
+ @user = User.where(:password_reset_token => params[:id]).first
19
+ if @user.password_reset_sent_at < 2.hours.ago
20
+ redirect_to new_password_reset_path, :alert => "Password reset has expired."
21
+ elsif @user.update_attributes(params[:user])
22
+ redirect_to root_url, :notice => "Password has been reset!"
23
+ else
24
+ render :edit
25
+ end
26
+ end
27
+ end
28
+
@@ -0,0 +1,34 @@
1
+ class PasswordResetsController < ApplicationController
2
+
3
+ def index
4
+ end
5
+
6
+ def create
7
+ #user = User.find_by_email(params[:email])
8
+ user = User.where(:email => params[:email]).first
9
+
10
+ user.send_password_reset if user
11
+ redirect_to root_url, :ma_notice => "Email sent with password reset instructions."
12
+ end
13
+
14
+ def edit
15
+ ## Deprecated syntax in rail 5
16
+ ##@user = User.find_by_password_reset_token!(params[:id])
17
+ @user = User.where(:password_reset_token => params[:id]).first
18
+ end
19
+
20
+ def update
21
+ ##@user = User.find_by_password_reset_token!(params[:id])
22
+ @user = User.where(:password_reset_token => params[:id]).first
23
+ if @user.password_reset_sent_at < 2.hours.ago
24
+ redirect_to new_password_reset_path, :alert => "Password &crarr;
25
+ reset has expired."
26
+ elsif @user.update_attributes(params[:user])
27
+ redirect_to root_url, :notice => "Password has been reset."
28
+ else
29
+ render :edit
30
+ end
31
+ end
32
+
33
+ end
34
+
@@ -0,0 +1,44 @@
1
+ # encoding: utf-8
2
+ class SessionsController < ApplicationController
3
+ def new
4
+ @title= 'Sign In'
5
+ end
6
+
7
+ def failure
8
+ # redirect_to login_path, alert: "Authentication failed, please try again."
9
+ redirect_to login_path, alert: "Authentication failed, please try again."
10
+ end
11
+
12
+ # to refresh the page, must know BEFOREHAND that the action needs refresh
13
+ # then use attribute 'data-ajax'=>'false'
14
+ # see app/views/sessions/new.html.erb for sample
15
+ def create
16
+ auth = request.env["omniauth.auth"]
17
+ user = User.from_omniauth(auth)
18
+ session[:user_id] = user.id
19
+ if params.permit[:remember_me]
20
+ cookies.permanent[:auth_token] = user.auth_token
21
+ else
22
+ cookies[:auth_token] = user.auth_token
23
+ end
24
+ # refresh_to root_path, :ma_notice => "Logged in" # Called by jinda_conroller
25
+ redirect_to root_path
26
+ # redirect_to articles_my_path
27
+
28
+ rescue
29
+ redirect_to root_path, :alert=> "Authentication failed, please try again."
30
+ end
31
+
32
+ def destroy
33
+ session[:user_id] = nil
34
+ cookies.delete(:auth_token)
35
+ refresh_to root_path, :ma_notice => "Logged Out" # called by jinda_controller, not pass tested
36
+ # redirect_to root_path # Ok with test
37
+
38
+ end
39
+
40
+ def failure
41
+ ma_log "Authentication failed, please try again."
42
+ redirect_to new_session_path, :alert=> "Authentication failed, please try again."
43
+ end
44
+ end
@@ -0,0 +1,12 @@
1
+ class SitemapController < ApplicationController
2
+ # From https://makandracards.com/makandra/689-know-your-haml-comments
3
+ SitemapController < ApplicationController
4
+ layout nil
5
+ def index
6
+ headers['Content-Type'] = 'application/xml'
7
+ respond_to do |format|
8
+ format.xml {@articles = Article.all}
9
+ end
10
+ end
11
+
12
+ end
@@ -0,0 +1,35 @@
1
+ # -*- encoding : utf-8 -*-
2
+ class UsersController < ApplicationController
3
+ def index
4
+ @today = Date.today
5
+ @xmains = current_ma_user.xmains.in(status:['R','I']).asc(:created_at)
6
+ end
7
+
8
+ # jinda methods
9
+ def update_user
10
+ # can't use session, current_ma_user inside jinda methods
11
+ $user.update_attribute :email, $xvars["enter_user"]["user"]["email"]
12
+ $user.update_attribute :image, $xvars["enter_user"]["user"]["image"]
13
+ end
14
+ def change_password
15
+ # check if old password correct
16
+ identity = Identity.find_by :code=> $user.code
17
+ if identity.authenticate($xvars["enter"]["epass"])
18
+ identity.password = $xvars["enter"]["npass"]
19
+ identity.password_confirmation = $xvars["enter"]["npass_confirm"]
20
+ identity.save
21
+ ma_log "Password changed"
22
+ else
23
+ ma_log "Unauthorized access"
24
+ end
25
+ end
26
+
27
+ def send_password_reset
28
+ generate_token(:password_reset_token)
29
+ self.password_reset_sent_at = Time.zone.now
30
+ save!
31
+ UserMailer.password_reset(self).deliver
32
+ end
33
+
34
+ end
35
+
@@ -0,0 +1,2 @@
1
+ module AdminsHelper
2
+ end
@@ -1,2 +1,33 @@
1
1
  module ApplicationHelper
2
+
3
+ def title(blog_title)
4
+ content_for(:title) { blog_title }
5
+ end
6
+
7
+ def meta_description(blog_text)
8
+ content_for(:meta_description) { blog_text }
9
+ end
10
+
11
+ require 'redcarpet'
12
+ require 'rouge'
13
+ require 'rouge/plugins/redcarpet'
14
+
15
+ class CodeRayify < Redcarpet::Render::HTML
16
+ def block_code(code, language)
17
+ CodeRay.scan(code, language).div
18
+ end
2
19
  end
20
+
21
+ def markdown(text)
22
+ coderayified = CodeRayify.new(:filter_html => true,
23
+ :hard_wrap => true)
24
+ options = {
25
+ :fenced_code_blocks => true,
26
+ :no_intra_emphasis => true,
27
+ :autolink => true,
28
+ :lax_html_blocks => true,
29
+ }
30
+ markdown_to_html = Redcarpet::Markdown.new(coderayified, options)
31
+ markdown_to_html.render(text).html_safe
32
+ end
33
+ end
@@ -0,0 +1,2 @@
1
+ module ApplicationHelper
2
+ end
@@ -0,0 +1,2 @@
1
+ module ArticlesHelper
2
+ end
@@ -0,0 +1,2 @@
1
+ module BasicHelper
2
+ end
@@ -0,0 +1,2 @@
1
+ module CommentsHelper
2
+ end
@@ -0,0 +1,2 @@
1
+ module CtrsHelper
2
+ end
@@ -0,0 +1,2 @@
1
+ module DevsHelper
2
+ end
@@ -0,0 +1,2 @@
1
+ module PicturesHelper
2
+ end
@@ -0,0 +1,2 @@
1
+ module SitemapHelper
2
+ end
@@ -0,0 +1,2 @@
1
+ module UsersHelper
2
+ end