jinda_mind 1.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/LICENSE.txt +21 -0
- data/README.md +4 -0
- data/Rakefile +3 -0
- data/app/assets/config/manifest.js +4 -0
- data/app/assets/images/4dcity-old.ico +0 -0
- data/app/assets/images/4dcity.ico +0 -0
- data/app/assets/images/account.png +0 -0
- data/app/assets/images/add.png +0 -0
- data/app/assets/images/ajax-loader-circle.gif +0 -0
- data/app/assets/images/ajax-loader.gif +0 -0
- data/app/assets/images/anchor.png +0 -0
- data/app/assets/images/application_double.png +0 -0
- data/app/assets/images/application_form_edit.png +0 -0
- data/app/assets/images/arrow_left.png +0 -0
- data/app/assets/images/arrow_right.png +0 -0
- data/app/assets/images/arrow_turn_left.png +0 -0
- data/app/assets/images/arrow_turn_right.png +0 -0
- data/app/assets/images/calendar.png +0 -0
- data/app/assets/images/cancel.png +0 -0
- data/app/assets/images/chart_bar.png +0 -0
- data/app/assets/images/clock.png +0 -0
- data/app/assets/images/cog.png +0 -0
- data/app/assets/images/control_fastforward.png +0 -0
- data/app/assets/images/control_play.png +0 -0
- data/app/assets/images/cross.png +0 -0
- data/app/assets/images/delete.png +0 -0
- data/app/assets/images/external-link.png +0 -0
- data/app/assets/images/facebook-continue-button.png +0 -0
- data/app/assets/images/facebooksmall.png +0 -0
- data/app/assets/images/favicon.ico +0 -0
- data/app/assets/images/freemind(mm).png +0 -0
- data/app/assets/images/google-continue-button.png +0 -0
- data/app/assets/images/help.png +0 -0
- data/app/assets/images/highway-menu.png +0 -0
- data/app/assets/images/highway.png +0 -0
- data/app/assets/images/house.png +0 -0
- data/app/assets/images/icons-18-black.png +0 -0
- data/app/assets/images/icons-18-white.png +0 -0
- data/app/assets/images/icons-36-black.png +0 -0
- data/app/assets/images/icons-36-white.png +0 -0
- data/app/assets/images/logo.png +0 -0
- data/app/assets/images/logo_jinda.png +0 -0
- data/app/assets/images/logout.png +0 -0
- data/app/assets/images/new.gif +0 -0
- data/app/assets/images/new.png +0 -0
- data/app/assets/images/page.png +0 -0
- data/app/assets/images/page_attach.png +0 -0
- data/app/assets/images/page_green.png +0 -0
- data/app/assets/images/page_output.png +0 -0
- data/app/assets/images/page_pdf.png +0 -0
- data/app/assets/images/pencil.png +0 -0
- data/app/assets/images/printer.png +0 -0
- data/app/assets/images/refresh.png +0 -0
- data/app/assets/images/report.png +0 -0
- data/app/assets/images/rssmall.png +0 -0
- data/app/assets/images/tick.png +0 -0
- data/app/assets/images/twittersmall.png +0 -0
- data/app/assets/images/user.png +0 -0
- data/app/assets/images/user_admin_gear.png +0 -0
- data/app/assets/images/view_code.png +0 -0
- data/app/assets/javascripts/application.js-org +24 -0
- data/app/assets/javascripts/cable.js +13 -0
- data/app/assets/javascripts/disable_enter_key.js +10 -0
- data/app/assets/javascripts/iscroll-wrapper.js +32 -0
- data/app/assets/javascripts/iscroll.js +1084 -0
- data/app/assets/javascripts/jinda.js +14 -0
- data/app/assets/javascripts/jinda_jqm.js +24 -0
- data/app/assets/javascripts/jquery.mobile-1.2.1.js +9272 -0
- data/app/assets/javascripts/jquery.mobile.datebox.js +1778 -0
- data/app/assets/javascripts/jquery.mobile.splitview.js +695 -0
- data/app/assets/stylesheets/app.scss +90 -0
- data/app/assets/stylesheets/articles.scss +94 -0
- data/app/assets/stylesheets/fonts/sarabun.eot +0 -0
- data/app/assets/stylesheets/fonts/sarabun.ttf +0 -0
- data/app/assets/stylesheets/fonts/sarabun.woff +0 -0
- data/app/assets/stylesheets/fonts/sarabun_bold.ttf +0 -0
- data/app/assets/stylesheets/fonts/sarabun_bolditalic.ttf +0 -0
- data/app/assets/stylesheets/fonts/sarabun_italic.ttf +0 -0
- data/app/assets/stylesheets/fonts/thsarabunnew-webfont.eot +0 -0
- data/app/assets/stylesheets/fonts/thsarabunnew-webfont.ttf +0 -0
- data/app/assets/stylesheets/fonts/thsarabunnew-webfont.woff +0 -0
- data/app/assets/stylesheets/fonts/thsarabunnew.css +47 -0
- data/app/assets/stylesheets/fonts/thsarabunnew_bold-webfont.eot +0 -0
- data/app/assets/stylesheets/fonts/thsarabunnew_bold-webfont.ttf +0 -0
- data/app/assets/stylesheets/fonts/thsarabunnew_bold-webfont.woff +0 -0
- data/app/assets/stylesheets/fonts/thsarabunnew_bolditalic-webfont.eot +0 -0
- data/app/assets/stylesheets/fonts/thsarabunnew_bolditalic-webfont.ttf +0 -0
- data/app/assets/stylesheets/fonts/thsarabunnew_bolditalic-webfont.woff +0 -0
- data/app/assets/stylesheets/fonts/thsarabunnew_italic-webfont.eot +0 -0
- data/app/assets/stylesheets/fonts/thsarabunnew_italic-webfont.ttf +0 -0
- data/app/assets/stylesheets/fonts/thsarabunnew_italic-webfont.woff +0 -0
- data/app/assets/stylesheets/images/ajax-loader.gif +0 -0
- data/app/assets/stylesheets/images/button_black.png +0 -0
- data/app/assets/stylesheets/images/button_blue.png +0 -0
- data/app/assets/stylesheets/images/button_red.png +0 -0
- data/app/assets/stylesheets/images/gears.png +0 -0
- data/app/assets/stylesheets/images/icons-18-black.png +0 -0
- data/app/assets/stylesheets/images/icons-18-white.png +0 -0
- data/app/assets/stylesheets/images/icons-36-black.png +0 -0
- data/app/assets/stylesheets/images/icons-36-white.png +0 -0
- data/app/assets/stylesheets/images/indicator.gif +0 -0
- data/app/assets/stylesheets/jinda.scss +185 -0
- data/app/assets/stylesheets/jinda_jqm.css.scss +32 -0
- data/app/assets/stylesheets/jquery.mobile-1.2.1.css +2339 -0
- data/app/assets/stylesheets/jquery.mobile.datebox.css +65 -0
- data/app/assets/stylesheets/jquery.mobile.grids.collapsible.css +122 -0
- data/app/assets/stylesheets/jquery.mobile.splitview.css +128 -0
- data/app/assets/stylesheets/kul-4.2.css +1516 -0
- data/app/assets/stylesheets/kul-4.2.min.css +11 -0
- data/app/assets/stylesheets/modules.scss +84 -0
- data/app/assets/stylesheets/sarabun.css +37 -0
- data/app/assets/stylesheets/social.scss +133 -0
- data/app/controllers/concerns/jinda_general_concern.rb +179 -0
- data/app/controllers/concerns/jinda_run_concern.rb +368 -0
- data/app/controllers/jinda_controller.rb +66 -0
- data/bin/console +14 -0
- data/bin/setup +8 -0
- data/config/mongoid.yml +19 -0
- data/config/routes.rb +44 -0
- data/lib/generators/jinda/USAGE +2 -0
- data/lib/generators/jinda/config_generator.rb +102 -0
- data/lib/generators/jinda/install_generator.rb +269 -0
- data/lib/generators/jinda/installer/gems_install.rb +132 -0
- data/lib/generators/jinda/installer/test.rb +6 -0
- data/lib/generators/jinda/minitest_generator.rb +30 -0
- data/lib/generators/jinda/rspec_generator.rb +30 -0
- data/lib/generators/jinda/templates/Dockerfile +26 -0
- data/lib/generators/jinda/templates/README.md +173 -0
- data/lib/generators/jinda/templates/app/assets/config/manifest.js +4 -0
- data/lib/generators/jinda/templates/app/assets/javascripts/application.js +15 -0
- data/lib/generators/jinda/templates/app/assets/stylesheets/application.css.scss +15 -0
- data/lib/generators/jinda/templates/app/channels/application_cable/channel.rb +4 -0
- data/lib/generators/jinda/templates/app/channels/application_cable/connection.rb +4 -0
- data/lib/generators/jinda/templates/app/controllers/api/v1/notes_controller.rb +81 -0
- data/lib/generators/jinda/templates/app/controllers/jinda_org/admins_controller.rb +6 -0
- data/lib/generators/jinda/templates/app/controllers/jinda_org/application_controller.rb +41 -0
- data/lib/generators/jinda/templates/app/controllers/jinda_org/articles_controller.rb +110 -0
- data/lib/generators/jinda/templates/app/controllers/jinda_org/comments_controller.rb +31 -0
- data/lib/generators/jinda/templates/app/controllers/jinda_org/docs_controller.rb +56 -0
- data/lib/generators/jinda/templates/app/controllers/jinda_org/identities_controller.rb +5 -0
- data/lib/generators/jinda/templates/app/controllers/jinda_org/notes_controller.rb +84 -0
- data/lib/generators/jinda/templates/app/controllers/jinda_org/password_resets.rb +28 -0
- data/lib/generators/jinda/templates/app/controllers/jinda_org/password_resets_controller.rb +34 -0
- data/lib/generators/jinda/templates/app/controllers/jinda_org/sessions_controller.rb +44 -0
- data/lib/generators/jinda/templates/app/controllers/jinda_org/sitemap_controller.rb +12 -0
- data/lib/generators/jinda/templates/app/controllers/jinda_org/users_controller.rb +35 -0
- data/lib/generators/jinda/templates/app/helpers/admins_helper.rb +2 -0
- data/lib/generators/jinda/templates/app/helpers/application_helper.rb +33 -0
- data/lib/generators/jinda/templates/app/helpers/articles_helper.rb +2 -0
- data/lib/generators/jinda/templates/app/helpers/basic_helper.rb +2 -0
- data/lib/generators/jinda/templates/app/helpers/comments_helper.rb +2 -0
- data/lib/generators/jinda/templates/app/helpers/ctrs_helper.rb +2 -0
- data/lib/generators/jinda/templates/app/helpers/devs_helper.rb +2 -0
- data/lib/generators/jinda/templates/app/helpers/pictures_helper.rb +2 -0
- data/lib/generators/jinda/templates/app/helpers/sitemap_helper.rb +2 -0
- data/lib/generators/jinda/templates/app/helpers/users_helper.rb +2 -0
- data/lib/generators/jinda/templates/app/jinda/index.mm +486 -0
- data/lib/generators/jinda/templates/app/jinda/template/index.mm +366 -0
- data/lib/generators/jinda/templates/app/jinda/template/linkview.haml +21 -0
- data/lib/generators/jinda/templates/app/jinda/template/view.html.erb +34 -0
- data/lib/generators/jinda/templates/app/mailers/application_mailer.rb +4 -0
- data/lib/generators/jinda/templates/app/mailers/jinda_mailer.rb +7 -0
- data/lib/generators/jinda/templates/app/mailers/note_mailer.rb +10 -0
- data/lib/generators/jinda/templates/app/mailers/user_mailer.rb +15 -0
- data/lib/generators/jinda/templates/app/models/address.rb +14 -0
- data/lib/generators/jinda/templates/app/models/article.rb +14 -0
- data/lib/generators/jinda/templates/app/models/comment.rb +14 -0
- data/lib/generators/jinda/templates/app/models/identity.rb +18 -0
- data/lib/generators/jinda/templates/app/models/jinda/doc.rb +36 -0
- data/lib/generators/jinda/templates/app/models/jinda/module.rb +11 -0
- data/lib/generators/jinda/templates/app/models/jinda/notice.rb +14 -0
- data/lib/generators/jinda/templates/app/models/jinda/role.rb +8 -0
- data/lib/generators/jinda/templates/app/models/jinda/runseq.rb +24 -0
- data/lib/generators/jinda/templates/app/models/jinda/service.rb +17 -0
- data/lib/generators/jinda/templates/app/models/jinda/xmain.rb +38 -0
- data/lib/generators/jinda/templates/app/models/note.rb +22 -0
- data/lib/generators/jinda/templates/app/models/param.rb +41 -0
- data/lib/generators/jinda/templates/app/models/person.rb +14 -0
- data/lib/generators/jinda/templates/app/models/user.rb +66 -0
- data/lib/generators/jinda/templates/app/views/adminbsbs/content.haml +241 -0
- data/lib/generators/jinda/templates/app/views/admins/edit_role/edit_role.html.erb +7 -0
- data/lib/generators/jinda/templates/app/views/admins/edit_role/select_user.html.erb +4 -0
- data/lib/generators/jinda/templates/app/views/api/v1/note.haml +0 -0
- data/lib/generators/jinda/templates/app/views/articles/_report.haml +35 -0
- data/lib/generators/jinda/templates/app/views/articles/edit.haml +23 -0
- data/lib/generators/jinda/templates/app/views/articles/edit_article/edit_article.html.erb +15 -0
- data/lib/generators/jinda/templates/app/views/articles/edit_article/select_article.html.erb +12 -0
- data/lib/generators/jinda/templates/app/views/articles/index.haml +5 -0
- data/lib/generators/jinda/templates/app/views/articles/my.haml +5 -0
- data/lib/generators/jinda/templates/app/views/articles/new_article/form_article.html.erb +16 -0
- data/lib/generators/jinda/templates/app/views/articles/show.html.haml +58 -0
- data/lib/generators/jinda/templates/app/views/articles/xedit_article/edit_article.html.erb +13 -0
- data/lib/generators/jinda/templates/app/views/ctrs/vfolder1/viewfile1.html.erb +23 -0
- data/lib/generators/jinda/templates/app/views/ctrs/vfolder1/viewfile2.html.erb +23 -0
- data/lib/generators/jinda/templates/app/views/ctrs/vfolder2/viewfile2.html.erb +23 -0
- data/lib/generators/jinda/templates/app/views/custom/_adsense.haml +6 -0
- data/lib/generators/jinda/templates/app/views/docs/doc_edit/doc_edit.html.erb +21 -0
- data/lib/generators/jinda/templates/app/views/docs/doc_edit/doc_select.html.erb +14 -0
- data/lib/generators/jinda/templates/app/views/docs/doc_new/doc_form.html.erb +32 -0
- data/lib/generators/jinda/templates/app/views/docs/doc_new/doc_form.md +36 -0
- data/lib/generators/jinda/templates/app/views/docs/doc_xedit/doc_edit.html.erb +21 -0
- data/lib/generators/jinda/templates/app/views/docs/edit/select_note.html.erb +14 -0
- data/lib/generators/jinda/templates/app/views/docs/index.haml +21 -0
- data/lib/generators/jinda/templates/app/views/docs/my.haml +27 -0
- data/lib/generators/jinda/templates/app/views/identities/new.html.haml +32 -0
- data/lib/generators/jinda/templates/app/views/jinda/_activity.md +10 -0
- data/lib/generators/jinda/templates/app/views/jinda/_menu.haml +27 -0
- data/lib/generators/jinda/templates/app/views/jinda/_menu_mm.haml +44 -0
- data/lib/generators/jinda/templates/app/views/jinda/_model.md +5 -0
- data/lib/generators/jinda/templates/app/views/jinda/_modul.md +9 -0
- data/lib/generators/jinda/templates/app/views/jinda/_pending_home.haml +5 -0
- data/lib/generators/jinda/templates/app/views/jinda/_pending_page.haml +24 -0
- data/lib/generators/jinda/templates/app/views/jinda/_service.md +24 -0
- data/lib/generators/jinda/templates/app/views/jinda/_static.haml +13 -0
- data/lib/generators/jinda/templates/app/views/jinda/doc-thai.md +37 -0
- data/lib/generators/jinda/templates/app/views/jinda/doc.md +36 -0
- data/lib/generators/jinda/templates/app/views/jinda/error_logs.haml +22 -0
- data/lib/generators/jinda/templates/app/views/jinda/feed.rss.builder +27 -0
- data/lib/generators/jinda/templates/app/views/jinda/help.haml +20 -0
- data/lib/generators/jinda/templates/app/views/jinda/index.html.haml +53 -0
- data/lib/generators/jinda/templates/app/views/jinda/logs.haml +22 -0
- data/lib/generators/jinda/templates/app/views/jinda/notice_logs.haml +18 -0
- data/lib/generators/jinda/templates/app/views/jinda/pending.haml +1 -0
- data/lib/generators/jinda/templates/app/views/jinda/run_form.haml +42 -0
- data/lib/generators/jinda/templates/app/views/jinda/run_output.haml +38 -0
- data/lib/generators/jinda/templates/app/views/jinda/search.haml +20 -0
- data/lib/generators/jinda/templates/app/views/jinda/status.haml +61 -0
- data/lib/generators/jinda/templates/app/views/jinda_mailer/gmail.html.erb +9 -0
- data/lib/generators/jinda/templates/app/views/layouts/_head.html.erb +10 -0
- data/lib/generators/jinda/templates/app/views/layouts/_meta_tag.html.erb +19 -0
- data/lib/generators/jinda/templates/app/views/layouts/application.haml +4 -0
- data/lib/generators/jinda/templates/app/views/layouts/bsb/_footer.haml +7 -0
- data/lib/generators/jinda/templates/app/views/layouts/bsb/_header.haml +147 -0
- data/lib/generators/jinda/templates/app/views/layouts/bsb/_menu.haml +47 -0
- data/lib/generators/jinda/templates/app/views/layouts/bsb/_menu_mm.haml +34 -0
- data/lib/generators/jinda/templates/app/views/layouts/bsb/_rightbar.haml +123 -0
- data/lib/generators/jinda/templates/app/views/layouts/bsb/_sidebar.haml +155 -0
- data/lib/generators/jinda/templates/app/views/layouts/bsb/application.haml-bsb +47 -0
- data/lib/generators/jinda/templates/app/views/layouts/gmail.html.erb +9 -0
- data/lib/generators/jinda/templates/app/views/layouts/jqm/_full.haml +33 -0
- data/lib/generators/jinda/templates/app/views/layouts/jqm/_page.haml +16 -0
- data/lib/generators/jinda/templates/app/views/layouts/jqm/application.haml-jqm +4 -0
- data/lib/generators/jinda/templates/app/views/layouts/mailer.html.erb +13 -0
- data/lib/generators/jinda/templates/app/views/layouts/mailer.html.haml +3 -0
- data/lib/generators/jinda/templates/app/views/layouts/mailer.text.erb +1 -0
- data/lib/generators/jinda/templates/app/views/layouts/mailer.text.haml +1 -0
- data/lib/generators/jinda/templates/app/views/layouts/mobile.html.erb +13 -0
- data/lib/generators/jinda/templates/app/views/layouts/mobilejq.html.erb +31 -0
- data/lib/generators/jinda/templates/app/views/layouts/print.html.erb +22 -0
- data/lib/generators/jinda/templates/app/views/layouts/utf8.html.erb +22 -0
- data/lib/generators/jinda/templates/app/views/note_mailer/gmail.html.haml +7 -0
- data/lib/generators/jinda/templates/app/views/note_mailer/gmail.text.haml +8 -0
- data/lib/generators/jinda/templates/app/views/notes/delete/select_note.html.erb +14 -0
- data/lib/generators/jinda/templates/app/views/notes/edit/edit_note.html.erb +10 -0
- data/lib/generators/jinda/templates/app/views/notes/edit/select_note.html.erb +14 -0
- data/lib/generators/jinda/templates/app/views/notes/index.haml +71 -0
- data/lib/generators/jinda/templates/app/views/notes/mail/display_mail.html.erb +20 -0
- data/lib/generators/jinda/templates/app/views/notes/mail/select_note.html.erb +19 -0
- data/lib/generators/jinda/templates/app/views/notes/mail/show.html.haml +13 -0
- data/lib/generators/jinda/templates/app/views/notes/my.haml +21 -0
- data/lib/generators/jinda/templates/app/views/notes/new/new_note.html.erb +13 -0
- data/lib/generators/jinda/templates/app/views/notes/show.haml +10 -0
- data/lib/generators/jinda/templates/app/views/notes/xedit/edit_note.html.erb +10 -0
- data/lib/generators/jinda/templates/app/views/password_resets/edit.html.erb +21 -0
- data/lib/generators/jinda/templates/app/views/password_resets/new.html.haml +11 -0
- data/lib/generators/jinda/templates/app/views/sessions/new.html.haml +22 -0
- data/lib/generators/jinda/templates/app/views/sitemap/index.xml.haml +10 -0
- data/lib/generators/jinda/templates/app/views/user_mailer/password_reset.html.haml +3 -0
- data/lib/generators/jinda/templates/app/views/user_mailer/password_reset.text.erb +3 -0
- data/lib/generators/jinda/templates/app/views/user_mailer/password_reset.text.haml +3 -0
- data/lib/generators/jinda/templates/app/views/users/index.haml +13 -0
- data/lib/generators/jinda/templates/app/views/users/pwd/enter.html.erb +6 -0
- data/lib/generators/jinda/templates/app/views/users/user/enter_user.html.erb +10 -0
- data/lib/generators/jinda/templates/config/cloudinary.yml +9 -0
- data/lib/generators/jinda/templates/config/initializers/fix_mongoid_generator.rb-org +14 -0
- data/lib/generators/jinda/templates/config/mongoid.yml-docker +182 -0
- data/lib/generators/jinda/templates/config/mongoid.yml-localhost +182 -0
- data/lib/generators/jinda/templates/db/seeds.rb +6 -0
- data/lib/generators/jinda/templates/docker-compose.yml +17 -0
- data/lib/generators/jinda/templates/dot/dot.env +2 -0
- data/lib/generators/jinda/templates/dotrspec +3 -0
- data/lib/generators/jinda/templates/entrypoint.sh +13 -0
- data/lib/generators/jinda/templates/jinda.yml +10 -0
- data/lib/generators/jinda/templates/public/404.html +67 -0
- data/lib/generators/jinda/templates/public/422.html +67 -0
- data/lib/generators/jinda/templates/public/500.html +66 -0
- data/lib/generators/jinda/templates/public/assets/images/logo.png +0 -0
- data/lib/generators/jinda/templates/public/favicon.ico +0 -0
- data/lib/generators/jinda/templates/public/robots.txt +3 -0
- data/lib/generators/jinda/templates/spec/controllers/api/v1_get_index_spec.rb +23 -0
- data/lib/generators/jinda/templates/spec/controllers/api/v1_get_my_spec.rb +14 -0
- data/lib/generators/jinda/templates/spec/controllers/api/v1_post_spec.rb +19 -0
- data/lib/generators/jinda/templates/spec/controllers/sessions_controller_spec.rb +98 -0
- data/lib/generators/jinda/templates/spec/features/userlogins_spec.rb +23 -0
- data/lib/generators/jinda/templates/spec/mailers/note_spec.rb +24 -0
- data/lib/generators/jinda/templates/spec/mailers/previews/note_preview.rb +9 -0
- data/lib/generators/jinda/templates/spec/models/note_spec.rb +41 -0
- data/lib/generators/jinda/templates/spec/models/user_spec.rb +12 -0
- data/lib/generators/jinda/templates/spec/rails_helper.rb +42 -0
- data/lib/generators/jinda/templates/spec/spec_helper.rb +80 -0
- data/lib/generators/jinda/templates/spec/support/authentication_helper.rb +20 -0
- data/lib/generators/jinda/templates/spec/support/databasecleaner.rb +13 -0
- data/lib/generators/jinda/templates/spec/support/factory_bot.rb +12 -0
- data/lib/generators/jinda/templates/spec/support/omniauth_macros.rb +38 -0
- data/lib/generators/jinda/templates/spec/support/request_spec_helper.rb +8 -0
- data/lib/generators/jinda/templates/spec/views/articles/_article.html.erb_spec.rbx +14 -0
- data/lib/generators/jinda/templates/test/application_system_test_case.rb +5 -0
- data/lib/generators/jinda/templates/test/integration/jinda_routes_test.rb +42 -0
- data/lib/generators/jinda/templates/test/test_helper.rb +6 -0
- data/lib/jinda/date_helpers.rb +109 -0
- data/lib/jinda/gem_helpers.rb +11 -0
- data/lib/jinda/gen_class.rb +13 -0
- data/lib/jinda/gen_freemind.rb +33 -0
- data/lib/jinda/gen_helpers.rb +141 -0
- data/lib/jinda/gen_models.rb +137 -0
- data/lib/jinda/gen_modules.rb +17 -0
- data/lib/jinda/gen_runseq.rb +71 -0
- data/lib/jinda/gen_services.rb +90 -0
- data/lib/jinda/gen_xmain.rb +38 -0
- data/lib/jinda/get_app.rb +34 -0
- data/lib/jinda/helpers.rb +26 -0
- data/lib/jinda/init_vars.rb +36 -0
- data/lib/jinda/railtie.rb +18 -0
- data/lib/jinda/rake_views.rb +63 -0
- data/lib/jinda/refresh.rb +67 -0
- data/lib/jinda/themes.rb +175 -0
- data/lib/jinda.rb +7 -0
- data/lib/jquery.validate.js +1293 -0
- data/lib/tasks/jinda.rake +42 -0
- data/test/dummy/Rakefile +6 -0
- data/test/dummy/app/assets/config/manifest.js +3 -0
- data/test/dummy/app/assets/stylesheets/application.css +15 -0
- data/test/dummy/app/channels/application_cable/channel.rb +4 -0
- data/test/dummy/app/channels/application_cable/connection.rb +4 -0
- data/test/dummy/app/controllers/application_controller.rb +2 -0
- data/test/dummy/app/helpers/application_helper.rb +2 -0
- data/test/dummy/app/javascript/packs/application.js +15 -0
- data/test/dummy/app/jobs/application_job.rb +7 -0
- data/test/dummy/app/mailers/application_mailer.rb +4 -0
- data/test/dummy/app/models/application_record.rb +3 -0
- data/test/dummy/app/views/layouts/application.html.erb +14 -0
- data/test/dummy/app/views/layouts/mailer.html.erb +13 -0
- data/test/dummy/app/views/layouts/mailer.text.erb +1 -0
- data/test/dummy/bin/rails +4 -0
- data/test/dummy/bin/rake +4 -0
- data/test/dummy/bin/setup +33 -0
- data/test/dummy/config/application.rb +19 -0
- data/test/dummy/config/boot.rb +5 -0
- data/test/dummy/config/cable.yml +10 -0
- data/test/dummy/config/database.yml +25 -0
- data/test/dummy/config/environment.rb +5 -0
- data/test/dummy/config/environments/development.rb +62 -0
- data/test/dummy/config/environments/production.rb +112 -0
- data/test/dummy/config/environments/test.rb +49 -0
- data/test/dummy/config/initializers/application_controller_renderer.rb +8 -0
- data/test/dummy/config/initializers/assets.rb +12 -0
- data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/test/dummy/config/initializers/content_security_policy.rb +28 -0
- data/test/dummy/config/initializers/cookies_serializer.rb +5 -0
- data/test/dummy/config/initializers/filter_parameter_logging.rb +4 -0
- data/test/dummy/config/initializers/inflections.rb +16 -0
- data/test/dummy/config/initializers/mime_types.rb +4 -0
- data/test/dummy/config/initializers/wrap_parameters.rb +14 -0
- data/test/dummy/config/locales/en.yml +33 -0
- data/test/dummy/config/puma.rb +38 -0
- data/test/dummy/config/routes.rb +3 -0
- data/test/dummy/config/spring.rb +6 -0
- data/test/dummy/config/storage.yml +34 -0
- data/test/dummy/config.ru +5 -0
- data/test/dummy/db/development.sqlite3 +0 -0
- data/test/dummy/log/development.log +8 -0
- data/test/dummy/public/404.html +67 -0
- data/test/dummy/public/422.html +67 -0
- data/test/dummy/public/500.html +66 -0
- data/test/dummy/public/apple-touch-icon-precomposed.png +0 -0
- data/test/dummy/public/apple-touch-icon.png +0 -0
- data/test/dummy/public/favicon.ico +0 -0
- data/test/dummy/tmp/development_secret.txt +1 -0
- data/test/integration/navigation_test.rb +7 -0
- data/test/jinda_test.rb +7 -0
- data/test/test_helper.rb +19 -0
- metadata +466 -0
@@ -0,0 +1,15 @@
|
|
1
|
+
// This is a manifest file that'll be compiled into application.js, which will include all the files
|
2
|
+
// listed below.
|
3
|
+
//
|
4
|
+
// Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts,
|
5
|
+
// or vendor/assets/javascripts of plugins, if any, can be referenced here using a relative path.
|
6
|
+
//
|
7
|
+
// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
|
8
|
+
// the compiled file.
|
9
|
+
//
|
10
|
+
// WARNING: THE FIRST BLANK LINE MARKS THE END OF WHAT'S TO BE PROCESSED, ANY BLANK LINE SHOULD
|
11
|
+
// GO AFTER THE REQUIRES BELOW.
|
12
|
+
//
|
13
|
+
//= require jinda_jqm
|
14
|
+
|
15
|
+
|
@@ -0,0 +1,15 @@
|
|
1
|
+
/*
|
2
|
+
* This is a manifest file that'll be compiled into application.css, which will include all the files
|
3
|
+
* listed below.
|
4
|
+
*
|
5
|
+
* Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets,
|
6
|
+
* or vendor/assets/stylesheets of plugins, if any, can be referenced here using a relative path.
|
7
|
+
*
|
8
|
+
* You're free to add application-wide styles to this file and they'll appear at the top of the
|
9
|
+
* compiled file, but it's generally better to create a new file per style scope.
|
10
|
+
*
|
11
|
+
*= require_tree .
|
12
|
+
*= require_self
|
13
|
+
*= require normalize-rails
|
14
|
+
*/
|
15
|
+
@import "jinda_jqm"
|
@@ -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
|
@@ -0,0 +1,41 @@
|
|
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
|
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
|
+
|
@@ -0,0 +1,33 @@
|
|
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
|
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
|