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.
- checksums.yaml +4 -4
- data/README.md +12 -1
- data/app/config/routes.rb +44 -0
- data/lib/generators/jinda/templates/README.md +3 -1
- data/lib/generators/jinda/templates/app/assets/stylesheets/application.css.scss +2 -2
- data/lib/generators/jinda/templates/app/assets/stylesheets/jinda_jqm.css.scss +32 -0
- data/lib/generators/jinda/templates/app/mailers/{application_mailer.rb → application_mailer.rb-org} +0 -0
- data/lib/generators/jinda/templates/config/mongoid.yml +3 -3
- data/lib/jinda/version.rb +1 -1
- data/test/Gemfile +2 -0
- data/test/dummy/Dockerfile +26 -0
- data/test/dummy/Gemfile +99 -0
- data/test/dummy/Gemfile.lock +515 -0
- data/test/dummy/{db/development.sqlite3 → README.md} +0 -0
- data/test/dummy/README.md.bak +24 -0
- data/test/dummy/Rakefile +1 -1
- data/test/dummy/app/assets/config/manifest.js +2 -1
- data/test/dummy/app/assets/config/manifest.js-rails +2 -0
- data/test/dummy/app/assets/javascripts/application.js +15 -0
- data/test/dummy/app/assets/stylesheets/{application.css → application.css.bak} +3 -3
- data/test/dummy/app/assets/stylesheets/application.css.scss +15 -0
- data/test/dummy/app/assets/stylesheets/jinda_jqm.css.scss +32 -0
- data/test/dummy/app/controllers/admins_controller.rb +6 -0
- data/test/dummy/app/controllers/api/v1/notes_controller.rb +81 -0
- data/test/dummy/app/controllers/application_controller.rb +39 -0
- data/test/dummy/app/controllers/application_controller.rb.bak +2 -0
- data/test/dummy/app/controllers/articles_controller.rb +110 -0
- data/test/dummy/app/controllers/comments_controller.rb +31 -0
- data/test/dummy/app/controllers/docs_controller.rb +56 -0
- data/test/dummy/app/controllers/identities_controller.rb +5 -0
- data/test/dummy/app/controllers/notes_controller.rb +84 -0
- data/test/dummy/app/controllers/password_resets.rb +28 -0
- data/test/dummy/app/controllers/password_resets_controller.rb +34 -0
- data/test/dummy/app/controllers/sessions_controller.rb +44 -0
- data/test/dummy/app/controllers/sitemap_controller.rb +12 -0
- data/test/dummy/app/controllers/users_controller.rb +35 -0
- data/test/dummy/app/helpers/admins_helper.rb +2 -0
- data/test/dummy/app/helpers/application_helper.rb +31 -0
- data/test/dummy/app/helpers/application_helper.rb.bak +2 -0
- data/test/dummy/app/helpers/articles_helper.rb +2 -0
- data/test/dummy/app/helpers/basic_helper.rb +2 -0
- data/test/dummy/app/helpers/comments_helper.rb +2 -0
- data/test/dummy/app/helpers/ctrs_helper.rb +2 -0
- data/test/dummy/app/helpers/devs_helper.rb +2 -0
- data/test/dummy/app/helpers/pictures_helper.rb +2 -0
- data/test/dummy/app/helpers/sitemap_helper.rb +2 -0
- data/test/dummy/app/helpers/users_helper.rb +2 -0
- data/test/dummy/app/jinda/index.mm +486 -0
- data/test/dummy/app/jinda/template/index.mm +366 -0
- data/test/dummy/app/jinda/template/linkview.haml +21 -0
- data/test/dummy/app/jinda/template/view.html.erb +34 -0
- data/test/dummy/app/mailers/application_mailer.rb +2 -2
- data/test/dummy/app/mailers/application_mailer.rb-org +4 -0
- data/test/dummy/app/mailers/jinda_mailer.rb +7 -0
- data/test/dummy/app/mailers/note_mailer.rb +10 -0
- data/test/dummy/app/mailers/user_mailer.rb +15 -0
- data/test/dummy/app/models/address.rb +14 -0
- data/test/dummy/app/models/article.rb +14 -0
- data/test/dummy/app/models/comment.rb +14 -0
- data/test/dummy/app/models/identity.rb +18 -0
- data/test/dummy/app/models/jinda/doc.rb +36 -0
- data/test/dummy/app/models/jinda/module.rb +11 -0
- data/test/dummy/app/models/jinda/notice.rb +14 -0
- data/test/dummy/app/models/jinda/role.rb +8 -0
- data/test/dummy/app/models/jinda/runseq.rb +24 -0
- data/test/dummy/app/models/jinda/service.rb +17 -0
- data/test/dummy/app/models/jinda/xmain.rb +38 -0
- data/test/dummy/app/models/note.rb +22 -0
- data/test/dummy/app/models/param.rb +41 -0
- data/test/dummy/app/models/person.rb +14 -0
- data/test/dummy/app/models/user.rb +66 -0
- data/test/dummy/app/views/adminbsbs/content.haml +241 -0
- data/test/dummy/app/views/admins/edit_role/edit_role.html.erb +7 -0
- data/test/dummy/app/views/admins/edit_role/select_user.html.erb +4 -0
- data/test/dummy/app/views/api/v1/note.haml +0 -0
- data/test/dummy/app/views/articles/_report.haml +35 -0
- data/test/dummy/app/views/articles/edit.haml +23 -0
- data/test/dummy/app/views/articles/edit_article/edit_article.html.erb +15 -0
- data/test/dummy/app/views/articles/edit_article/select_article.html.erb +12 -0
- data/test/dummy/app/views/articles/index.haml +5 -0
- data/test/dummy/app/views/articles/my.haml +5 -0
- data/test/dummy/app/views/articles/new_article/form_article.html.erb +16 -0
- data/test/dummy/app/views/articles/show.html.haml +58 -0
- data/test/dummy/app/views/articles/xedit_article/edit_article.html.erb +13 -0
- data/test/dummy/app/views/ctrs/vfolder1/viewfile1.html.erb +23 -0
- data/test/dummy/app/views/ctrs/vfolder1/viewfile2.html.erb +23 -0
- data/test/dummy/app/views/ctrs/vfolder2/viewfile2.html.erb +23 -0
- data/test/dummy/app/views/custom/_adsense.haml +6 -0
- data/test/dummy/app/views/docs/doc_edit/doc_edit.html.erb +21 -0
- data/test/dummy/app/views/docs/doc_edit/doc_select.html.erb +14 -0
- data/test/dummy/app/views/docs/doc_new/doc_form.html.erb +32 -0
- data/test/dummy/app/views/docs/doc_new/doc_form.md +36 -0
- data/test/dummy/app/views/docs/doc_xedit/doc_edit.html.erb +21 -0
- data/test/dummy/app/views/docs/edit/select_note.html.erb +14 -0
- data/test/dummy/app/views/docs/index.haml +21 -0
- data/test/dummy/app/views/docs/my.haml +27 -0
- data/test/dummy/app/views/identities/new.html.haml +32 -0
- data/test/dummy/app/views/jinda/_activity.md +10 -0
- data/test/dummy/app/views/jinda/_menu.haml +27 -0
- data/test/dummy/app/views/jinda/_menu_mm.haml +44 -0
- data/test/dummy/app/views/jinda/_model.md +5 -0
- data/test/dummy/app/views/jinda/_modul.md +9 -0
- data/test/dummy/app/views/jinda/_pending_home.haml +5 -0
- data/test/dummy/app/views/jinda/_pending_page.haml +24 -0
- data/test/dummy/app/views/jinda/_service.md +24 -0
- data/test/dummy/app/views/jinda/_static.haml +13 -0
- data/test/dummy/app/views/jinda/doc-thai.md +37 -0
- data/test/dummy/app/views/jinda/doc.md +36 -0
- data/test/dummy/app/views/jinda/error_logs.haml +22 -0
- data/test/dummy/app/views/jinda/feed.rss.builder +27 -0
- data/test/dummy/app/views/jinda/help.haml +20 -0
- data/test/dummy/app/views/jinda/index.html.haml +53 -0
- data/test/dummy/app/views/jinda/logs.haml +22 -0
- data/test/dummy/app/views/jinda/notice_logs.haml +18 -0
- data/test/dummy/app/views/jinda/pending.haml +1 -0
- data/test/dummy/app/views/jinda/run_form.haml +42 -0
- data/test/dummy/app/views/jinda/run_output.haml +38 -0
- data/test/dummy/app/views/jinda/search.haml +20 -0
- data/test/dummy/app/views/jinda/status.haml +61 -0
- data/test/dummy/app/views/jinda_mailer/gmail.html.erb +9 -0
- data/test/dummy/app/views/layouts/_head.html.erb +10 -0
- data/test/dummy/app/views/layouts/_meta_tag.html.erb +19 -0
- data/test/dummy/app/views/layouts/application.haml +4 -0
- data/test/dummy/app/views/layouts/{application.html.erb → application.html.erb.bak} +2 -1
- data/test/dummy/app/views/layouts/bsb/_footer.haml +7 -0
- data/test/dummy/app/views/layouts/bsb/_header.haml +147 -0
- data/test/dummy/app/views/layouts/bsb/_menu.haml +47 -0
- data/test/dummy/app/views/layouts/bsb/_menu_mm.haml +34 -0
- data/test/dummy/app/views/layouts/bsb/_rightbar.haml +123 -0
- data/test/dummy/app/views/layouts/bsb/_sidebar.haml +155 -0
- data/test/dummy/app/views/layouts/bsb/application.haml-bsb +47 -0
- data/test/dummy/app/views/layouts/gmail.html.erb +9 -0
- data/test/dummy/app/views/layouts/jqm/_full.haml +33 -0
- data/test/dummy/app/views/layouts/jqm/_page.haml +16 -0
- data/test/dummy/app/views/layouts/jqm/application.haml-jqm +4 -0
- data/test/dummy/app/views/layouts/mailer.html.haml +3 -0
- data/test/dummy/app/views/layouts/mailer.text.haml +1 -0
- data/test/dummy/app/views/layouts/mobile.html.erb +13 -0
- data/test/dummy/app/views/layouts/mobilejq.html.erb +31 -0
- data/test/dummy/app/views/layouts/print.html.erb +22 -0
- data/test/dummy/app/views/layouts/utf8.html.erb +22 -0
- data/test/dummy/app/views/note_mailer/gmail.html.haml +7 -0
- data/test/dummy/app/views/note_mailer/gmail.text.haml +8 -0
- data/test/dummy/app/views/notes/delete/select_note.html.erb +14 -0
- data/test/dummy/app/views/notes/edit/edit_note.html.erb +10 -0
- data/test/dummy/app/views/notes/edit/select_note.html.erb +14 -0
- data/test/dummy/app/views/notes/index.haml +71 -0
- data/test/dummy/app/views/notes/mail/display_mail.html.erb +20 -0
- data/test/dummy/app/views/notes/mail/select_note.html.erb +19 -0
- data/test/dummy/app/views/notes/mail/show.html.haml +13 -0
- data/test/dummy/app/views/notes/my.haml +21 -0
- data/test/dummy/app/views/notes/new/new_note.html.erb +13 -0
- data/test/dummy/app/views/notes/show.haml +10 -0
- data/test/dummy/app/views/notes/xedit/edit_note.html.erb +10 -0
- data/test/dummy/app/views/password_resets/edit.html.erb +21 -0
- data/test/dummy/app/views/password_resets/new.html.haml +11 -0
- data/test/dummy/app/views/sessions/new.html.haml +22 -0
- data/test/dummy/app/views/sitemap/index.xml.haml +10 -0
- data/test/dummy/app/views/user_mailer/password_reset.html.haml +3 -0
- data/test/dummy/app/views/user_mailer/password_reset.text.erb +3 -0
- data/test/dummy/app/views/user_mailer/password_reset.text.haml +3 -0
- data/test/dummy/app/views/users/index.haml +13 -0
- data/test/dummy/app/views/users/pwd/enter.html.erb +6 -0
- data/test/dummy/app/views/users/user/enter_user.html.erb +10 -0
- data/test/dummy/bin/rails +3 -3
- data/test/dummy/bin/rake +2 -2
- data/test/dummy/bin/setup +9 -17
- data/test/dummy/config/application.rb +51 -9
- data/test/dummy/config/boot.rb +3 -4
- data/test/dummy/config/cloudinary.yml +9 -0
- data/test/dummy/config/credentials.yml.enc +1 -0
- data/test/dummy/config/environment.rb +7 -1
- data/test/dummy/config/environments/development.rb +20 -20
- data/test/dummy/config/environments/production.rb +16 -40
- data/test/dummy/config/environments/test.rb +19 -11
- data/test/dummy/config/initializers/assets.rb +1 -1
- data/test/dummy/config/initializers/content_security_policy.rb +21 -24
- data/test/dummy/config/initializers/filter_parameter_logging.rb +6 -2
- data/test/dummy/config/initializers/fix_mongoid_generator.rb-org +14 -0
- data/test/dummy/config/initializers/inflections.rb +4 -4
- data/test/dummy/config/initializers/jinda.rb +14 -0
- data/test/dummy/config/initializers/mongoid.rb +10 -0
- data/test/dummy/config/initializers/omniauth.rb +17 -0
- data/test/dummy/config/initializers/permissions_policy.rb +11 -0
- data/test/dummy/config/locales/en.yml +3 -3
- data/test/dummy/config/mongoid.yml +196 -0
- data/test/dummy/config/mongoid.yml-docker +182 -0
- data/test/dummy/config/mongoid.yml-localhost +182 -0
- data/test/dummy/config/puma.rb +7 -2
- data/test/dummy/config/routes.rb +5 -1
- data/test/dummy/config.ru +2 -1
- data/test/dummy/db/seeds.rb +6 -0
- data/test/dummy/docker-compose.yml +19 -0
- data/test/dummy/dot/dot.env +2 -0
- data/test/dummy/entrypoint.sh +13 -0
- data/test/dummy/log/development.log +697 -6
- data/test/dummy/public/robots.txt +1 -0
- data/test/dummy/spec/controllers/api/v1_get_index_spec.rb +23 -0
- data/test/dummy/spec/controllers/api/v1_get_my_spec.rb +14 -0
- data/test/dummy/spec/controllers/api/v1_post_spec.rb +19 -0
- data/test/dummy/spec/controllers/sessions_controller_spec.rb +98 -0
- data/test/dummy/spec/features/userlogins_spec.rb +23 -0
- data/test/dummy/spec/mailers/note_spec.rb +24 -0
- data/test/dummy/spec/mailers/previews/note_preview.rb +9 -0
- data/test/dummy/spec/models/note_spec.rb +41 -0
- data/test/dummy/spec/models/user_spec.rb +12 -0
- data/test/dummy/spec/rails_helper.rb +42 -0
- data/test/dummy/spec/spec_helper.rb +80 -0
- data/test/dummy/spec/support/authentication_helper.rb +20 -0
- data/test/dummy/spec/support/databasecleaner.rb +13 -0
- data/test/dummy/spec/support/factory_bot.rb +12 -0
- data/test/dummy/spec/support/omniauth_macros.rb +38 -0
- data/test/dummy/spec/support/request_spec_helper.rb +8 -0
- data/test/dummy/spec/views/articles/_article.html.erb_spec.rbx +14 -0
- data/test/dummy/tmp/development_secret.txt +1 -1
- metadata +188 -17
- data/test/dummy/app/javascript/packs/application.js +0 -15
- data/test/dummy/app/models/application_record.rb +0 -3
- data/test/dummy/config/database.yml +0 -25
- data/test/dummy/config/initializers/application_controller_renderer.rb +0 -8
- data/test/dummy/config/initializers/backtrace_silencers.rb +0 -7
- data/test/dummy/config/initializers/cookies_serializer.rb +0 -5
- data/test/dummy/config/initializers/mime_types.rb +0 -4
- data/test/dummy/config/initializers/wrap_parameters.rb +0 -14
- data/test/dummy/config/spring.rb +0 -6
- 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,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,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 ↵
|
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
|
+
|
@@ -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
|