HornsAndHooves-publify_core 10.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/CHANGELOG.md +102 -0
- data/MIT-LICENSE +21 -0
- data/README.md +9 -0
- data/app/assets/fonts/bootstrap/glyphicons-halflings-regular.eot +0 -0
- data/app/assets/fonts/bootstrap/glyphicons-halflings-regular.svg +288 -0
- data/app/assets/fonts/bootstrap/glyphicons-halflings-regular.ttf +0 -0
- data/app/assets/fonts/bootstrap/glyphicons-halflings-regular.woff +0 -0
- data/app/assets/fonts/bootstrap/glyphicons-halflings-regular.woff2 +0 -0
- data/app/assets/fonts/open-sans-bold.woff +0 -0
- data/app/assets/fonts/open-sans.woff +0 -0
- data/app/assets/images/admin/loading.gif +0 -0
- data/app/assets/images/admin/typologo.gif +0 -0
- data/app/assets/images/calendar_date_select/calendar.gif +0 -0
- data/app/assets/images/close.gif +0 -0
- data/app/assets/images/closelabel.gif +0 -0
- data/app/assets/images/go.png +0 -0
- data/app/assets/images/loading.gif +0 -0
- data/app/assets/images/nextlabel.gif +0 -0
- data/app/assets/images/overlay.png +0 -0
- data/app/assets/images/powered.gif +0 -0
- data/app/assets/images/prevlabel.gif +0 -0
- data/app/assets/images/spinner-blue.gif +0 -0
- data/app/assets/images/spinner.gif +0 -0
- data/app/assets/images/thumb_blank.jpg +0 -0
- data/app/assets/javascripts/application.js +2 -0
- data/app/assets/javascripts/bootstrap/affix.js +164 -0
- data/app/assets/javascripts/bootstrap/alert.js +95 -0
- data/app/assets/javascripts/bootstrap/button.js +125 -0
- data/app/assets/javascripts/bootstrap/collapse.js +212 -0
- data/app/assets/javascripts/bootstrap/dropdown.js +165 -0
- data/app/assets/javascripts/bootstrap/modal.js +358 -0
- data/app/assets/javascripts/bootstrap/tab.js +155 -0
- data/app/assets/javascripts/bootstrap/transition.js +59 -0
- data/app/assets/javascripts/bootstrap-sprockets.js +8 -0
- data/app/assets/javascripts/cookies.js +60 -0
- data/app/assets/javascripts/datetimepicker.js +1470 -0
- data/app/assets/javascripts/lang/da_DK.js +17 -0
- data/app/assets/javascripts/lang/default.js +21 -0
- data/app/assets/javascripts/lang/en_US.js +21 -0
- data/app/assets/javascripts/lang/fr_FR.js +21 -0
- data/app/assets/javascripts/lang/nl_NL.js +21 -0
- data/app/assets/javascripts/lang/zh_TW.js +17 -0
- data/app/assets/javascripts/lightbox.js +350 -0
- data/app/assets/javascripts/observe.js +28 -0
- data/app/assets/javascripts/publify.js +11 -0
- data/app/assets/javascripts/publify_admin.js +104 -0
- data/app/assets/javascripts/quicktags.js +448 -0
- data/app/assets/javascripts/set-timeago-lang.js +3 -0
- data/app/assets/javascripts/sidebar.js +28 -0
- data/app/assets/javascripts/spinnable.js +5 -0
- data/app/assets/javascripts/tagmanager.js +481 -0
- data/app/assets/javascripts/typeahead.js +1139 -0
- data/app/assets/stylesheets/_bootstrap-compass.scss +9 -0
- data/app/assets/stylesheets/_bootstrap-mincer.scss +19 -0
- data/app/assets/stylesheets/_bootstrap-sprockets.scss +9 -0
- data/app/assets/stylesheets/_bootstrap.scss +43 -0
- data/app/assets/stylesheets/accounts.css.scss +7 -0
- data/app/assets/stylesheets/administration_structure.css.scss +255 -0
- data/app/assets/stylesheets/bootstrap/_alerts.scss +73 -0
- data/app/assets/stylesheets/bootstrap/_button-groups.scss +242 -0
- data/app/assets/stylesheets/bootstrap/_buttons.scss +168 -0
- data/app/assets/stylesheets/bootstrap/_close.scss +37 -0
- data/app/assets/stylesheets/bootstrap/_code.scss +69 -0
- data/app/assets/stylesheets/bootstrap/_component-animations.scss +38 -0
- data/app/assets/stylesheets/bootstrap/_dropdowns.scss +213 -0
- data/app/assets/stylesheets/bootstrap/_forms.scss +586 -0
- data/app/assets/stylesheets/bootstrap/_glyphicons.scss +307 -0
- data/app/assets/stylesheets/bootstrap/_grid.scss +94 -0
- data/app/assets/stylesheets/bootstrap/_labels.scss +66 -0
- data/app/assets/stylesheets/bootstrap/_media.scss +66 -0
- data/app/assets/stylesheets/bootstrap/_mixins.scss +37 -0
- data/app/assets/stylesheets/bootstrap/_modals.scss +150 -0
- data/app/assets/stylesheets/bootstrap/_navbar.scss +479 -0
- data/app/assets/stylesheets/bootstrap/_navs.scss +242 -0
- data/app/assets/stylesheets/bootstrap/_normalize.scss +427 -0
- data/app/assets/stylesheets/bootstrap/_pagination.scss +86 -0
- data/app/assets/stylesheets/bootstrap/_panels.scss +222 -0
- data/app/assets/stylesheets/bootstrap/_print.scss +99 -0
- data/app/assets/stylesheets/bootstrap/_scaffolding.scss +160 -0
- data/app/assets/stylesheets/bootstrap/_tables.scss +234 -0
- data/app/assets/stylesheets/bootstrap/_theme.scss +224 -0
- data/app/assets/stylesheets/bootstrap/_type.scss +296 -0
- data/app/assets/stylesheets/bootstrap/_utilities.scss +55 -0
- data/app/assets/stylesheets/bootstrap/_variables.scss +654 -0
- data/app/assets/stylesheets/bootstrap/_wells.scss +29 -0
- data/app/assets/stylesheets/bootstrap/mixins/_alerts.scss +15 -0
- data/app/assets/stylesheets/bootstrap/mixins/_background-variant.scss +12 -0
- data/app/assets/stylesheets/bootstrap/mixins/_border-radius.scss +18 -0
- data/app/assets/stylesheets/bootstrap/mixins/_buttons.scss +56 -0
- data/app/assets/stylesheets/bootstrap/mixins/_center-block.scss +7 -0
- data/app/assets/stylesheets/bootstrap/mixins/_clearfix.scss +22 -0
- data/app/assets/stylesheets/bootstrap/mixins/_forms.scss +82 -0
- data/app/assets/stylesheets/bootstrap/mixins/_gradients.scss +56 -0
- data/app/assets/stylesheets/bootstrap/mixins/_grid-framework.scss +81 -0
- data/app/assets/stylesheets/bootstrap/mixins/_grid.scss +122 -0
- data/app/assets/stylesheets/bootstrap/mixins/_hide-text.scss +21 -0
- data/app/assets/stylesheets/bootstrap/mixins/_image.scss +28 -0
- data/app/assets/stylesheets/bootstrap/mixins/_labels.scss +12 -0
- data/app/assets/stylesheets/bootstrap/mixins/_nav-divider.scss +10 -0
- data/app/assets/stylesheets/bootstrap/mixins/_nav-vertical-align.scss +9 -0
- data/app/assets/stylesheets/bootstrap/mixins/_opacity.scss +7 -0
- data/app/assets/stylesheets/bootstrap/mixins/_pagination.scss +24 -0
- data/app/assets/stylesheets/bootstrap/mixins/_panels.scss +20 -0
- data/app/assets/stylesheets/bootstrap/mixins/_reset-filter.scss +8 -0
- data/app/assets/stylesheets/bootstrap/mixins/_resize.scss +6 -0
- data/app/assets/stylesheets/bootstrap/mixins/_responsive-visibility.scss +17 -0
- data/app/assets/stylesheets/bootstrap/mixins/_size.scss +10 -0
- data/app/assets/stylesheets/bootstrap/mixins/_tab-focus.scss +9 -0
- data/app/assets/stylesheets/bootstrap/mixins/_table-row.scss +28 -0
- data/app/assets/stylesheets/bootstrap/mixins/_text-emphasis.scss +12 -0
- data/app/assets/stylesheets/bootstrap/mixins/_text-overflow.scss +8 -0
- data/app/assets/stylesheets/bootstrap/mixins/_vendor-prefixes.scss +222 -0
- data/app/assets/stylesheets/coderay.css +135 -0
- data/app/assets/stylesheets/datetimepicker.css +306 -0
- data/app/assets/stylesheets/lightbox.css +63 -0
- data/app/assets/stylesheets/publify.css.scss +9 -0
- data/app/assets/stylesheets/publify_admin.css.scss +10 -0
- data/app/assets/stylesheets/rss.css +53 -0
- data/app/assets/stylesheets/sidebar_admin.css.scss +36 -0
- data/app/assets/stylesheets/tagmanager.css +102 -0
- data/app/assets/stylesheets/user-styles.css +29 -0
- data/app/controllers/accounts_controller.rb +4 -0
- data/app/controllers/admin/base_controller.rb +27 -0
- data/app/controllers/admin/content_controller.rb +194 -0
- data/app/controllers/admin/dashboard_controller.rb +33 -0
- data/app/controllers/admin/feedback_controller.rb +160 -0
- data/app/controllers/admin/notes_controller.rb +73 -0
- data/app/controllers/admin/pages_controller.rb +73 -0
- data/app/controllers/admin/post_types_controller.rb +57 -0
- data/app/controllers/admin/profiles_controller.rb +57 -0
- data/app/controllers/admin/redirects_controller.rb +51 -0
- data/app/controllers/admin/resources_controller.rb +36 -0
- data/app/controllers/admin/seo_controller.rb +46 -0
- data/app/controllers/admin/settings_controller.rb +53 -0
- data/app/controllers/admin/sidebar_controller.rb +67 -0
- data/app/controllers/admin/tags_controller.rb +55 -0
- data/app/controllers/admin/themes_controller.rb +31 -0
- data/app/controllers/admin/users_controller.rb +67 -0
- data/app/controllers/articles_controller.rb +215 -0
- data/app/controllers/authors_controller.rb +30 -0
- data/app/controllers/base_controller.rb +43 -0
- data/app/controllers/comments_controller.rb +67 -0
- data/app/controllers/content_controller.rb +24 -0
- data/app/controllers/feedback_controller.rb +13 -0
- data/app/controllers/notes_controller.rb +35 -0
- data/app/controllers/setup_controller.rb +61 -0
- data/app/controllers/tags_controller.rb +50 -0
- data/app/controllers/text_controller.rb +7 -0
- data/app/controllers/textfilter_controller.rb +5 -0
- data/app/controllers/theme_controller.rb +63 -0
- data/app/controllers/xml_controller.rb +20 -0
- data/app/helpers/admin/base_helper.rb +87 -0
- data/app/helpers/admin/feedback_helper.rb +53 -0
- data/app/helpers/articles_helper.rb +10 -0
- data/app/helpers/authors_helper.rb +30 -0
- data/app/helpers/base_helper.rb +257 -0
- data/app/helpers/blog_helper.rb +14 -0
- data/app/helpers/xml_helper.rb +18 -0
- data/app/jobs/application_job.rb +5 -0
- data/app/mailers/notification_mailer.rb +40 -0
- data/app/models/ability.rb +53 -0
- data/app/models/archives_sidebar.rb +45 -0
- data/app/models/article/factory.rb +64 -0
- data/app/models/article.rb +308 -0
- data/app/models/blog.rb +280 -0
- data/app/models/comment.rb +57 -0
- data/app/models/config_manager.rb +83 -0
- data/app/models/content.rb +118 -0
- data/app/models/content_base.rb +88 -0
- data/app/models/feedback.rb +250 -0
- data/app/models/meta_sidebar.rb +10 -0
- data/app/models/note.rb +152 -0
- data/app/models/page.rb +42 -0
- data/app/models/page_sidebar.rb +14 -0
- data/app/models/ping.rb +5 -0
- data/app/models/post_type.rb +16 -0
- data/app/models/redirect.rb +51 -0
- data/app/models/redirection.rb +6 -0
- data/app/models/resource.rb +12 -0
- data/app/models/search_sidebar.rb +9 -0
- data/app/models/sidebar.rb +142 -0
- data/app/models/static_sidebar.rb +22 -0
- data/app/models/tag.rb +71 -0
- data/app/models/tag_sidebar.rb +30 -0
- data/app/models/text_filter.rb +141 -0
- data/app/models/trackback.rb +46 -0
- data/app/models/trigger.rb +34 -0
- data/app/models/user.rb +142 -0
- data/app/services/title_builder.rb +88 -0
- data/app/uploaders/resource_uploader.rb +63 -0
- data/app/views/accounts/confirm.html.erb +7 -0
- data/app/views/admin/content/_article_list.html.erb +26 -0
- data/app/views/admin/content/_form.html.erb +145 -0
- data/app/views/admin/content/autosave.js.erb +5 -0
- data/app/views/admin/content/edit.html.erb +3 -0
- data/app/views/admin/content/index.html.erb +48 -0
- data/app/views/admin/content/index.js.erb +1 -0
- data/app/views/admin/content/new.html.erb +3 -0
- data/app/views/admin/dashboard/_comment.html.erb +18 -0
- data/app/views/admin/dashboard/_comments.html.erb +10 -0
- data/app/views/admin/dashboard/_drafts.html.erb +25 -0
- data/app/views/admin/dashboard/_overview.html.erb +21 -0
- data/app/views/admin/dashboard/_welcome.html.erb +28 -0
- data/app/views/admin/dashboard/index.html.erb +16 -0
- data/app/views/admin/feedback/_button.html.erb +19 -0
- data/app/views/admin/feedback/_feedback.html.erb +7 -0
- data/app/views/admin/feedback/_ham.html.erb +17 -0
- data/app/views/admin/feedback/_spam.html.erb +23 -0
- data/app/views/admin/feedback/article.html.erb +69 -0
- data/app/views/admin/feedback/edit.html.erb +48 -0
- data/app/views/admin/feedback/ham.js +1 -0
- data/app/views/admin/feedback/index.html.erb +53 -0
- data/app/views/admin/feedback/spam.js +1 -0
- data/app/views/admin/migrations/show.html.erb +39 -0
- data/app/views/admin/notes/_form.html.erb +37 -0
- data/app/views/admin/notes/_header.html.erb +6 -0
- data/app/views/admin/notes/_list.html.erb +13 -0
- data/app/views/admin/notes/_note.html.erb +14 -0
- data/app/views/admin/notes/edit.html.erb +11 -0
- data/app/views/admin/notes/index.html.erb +11 -0
- data/app/views/admin/notes/show.html.erb +14 -0
- data/app/views/admin/pages/_form.html.erb +101 -0
- data/app/views/admin/pages/_pages.html.erb +21 -0
- data/app/views/admin/pages/edit.html.erb +1 -0
- data/app/views/admin/pages/index.html.erb +17 -0
- data/app/views/admin/pages/new.html.erb +1 -0
- data/app/views/admin/post_types/_index_and_form.html.erb +65 -0
- data/app/views/admin/post_types/edit.html.erb +1 -0
- data/app/views/admin/post_types/index.html.erb +1 -0
- data/app/views/admin/profiles/index.html.erb +10 -0
- data/app/views/admin/redirects/_index_and_form.html.erb +68 -0
- data/app/views/admin/redirects/edit.html.erb +1 -0
- data/app/views/admin/redirects/index.html.erb +1 -0
- data/app/views/admin/resources/index.html.erb +72 -0
- data/app/views/admin/seo/_general.html.erb +104 -0
- data/app/views/admin/seo/_permalinks.html.erb +53 -0
- data/app/views/admin/seo/_titles.html.erb +209 -0
- data/app/views/admin/seo/show.html.erb +28 -0
- data/app/views/admin/settings/display.html.erb +101 -0
- data/app/views/admin/settings/feedback.html.erb +118 -0
- data/app/views/admin/settings/index.html.erb +73 -0
- data/app/views/admin/settings/write.html.erb +69 -0
- data/app/views/admin/shared/_edit.html.erb +4 -0
- data/app/views/admin/shared/_menu.html.erb +121 -0
- data/app/views/admin/shared/_twitter_alert.html.erb +3 -0
- data/app/views/admin/sidebar/_available.html.erb +6 -0
- data/app/views/admin/sidebar/_available.json.erb +6 -0
- data/app/views/admin/sidebar/_config.html.erb +27 -0
- data/app/views/admin/sidebar/_target.html.erb +9 -0
- data/app/views/admin/sidebar/_target_sidebar.html.erb +20 -0
- data/app/views/admin/sidebar/destroy.js.erb +1 -0
- data/app/views/admin/sidebar/index.html.erb +31 -0
- data/app/views/admin/sidebar/sortable.js.erb +3 -0
- data/app/views/admin/sidebar/update.js.erb +2 -0
- data/app/views/admin/tags/_index_and_form.html.erb +59 -0
- data/app/views/admin/tags/edit.html.erb +1 -0
- data/app/views/admin/tags/index.html.erb +1 -0
- data/app/views/admin/themes/index.html.erb +27 -0
- data/app/views/admin/users/_form.html.erb +215 -0
- data/app/views/admin/users/edit.html.erb +8 -0
- data/app/views/admin/users/index.html.erb +39 -0
- data/app/views/admin/users/new.html.erb +8 -0
- data/app/views/archives_sidebar/_content.html.erb +13 -0
- data/app/views/articles/_archives_article.html.erb +9 -0
- data/app/views/articles/_article.html.erb +9 -0
- data/app/views/articles/_article_author.html.erb +4 -0
- data/app/views/articles/_article_collection.html.erb +8 -0
- data/app/views/articles/_article_content.html.erb +5 -0
- data/app/views/articles/_article_excerpt.html.erb +15 -0
- data/app/views/articles/_article_links.html.erb +12 -0
- data/app/views/articles/_comment.html.erb +1 -0
- data/app/views/articles/_comment_errors.html.erb +2 -0
- data/app/views/articles/_comment_form.html.erb +48 -0
- data/app/views/articles/_comment_list.html.erb +5 -0
- data/app/views/articles/_comment_preview.html.erb +4 -0
- data/app/views/articles/_full_article_content.html.erb +4 -0
- data/app/views/articles/_password_form.html.erb +10 -0
- data/app/views/articles/_trackback.html.erb +6 -0
- data/app/views/articles/archives.html.erb +15 -0
- data/app/views/articles/comment.js.erb +5 -0
- data/app/views/articles/comment_failed.js.erb +3 -0
- data/app/views/articles/error.html.erb +3 -0
- data/app/views/articles/feedback_atom_feed.atom.builder +10 -0
- data/app/views/articles/feedback_rss_feed.rss.builder +21 -0
- data/app/views/articles/index.html.erb +1 -0
- data/app/views/articles/index_atom_feed.atom.builder +9 -0
- data/app/views/articles/index_rss_feed.rss.builder +20 -0
- data/app/views/articles/live_search.html.erb +10 -0
- data/app/views/articles/read.html.erb +43 -0
- data/app/views/articles/search.html.erb +8 -0
- data/app/views/articles/trackback.xml.builder +7 -0
- data/app/views/articles/view_page.html.erb +3 -0
- data/app/views/authors/show.html.erb +30 -0
- data/app/views/authors/show_atom_feed.atom.builder +9 -0
- data/app/views/authors/show_rss_feed.rss.builder +20 -0
- data/app/views/comments/_comment.html.erb +17 -0
- data/app/views/comments/preview.html.erb +1 -0
- data/app/views/comments/preview.js.erb +3 -0
- data/app/views/devise/mailer/reset_password_instructions.html.erb +11 -0
- data/app/views/devise/passwords/edit.html.erb +28 -0
- data/app/views/devise/passwords/new.html.erb +20 -0
- data/app/views/devise/registrations/new.html.erb +36 -0
- data/app/views/devise/sessions/new.html.erb +32 -0
- data/app/views/devise/shared/_links.html.erb +11 -0
- data/app/views/errors/404.html.erb +2 -0
- data/app/views/feedback/index.atom.builder +9 -0
- data/app/views/feedback/index.rss.builder +20 -0
- data/app/views/layouts/accounts.html.erb +33 -0
- data/app/views/layouts/administration.html.erb +37 -0
- data/app/views/layouts/default.html.erb +33 -0
- data/app/views/layouts/editor.html.erb +17 -0
- data/app/views/meta_sidebar/_content.html.erb +8 -0
- data/app/views/notes/_note.html.erb +16 -0
- data/app/views/notes/error.html.erb +3 -0
- data/app/views/notes/index.html.erb +15 -0
- data/app/views/notes/show.html.erb +5 -0
- data/app/views/notes/show_in_reply.html.erb +18 -0
- data/app/views/notification_mailer/_mail_footer.html.erb +5 -0
- data/app/views/notification_mailer/_mail_header.html.erb +3 -0
- data/app/views/notification_mailer/article.html.erb +7 -0
- data/app/views/notification_mailer/comment.html.erb +12 -0
- data/app/views/notification_mailer/notif_user.html.erb +9 -0
- data/app/views/page_sidebar/_content.html.erb +12 -0
- data/app/views/search_sidebar/_content.html.erb +10 -0
- data/app/views/settings/done.html.erb +2 -0
- data/app/views/settings/install.html.erb +12 -0
- data/app/views/setup/index.html.erb +17 -0
- data/app/views/shared/_atom_header.atom.builder +6 -0
- data/app/views/shared/_atom_item_article.atom.builder +36 -0
- data/app/views/shared/_atom_item_comment.atom.builder +10 -0
- data/app/views/shared/_atom_item_trackback.atom.builder +10 -0
- data/app/views/shared/_flash.erb +10 -0
- data/app/views/shared/_google_analytics.html.erb +8 -0
- data/app/views/shared/_page_header.html.erb +23 -0
- data/app/views/shared/_rss_item_article.rss.builder +32 -0
- data/app/views/shared/_rss_item_comment.rss.builder +9 -0
- data/app/views/shared/_rss_item_trackback.rss.builder +9 -0
- data/app/views/sidebar/_row.html.erb +1 -0
- data/app/views/sidebar/_sidebar.html.erb +5 -0
- data/app/views/sidebar/display_plugins.html.erb +5 -0
- data/app/views/sidebar/show.html.erb +1 -0
- data/app/views/static_sidebar/_content.html.erb +2 -0
- data/app/views/tag_sidebar/_content.html.erb +10 -0
- data/app/views/tags/index.html.erb +15 -0
- data/app/views/tags/show.html.erb +1 -0
- data/app/views/theme/static_view_test.html.erb +1 -0
- data/app/views/xml/_googlesitemap_item_article.googlesitemap.builder +7 -0
- data/app/views/xml/_googlesitemap_item_category.googlesitemap.builder +6 -0
- data/app/views/xml/_googlesitemap_item_page.googlesitemap.builder +6 -0
- data/app/views/xml/_googlesitemap_item_tag.googlesitemap.builder +6 -0
- data/app/views/xml/sitemap.googlesitemap.builder +9 -0
- data/config/i18n-tasks.yml +49 -0
- data/config/initializers/devise.rb +271 -0
- data/config/initializers/mime_types.rb +7 -0
- data/config/locales/da.yml +769 -0
- data/config/locales/de.yml +769 -0
- data/config/locales/en.yml +770 -0
- data/config/locales/es-MX.yml +769 -0
- data/config/locales/fr.yml +769 -0
- data/config/locales/he.yml +769 -0
- data/config/locales/it.yml +769 -0
- data/config/locales/ja.yml +769 -0
- data/config/locales/lt.yml +783 -0
- data/config/locales/nb-NO.yml +769 -0
- data/config/locales/nl.yml +769 -0
- data/config/locales/pl.yml +797 -0
- data/config/locales/pt-BR.yml +769 -0
- data/config/locales/ro.yml +782 -0
- data/config/locales/ru.yml +797 -0
- data/config/locales/sidebars.da.yml +20 -0
- data/config/locales/sidebars.de.yml +20 -0
- data/config/locales/sidebars.en.yml +20 -0
- data/config/locales/sidebars.es-MX.yml +20 -0
- data/config/locales/sidebars.fr.yml +20 -0
- data/config/locales/sidebars.he.yml +20 -0
- data/config/locales/sidebars.it.yml +20 -0
- data/config/locales/sidebars.ja.yml +20 -0
- data/config/locales/sidebars.lt.yml +20 -0
- data/config/locales/sidebars.nb-NO.yml +20 -0
- data/config/locales/sidebars.nl.yml +20 -0
- data/config/locales/sidebars.pl.yml +20 -0
- data/config/locales/sidebars.pt-BR.yml +20 -0
- data/config/locales/sidebars.ro.yml +20 -0
- data/config/locales/sidebars.ru.yml +20 -0
- data/config/locales/sidebars.zh-CN.yml +20 -0
- data/config/locales/sidebars.zh-TW.yml +20 -0
- data/config/locales/zh-CN.yml +768 -0
- data/config/locales/zh-TW.yml +769 -0
- data/config/routes.rb +174 -0
- data/db/migrate/113_initial_schema.rb +210 -0
- data/db/migrate/114_fixes_buggy_articles_and_notes.rb +56 -0
- data/db/migrate/115_drops_categories_for_tags.rb +37 -0
- data/db/migrate/20150207131657_add_missing_indexes.rb +23 -0
- data/db/migrate/20150807134129_simplify_redirect_relations.rb +45 -0
- data/db/migrate/20150808052637_add_blog_ids.rb +39 -0
- data/db/migrate/20150808191127_add_blog_id_to_redirects.rb +19 -0
- data/db/migrate/20150810094754_add_blog_id_to_tags.rb +19 -0
- data/db/migrate/20160108111120_add_devise_to_users.rb +57 -0
- data/db/migrate/20160108184201_move_last_connection_to_last_sign_in_at.rb +20 -0
- data/db/migrate/20160110094906_remove_profiles_rights.rb +18 -0
- data/db/migrate/20160605103918_replace_profile_id_with_string.rb +32 -0
- data/db/migrate/20160605154632_remove_profiles.rb +31 -0
- data/db/migrate/20160701061851_demand_blog_id_on_contents.rb +13 -0
- data/db/migrate/20160701062604_add_blog_id_to_resources.rb +32 -0
- data/db/migrate/20170528093024_move_resources_to_content.rb +9 -0
- data/db/migrate/20170528094923_move_tags_to_content.rb +10 -0
- data/db/migrate/20170528201606_remove_separate_published_flag.rb +9 -0
- data/db/migrate/20170605071626_remove_extra_state_columns_from_feedback.rb +10 -0
- data/db/migrate/20170702105201_remove_published_at_from_feedback.rb +9 -0
- data/db/migrate/20190208151235_add_text_filter_name_fields.rb +11 -0
- data/db/migrate/20190208152646_move_text_filter_to_name.rb +99 -0
- data/db/migrate/20190209155717_remove_text_filter_ids.rb +21 -0
- data/db/migrate/20190209160610_remove_text_filters.rb +19 -0
- data/db/seeds.rb +25 -0
- data/lib/email_notify.rb +28 -0
- data/lib/format.rb +9 -0
- data/lib/publify_core/engine.rb +31 -0
- data/lib/publify_core/lang.rb +9 -0
- data/lib/publify_core/testing_support/dns_mock.rb +15 -0
- data/lib/publify_core/testing_support/factories.rb +242 -0
- data/lib/publify_core/testing_support/feed_assertions.rb +48 -0
- data/lib/publify_core/testing_support/fixtures/exploit.svg +4 -0
- data/lib/publify_core/testing_support/fixtures/fakepng.png +1 -0
- data/lib/publify_core/testing_support/fixtures/otherfile.txt +1 -0
- data/lib/publify_core/testing_support/fixtures/testfile.png +0 -0
- data/lib/publify_core/testing_support/fixtures/testfile.txt +1 -0
- data/lib/publify_core/testing_support/upload_fixtures.rb +15 -0
- data/lib/publify_core/version.rb +5 -0
- data/lib/publify_core.rb +46 -0
- data/lib/publify_guid.rb +11 -0
- data/lib/publify_plugins.rb +77 -0
- data/lib/publify_textfilter_markdown.rb +57 -0
- data/lib/publify_textfilter_none.rb +16 -0
- data/lib/publify_textfilter_smartypants.rb +16 -0
- data/lib/publify_textfilter_textile.rb +23 -0
- data/lib/publify_textfilter_twitterfilter.rb +39 -0
- data/lib/publify_time.rb +34 -0
- data/lib/sidebar_field.rb +127 -0
- data/lib/sidebar_registry.rb +35 -0
- data/lib/spam_protection.rb +103 -0
- data/lib/tasks/i18n.rake +9 -0
- data/lib/tasks/manifest.rake +30 -0
- data/lib/tasks/publify_core_tasks.rake +6 -0
- data/lib/text_filter_plugin.rb +183 -0
- data/lib/theme.rb +72 -0
- data/lib/transforms.rb +47 -0
- data/themes/plain/about.markdown +4 -0
- data/themes/plain/javascripts/theme.js +0 -0
- data/themes/plain/preview.png +0 -0
- data/themes/plain/stylesheets/theme.css +57 -0
- metadata +1062 -0
@@ -0,0 +1,36 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class Admin::ResourcesController < Admin::BaseController
|
4
|
+
def upload
|
5
|
+
file = params[:upload]
|
6
|
+
|
7
|
+
@up = Resource.new(blog: this_blog, upload: file)
|
8
|
+
@up.mime = @up.upload.content_type
|
9
|
+
|
10
|
+
if @up.save
|
11
|
+
flash[:success] = I18n.t("admin.resources.upload.success")
|
12
|
+
else
|
13
|
+
flash[:warning] = I18n.t("admin.resources.upload.warning")
|
14
|
+
end
|
15
|
+
|
16
|
+
redirect_to admin_resources_url
|
17
|
+
end
|
18
|
+
|
19
|
+
def index
|
20
|
+
@r = Resource.new
|
21
|
+
@resources = Resource.order("created_at DESC").page(params[:page]).
|
22
|
+
per(this_blog.admin_display_elements)
|
23
|
+
end
|
24
|
+
|
25
|
+
def destroy
|
26
|
+
if Content.where(resource_id: params[:id]).any?
|
27
|
+
flash[:error] = I18n.t("admin.resources.destroy.error")
|
28
|
+
else
|
29
|
+
@record = Resource.find(params[:id])
|
30
|
+
@record.destroy
|
31
|
+
flash[:notice] = I18n.t("admin.resources.destroy.notice")
|
32
|
+
end
|
33
|
+
|
34
|
+
redirect_to admin_resources_url
|
35
|
+
end
|
36
|
+
end
|
@@ -0,0 +1,46 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class Admin::SeoController < Admin::BaseController
|
4
|
+
before_action :set_setting
|
5
|
+
before_action :set_section
|
6
|
+
|
7
|
+
def show
|
8
|
+
if @setting.permalink_format != "/%year%/%month%/%day%/%title%" &&
|
9
|
+
@setting.permalink_format != "/%year%/%month%/%title%" &&
|
10
|
+
@setting.permalink_format != "/%title%"
|
11
|
+
@setting.custom_permalink = @setting.permalink_format
|
12
|
+
@setting.permalink_format = "custom"
|
13
|
+
end
|
14
|
+
end
|
15
|
+
|
16
|
+
def update
|
17
|
+
if settings_params[:permalink_format] == "custom"
|
18
|
+
settings_params[:permalink_format] = settings_params[:custom_permalink]
|
19
|
+
end
|
20
|
+
if @setting.update(settings_params)
|
21
|
+
flash[:success] = I18n.t("admin.settings.update.success")
|
22
|
+
redirect_to admin_seo_path(section: @section)
|
23
|
+
else
|
24
|
+
flash[:error] = I18n.t("admin.settings.update.error",
|
25
|
+
messages: this_blog.errors.full_messages.join(", "))
|
26
|
+
render :show
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
private
|
31
|
+
|
32
|
+
def settings_params
|
33
|
+
@settings_params ||= params.require(:setting).permit!
|
34
|
+
end
|
35
|
+
|
36
|
+
VALID_SECTIONS = %w(general titles permalinks).freeze
|
37
|
+
|
38
|
+
def set_section
|
39
|
+
section = params[:section]
|
40
|
+
@section = VALID_SECTIONS.include?(section) ? section : "general"
|
41
|
+
end
|
42
|
+
|
43
|
+
def set_setting
|
44
|
+
@setting = this_blog
|
45
|
+
end
|
46
|
+
end
|
@@ -0,0 +1,53 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class Admin::SettingsController < Admin::BaseController
|
4
|
+
def index
|
5
|
+
this_blog.base_url = blog_base_url if this_blog.base_url.blank?
|
6
|
+
load_settings
|
7
|
+
end
|
8
|
+
|
9
|
+
def write
|
10
|
+
load_settings
|
11
|
+
end
|
12
|
+
|
13
|
+
def feedback
|
14
|
+
load_settings
|
15
|
+
end
|
16
|
+
|
17
|
+
def display
|
18
|
+
load_settings
|
19
|
+
end
|
20
|
+
|
21
|
+
def update
|
22
|
+
load_settings
|
23
|
+
if @setting.update(settings_params)
|
24
|
+
load_lang
|
25
|
+
flash[:success] = I18n.t("admin.settings.update.success")
|
26
|
+
redirect_to action: action_param
|
27
|
+
else
|
28
|
+
flash[:error] = I18n.t("admin.settings.update.error",
|
29
|
+
messages: this_blog.errors.full_messages.join(", "))
|
30
|
+
render action_param
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
private
|
35
|
+
|
36
|
+
VALID_ACTIONS = %w(index write feedback display).freeze
|
37
|
+
|
38
|
+
def settings_params
|
39
|
+
@settings_params ||= params.require(:setting).permit!
|
40
|
+
end
|
41
|
+
|
42
|
+
def action_param
|
43
|
+
@action_param ||=
|
44
|
+
begin
|
45
|
+
value = params[:from]
|
46
|
+
VALID_ACTIONS.include?(value) ? value : "index"
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
def load_settings
|
51
|
+
@setting = this_blog
|
52
|
+
end
|
53
|
+
end
|
@@ -0,0 +1,67 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class Admin::SidebarController < Admin::BaseController
|
4
|
+
def index
|
5
|
+
@available = SidebarRegistry.available_sidebars
|
6
|
+
@ordered_sidebars = Sidebar.ordered_sidebars
|
7
|
+
end
|
8
|
+
|
9
|
+
# Just update a single active Sidebar instance at once
|
10
|
+
def update
|
11
|
+
@sidebar = Sidebar.where(id: params[:id]).first
|
12
|
+
@old_s_index = @sidebar.staged_position || @sidebar.active_position
|
13
|
+
@sidebar.update params[:configure][@sidebar.id.to_s].permit!
|
14
|
+
respond_to do |format|
|
15
|
+
format.js
|
16
|
+
format.html do
|
17
|
+
return redirect_to(admin_sidebar_index_path)
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
def destroy
|
23
|
+
@sidebar = Sidebar.where(id: params[:id]).first
|
24
|
+
@sidebar&.destroy
|
25
|
+
respond_to do |format|
|
26
|
+
format.html { return redirect_to(admin_sidebar_index_path) }
|
27
|
+
format.js
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
31
|
+
def publish
|
32
|
+
Sidebar.apply_staging_on_active!
|
33
|
+
redirect_to admin_sidebar_index_path
|
34
|
+
end
|
35
|
+
|
36
|
+
# Callback for admin sidebar sortable plugin
|
37
|
+
def sortable
|
38
|
+
sorted = params[:sidebar].map(&:to_i)
|
39
|
+
|
40
|
+
Sidebar.transaction do
|
41
|
+
sorted.each_with_index do |sidebar_id, staged_index|
|
42
|
+
# DEV NOTE : Ok, that's a HUGE hack. Sidebar.available are Class, not
|
43
|
+
# Sidebar instances. In order to use jQuery.sortable we need that hack:
|
44
|
+
# Sidebar.available is an Array, so it's ordered. I arbitrary shift by?
|
45
|
+
# IT'S OVER NINE THOUSAND! considering we'll never reach 9K Sidebar
|
46
|
+
# instances or Sidebar specializations
|
47
|
+
sidebar = if sidebar_id >= 9000
|
48
|
+
SidebarRegistry.available_sidebars[sidebar_id - 9000].
|
49
|
+
new(blog: this_blog)
|
50
|
+
else
|
51
|
+
Sidebar.valid.find(sidebar_id)
|
52
|
+
end
|
53
|
+
sidebar.update(staged_position: staged_index)
|
54
|
+
end
|
55
|
+
end
|
56
|
+
|
57
|
+
@ordered_sidebars = Sidebar.ordered_sidebars
|
58
|
+
@available = SidebarRegistry.available_sidebars
|
59
|
+
|
60
|
+
respond_to do |format|
|
61
|
+
format.js
|
62
|
+
format.html do
|
63
|
+
return redirect_to admin_sidebar_index_path
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
67
|
+
end
|
@@ -0,0 +1,55 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class Admin::TagsController < Admin::BaseController
|
4
|
+
before_action :fetch_tags, only: [:index, :edit]
|
5
|
+
before_action :set_tag, only: [:edit, :update, :destroy]
|
6
|
+
|
7
|
+
def index
|
8
|
+
@tag = Tag.new
|
9
|
+
end
|
10
|
+
|
11
|
+
def edit; end
|
12
|
+
|
13
|
+
def create
|
14
|
+
@tag = this_blog.tags.new(tag_params)
|
15
|
+
|
16
|
+
if @tag.save
|
17
|
+
redirect_to admin_tags_url, notice: "Tag was successfully created."
|
18
|
+
else
|
19
|
+
fetch_tags
|
20
|
+
render :index
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
def update
|
25
|
+
old_name = @tag.name
|
26
|
+
if @tag.update(tag_params)
|
27
|
+
# TODO: Check whether these redirects are useful or ignored.
|
28
|
+
Redirect.create(from_path: "/tag/#{old_name}", to_path: @tag.permalink_url(nil, true))
|
29
|
+
redirect_to admin_tags_url, notice: I18n.t("admin.tags.edit.success")
|
30
|
+
else
|
31
|
+
render :edit
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
def destroy
|
36
|
+
destroy_a(Tag)
|
37
|
+
end
|
38
|
+
|
39
|
+
private
|
40
|
+
|
41
|
+
# Use callbacks to share common setup or constraints between actions.
|
42
|
+
def set_tag
|
43
|
+
@tag = Tag.find(params[:id])
|
44
|
+
end
|
45
|
+
|
46
|
+
# Never trust parameters from the scary internet, only allow the white list through.
|
47
|
+
def tag_params
|
48
|
+
params.require(:tag).permit(:display_name)
|
49
|
+
end
|
50
|
+
|
51
|
+
def fetch_tags
|
52
|
+
@tags = Tag.order("display_name").page(params[:page]).
|
53
|
+
per(this_blog.admin_display_elements)
|
54
|
+
end
|
55
|
+
end
|
@@ -0,0 +1,31 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "open-uri"
|
4
|
+
require "time"
|
5
|
+
require "rexml/document"
|
6
|
+
|
7
|
+
class Admin::ThemesController < Admin::BaseController
|
8
|
+
def index
|
9
|
+
@themes = Theme.find_all
|
10
|
+
@themes.each do |theme|
|
11
|
+
# TODO: Move to Theme
|
12
|
+
theme.description_html = TextFilter.filter_text(theme.description,
|
13
|
+
[:markdown, :smartypants])
|
14
|
+
end
|
15
|
+
@active = this_blog.current_theme
|
16
|
+
end
|
17
|
+
|
18
|
+
def preview
|
19
|
+
theme = Theme.find(params[:theme])
|
20
|
+
send_file File.join(theme.path, "preview.png"),
|
21
|
+
type: "image/png", disposition: "inline", stream: false
|
22
|
+
end
|
23
|
+
|
24
|
+
def switchto
|
25
|
+
this_blog.theme = params[:theme]
|
26
|
+
this_blog.save
|
27
|
+
this_blog.current_theme(:reload)
|
28
|
+
flash[:success] = I18n.t("admin.themes.switchto.success")
|
29
|
+
redirect_to admin_themes_url
|
30
|
+
end
|
31
|
+
end
|
@@ -0,0 +1,67 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class Admin::UsersController < Admin::BaseController
|
4
|
+
before_action :set_user, only: [:edit, :update, :destroy]
|
5
|
+
|
6
|
+
def index
|
7
|
+
@users = User.order("login asc").page(params[:page]).
|
8
|
+
per(this_blog.admin_display_elements)
|
9
|
+
end
|
10
|
+
|
11
|
+
def new
|
12
|
+
@user = User.new
|
13
|
+
@user.text_filter_name = this_blog.text_filter
|
14
|
+
end
|
15
|
+
|
16
|
+
def edit
|
17
|
+
@user = params[:id] ? User.find_by(id: params[:id]) : current_user
|
18
|
+
end
|
19
|
+
|
20
|
+
def create
|
21
|
+
@user = User.new(user_params)
|
22
|
+
@user.name = @user.login
|
23
|
+
if @user.save
|
24
|
+
redirect_to admin_users_url, notice: I18n.t("admin.users.new.success")
|
25
|
+
else
|
26
|
+
render :new
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
def update
|
31
|
+
if @user.update(update_params)
|
32
|
+
redirect_to admin_users_url, notice: "User was successfully updated."
|
33
|
+
else
|
34
|
+
render :edit
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
def destroy
|
39
|
+
@user.destroy if User.where("profile = ? and id != ?", User::ADMIN, @user.id).count > 1
|
40
|
+
redirect_to admin_users_url
|
41
|
+
end
|
42
|
+
|
43
|
+
private
|
44
|
+
|
45
|
+
def set_user
|
46
|
+
@user = User.find(params[:id])
|
47
|
+
end
|
48
|
+
|
49
|
+
def user_params
|
50
|
+
params.require(:user).permit(:login, :password, :password_confirmation,
|
51
|
+
:email, :firstname, :lastname, :nickname,
|
52
|
+
:name, :notify_via_email,
|
53
|
+
:notify_on_new_articles, :notify_on_comments,
|
54
|
+
:profile, :text_filter_name, :state,
|
55
|
+
:twitter_account, :twitter_oauth_token,
|
56
|
+
:twitter_oauth_token_secret, :description,
|
57
|
+
:url, :msn, :yahoo, :jabber, :aim, :twitter)
|
58
|
+
end
|
59
|
+
|
60
|
+
def update_params
|
61
|
+
if user_params[:password].blank? && user_params[:password_confirmation].blank?
|
62
|
+
user_params.except(:password_confirmation, :password)
|
63
|
+
else
|
64
|
+
user_params
|
65
|
+
end
|
66
|
+
end
|
67
|
+
end
|
@@ -0,0 +1,215 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class ArticlesController < ContentController
|
4
|
+
RECENT_ARTICLES_COUNT = 3
|
5
|
+
|
6
|
+
before_action :login_required, only: [:preview, :preview_page]
|
7
|
+
before_action :auto_discovery_feed, only: [:show, :index]
|
8
|
+
before_action :verify_config
|
9
|
+
before_action :populate_recent_articles, only: [:redirect, :preview]
|
10
|
+
|
11
|
+
layout :theme_layout, except: [:trackback]
|
12
|
+
|
13
|
+
helper :'admin/base'
|
14
|
+
|
15
|
+
def index
|
16
|
+
wanted_types = this_blog.statuses_in_timeline ? ["Article", "Note"] : ["Article"]
|
17
|
+
|
18
|
+
limit = this_blog.per_page(params[:format])
|
19
|
+
articles_base = if params[:year].blank?
|
20
|
+
this_blog.contents.published
|
21
|
+
else
|
22
|
+
this_blog.contents.published_at(params.values_at(:year, :month, :day))
|
23
|
+
end
|
24
|
+
@articles = articles_base.includes(:user, :resources, :tags).
|
25
|
+
where(type: wanted_types).page(params[:page]).per(limit)
|
26
|
+
|
27
|
+
respond_to do |format|
|
28
|
+
format.html do
|
29
|
+
set_index_title_and_description(this_blog, params)
|
30
|
+
@keywords = this_blog.meta_keywords
|
31
|
+
|
32
|
+
render_paginated_index
|
33
|
+
end
|
34
|
+
format.atom do
|
35
|
+
render_articles_feed("atom")
|
36
|
+
end
|
37
|
+
format.rss do
|
38
|
+
auto_discovery_feed(only_path: false)
|
39
|
+
render_articles_feed("rss")
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
def search
|
45
|
+
@articles = this_blog.articles_matching(params[:q],
|
46
|
+
page: params[:page],
|
47
|
+
per_page: this_blog.per_page(params[:format]))
|
48
|
+
return error! if @articles.empty?
|
49
|
+
|
50
|
+
@page_title = this_blog.search_title_template.to_title(@articles, this_blog, params)
|
51
|
+
@description = this_blog.search_desc_template.to_title(@articles, this_blog, params)
|
52
|
+
respond_to do |format|
|
53
|
+
format.html { render "search" }
|
54
|
+
format.rss { render_articles_feed "rss" }
|
55
|
+
format.atom { render_articles_feed "atom" }
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
59
|
+
def live_search
|
60
|
+
@search = params[:q]
|
61
|
+
@articles = Article.search(@search)
|
62
|
+
render :live_search, layout: false
|
63
|
+
end
|
64
|
+
|
65
|
+
def preview
|
66
|
+
@article = Article.last_draft(params[:id])
|
67
|
+
@page_title = this_blog.article_title_template.to_title(@article, this_blog, params)
|
68
|
+
|
69
|
+
render "read"
|
70
|
+
end
|
71
|
+
|
72
|
+
def check_password
|
73
|
+
return unless request.xhr?
|
74
|
+
|
75
|
+
@article = Article.find(params[:article][:id])
|
76
|
+
if @article.password == params[:article][:password]
|
77
|
+
render partial: "articles/full_article_content", locals: { article: @article }
|
78
|
+
else
|
79
|
+
render partial: "articles/password_form", locals: { article: @article }
|
80
|
+
end
|
81
|
+
end
|
82
|
+
|
83
|
+
def redirect
|
84
|
+
from = extract_feed_format(params[:from])
|
85
|
+
factory = Article::Factory.new(this_blog, current_user)
|
86
|
+
|
87
|
+
@article = factory.match_permalink_format(from, this_blog.permalink_format)
|
88
|
+
return show_article if @article
|
89
|
+
|
90
|
+
# Redirect old version with /:year/:month/:day/:title to new format,
|
91
|
+
# because it's changed
|
92
|
+
["%year%/%month%/%day%/%title%", "articles/%year%/%month%/%day%/%title%"].each do |part|
|
93
|
+
@article = factory.match_permalink_format(from, part)
|
94
|
+
if @article
|
95
|
+
return redirect_to URI.parse(@article.permalink_url).path,
|
96
|
+
status: :moved_permanently
|
97
|
+
end
|
98
|
+
end
|
99
|
+
|
100
|
+
r = Redirect.find_by!(from_path: from)
|
101
|
+
# TODO: If linked to article, directly redirect to the article.
|
102
|
+
# Let redirection made outside of the blog on purpose (deal with it, Brakeman!)
|
103
|
+
redirect_to r.full_to_path, status: :moved_permanently if r
|
104
|
+
end
|
105
|
+
|
106
|
+
def archives
|
107
|
+
limit = this_blog.limit_archives_display
|
108
|
+
@articles = this_blog.published_articles.includes(:tags).page(params[:page]).per(limit)
|
109
|
+
@page_title = this_blog.archives_title_template.to_title(@articles, this_blog, params)
|
110
|
+
@keywords = this_blog.meta_keywords
|
111
|
+
@description = this_blog.archives_desc_template.to_title(@articles, this_blog, params)
|
112
|
+
end
|
113
|
+
|
114
|
+
def tag
|
115
|
+
redirect_to tags_path, status: :moved_permanently
|
116
|
+
end
|
117
|
+
|
118
|
+
def preview_page
|
119
|
+
@page = Page.find(params[:id])
|
120
|
+
render "view_page"
|
121
|
+
end
|
122
|
+
|
123
|
+
def view_page
|
124
|
+
@page = Page.published.find_by!(name: Array(params[:name]).join("/"))
|
125
|
+
@page_title = @page.title
|
126
|
+
@description = this_blog.meta_description
|
127
|
+
@keywords = this_blog.meta_keywords
|
128
|
+
end
|
129
|
+
|
130
|
+
# TODO: Move to TextfilterController?
|
131
|
+
def markup_help
|
132
|
+
render html: TextFilter.make_filter(params[:id]).commenthelp
|
133
|
+
end
|
134
|
+
|
135
|
+
private
|
136
|
+
|
137
|
+
def set_index_title_and_description(blog, parameters)
|
138
|
+
@page_title = blog.home_title_template
|
139
|
+
@description = blog.home_desc_template
|
140
|
+
if parameters[:year]
|
141
|
+
@page_title = blog.archives_title_template
|
142
|
+
@description = blog.archives_desc_template
|
143
|
+
elsif parameters[:page]
|
144
|
+
@page_title = blog.paginated_title_template
|
145
|
+
@description = blog.paginated_desc_template
|
146
|
+
end
|
147
|
+
@page_title = @page_title.to_title(@articles, blog, parameters)
|
148
|
+
@description = @description.to_title(@articles, blog, parameters)
|
149
|
+
end
|
150
|
+
|
151
|
+
def verify_config
|
152
|
+
if !this_blog.configured?
|
153
|
+
redirect_to controller: "setup", action: "index"
|
154
|
+
elsif User.count == 0
|
155
|
+
redirect_to new_user_registration_path
|
156
|
+
else
|
157
|
+
true
|
158
|
+
end
|
159
|
+
end
|
160
|
+
|
161
|
+
private def populate_recent_articles
|
162
|
+
@recent_articles = this_blog.contents.published.limit(RECENT_ARTICLES_COUNT)
|
163
|
+
end
|
164
|
+
|
165
|
+
# See an article We need define @article before
|
166
|
+
def show_article
|
167
|
+
auto_discovery_feed
|
168
|
+
respond_to do |format|
|
169
|
+
format.html do
|
170
|
+
@comment = Comment.new
|
171
|
+
@page_title = this_blog.article_title_template.to_title(@article, this_blog, params)
|
172
|
+
@description = this_blog.article_desc_template.to_title(@article, this_blog, params)
|
173
|
+
|
174
|
+
@keywords = @article.tags.map(&:name).join(", ")
|
175
|
+
render "articles/#{@article.post_type}"
|
176
|
+
end
|
177
|
+
format.atom { render_feedback_feed("atom") }
|
178
|
+
format.rss { render_feedback_feed("rss") }
|
179
|
+
format.xml { render_feedback_feed("atom") }
|
180
|
+
end
|
181
|
+
rescue ActiveRecord::RecordNotFound
|
182
|
+
error!
|
183
|
+
end
|
184
|
+
|
185
|
+
def render_articles_feed(format)
|
186
|
+
render_cached_xml("index_#{format}_feed", @articles)
|
187
|
+
end
|
188
|
+
|
189
|
+
def render_feedback_feed(format)
|
190
|
+
render_cached_xml("feedback_#{format}_feed", @article)
|
191
|
+
end
|
192
|
+
|
193
|
+
def render_paginated_index
|
194
|
+
return error! if @articles.empty?
|
195
|
+
|
196
|
+
auto_discovery_feed(only_path: false)
|
197
|
+
render "index"
|
198
|
+
end
|
199
|
+
|
200
|
+
def extract_feed_format(from)
|
201
|
+
if /^.*\.rss$/.match?(from)
|
202
|
+
request.format = "rss"
|
203
|
+
from = from.gsub(/\.rss/, "")
|
204
|
+
elsif /^.*\.atom$/.match?(from)
|
205
|
+
request.format = "atom"
|
206
|
+
from = from.gsub(/\.atom$/, "")
|
207
|
+
end
|
208
|
+
from
|
209
|
+
end
|
210
|
+
|
211
|
+
def error!
|
212
|
+
@message = I18n.t("errors.no_posts_found")
|
213
|
+
render "articles/error", status: :ok
|
214
|
+
end
|
215
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class AuthorsController < ContentController
|
4
|
+
layout :theme_layout
|
5
|
+
|
6
|
+
def show
|
7
|
+
@author = User.find_by(login: params[:id])
|
8
|
+
raise ActiveRecord::RecordNotFound unless @author
|
9
|
+
|
10
|
+
@articles = @author.articles.published.page(params[:page]).
|
11
|
+
per(this_blog.per_page(params[:format]))
|
12
|
+
@page_title = this_blog.author_title_template.to_title(@author, this_blog, params)
|
13
|
+
@keywords = this_blog.meta_keywords
|
14
|
+
@description = this_blog.author_desc_template.to_title(@author, this_blog, params)
|
15
|
+
|
16
|
+
auto_discovery_feed(only_path: false)
|
17
|
+
|
18
|
+
respond_to do |format|
|
19
|
+
format.rss { render_feed "rss" }
|
20
|
+
format.atom { render_feed "atom" }
|
21
|
+
format.html
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
private
|
26
|
+
|
27
|
+
def render_feed(format)
|
28
|
+
render "show_#{format}_feed", layout: false
|
29
|
+
end
|
30
|
+
end
|
@@ -0,0 +1,43 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "cancancan"
|
4
|
+
|
5
|
+
class BaseController < ApplicationController
|
6
|
+
before_action :fire_triggers, :load_lang, :set_paths
|
7
|
+
|
8
|
+
private
|
9
|
+
|
10
|
+
def login_required
|
11
|
+
authenticate_user! && authorize!(params[:action], params[:controller])
|
12
|
+
end
|
13
|
+
|
14
|
+
def set_paths
|
15
|
+
prepend_view_path this_blog.current_theme.view_path
|
16
|
+
Dir.glob(File.join(::Rails.root.to_s, "lib", "*_sidebar/app/views")).select do |file|
|
17
|
+
append_view_path file
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
def fire_triggers
|
22
|
+
Trigger.fire
|
23
|
+
end
|
24
|
+
|
25
|
+
def load_lang
|
26
|
+
if I18n.available_locales.include?(this_blog.lang.to_sym)
|
27
|
+
I18n.locale = this_blog.lang
|
28
|
+
elsif I18n.available_locales.include?(this_blog.lang[0..1].to_sym)
|
29
|
+
I18n.locale = this_blog.lang[0..1]
|
30
|
+
# for the same language used in different areas, e.g. zh_CN, zh_TW
|
31
|
+
elsif I18n.available_locales.include?(this_blog.lang.sub("_", "-").to_sym)
|
32
|
+
I18n.locale = this_blog.lang.sub("_", "-")
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
def add_to_cookies(name, value, path = nil, _expires = nil)
|
37
|
+
cookies[name] = { value: value,
|
38
|
+
path: path || "/#{controller_name}",
|
39
|
+
expires: 6.weeks.from_now }
|
40
|
+
end
|
41
|
+
|
42
|
+
include BlogHelper
|
43
|
+
end
|