typo 4.0.3 → 4.1
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGES-4.1 +83 -0
- data/MAINTAINERS +3 -7
- data/README +1 -1
- data/{components/sidebars/README → README.SIDEBARS} +3 -0
- data/Rakefile +1 -1
- data/TODO-4.1 +16 -0
- data/app/apis/blogger_service.rb +3 -3
- data/app/apis/meta_weblog_service.rb +4 -21
- data/app/apis/movable_type_service.rb +5 -5
- data/app/controllers/accounts_controller.rb +6 -3
- data/app/controllers/admin/blacklist_controller.rb +1 -1
- data/app/controllers/admin/cache_controller.rb +3 -7
- data/app/controllers/admin/content_controller.rb +46 -24
- data/app/controllers/admin/feedback_controller.rb +3 -3
- data/app/controllers/admin/general_controller.rb +3 -3
- data/app/controllers/admin/pages_controller.rb +7 -3
- data/app/controllers/admin/sidebar_controller.rb +19 -26
- data/app/controllers/admin/textfilters_controller.rb +3 -1
- data/app/controllers/admin/themes_controller.rb +1 -1
- data/app/controllers/admin/users_controller.rb +1 -1
- data/app/controllers/application.rb +25 -27
- data/app/controllers/articles_controller.rb +14 -18
- data/app/controllers/content_controller.rb +7 -7
- data/app/controllers/live_controller.rb +1 -1
- data/app/controllers/redirect_controller.rb +2 -0
- data/app/controllers/textfilter_controller.rb +0 -3
- data/app/controllers/theme_controller.rb +10 -5
- data/app/controllers/xml_controller.rb +7 -9
- data/app/helpers/admin/base_helper.rb +10 -5
- data/app/helpers/admin/content_helper.rb +6 -0
- data/app/helpers/admin/feedback_helper.rb +1 -1
- data/app/helpers/admin/pages_helper.rb +5 -0
- data/app/helpers/application_helper.rb +84 -51
- data/app/helpers/articles_helper.rb +29 -29
- data/app/helpers/mail_helper.rb +3 -2
- data/app/helpers/sidebar_helper.rb +25 -16
- data/app/helpers/xml_helper.rb +0 -16
- data/app/models/article.rb +90 -32
- data/app/models/blog.rb +82 -74
- data/app/models/blog_sweeper.rb +33 -8
- data/app/models/categorization.rb +4 -0
- data/app/models/category.rb +21 -4
- data/app/models/comment.rb +23 -21
- data/app/models/content.rb +106 -64
- data/app/models/content_state/base.rb +12 -3
- data/app/models/content_state/draft.rb +2 -3
- data/app/models/content_state/factory.rb +1 -1
- data/app/models/content_state/ham.rb +0 -1
- data/app/models/content_state/just_marked_as_ham.rb +8 -1
- data/app/models/content_state/just_marked_as_spam.rb +4 -1
- data/app/models/content_state/just_presumed_ham.rb +14 -14
- data/app/models/content_state/just_published.rb +11 -18
- data/app/models/content_state/just_withdrawn.rb +11 -0
- data/app/models/content_state/new.rb +0 -1
- data/app/models/content_state/presumed_ham.rb +9 -3
- data/app/models/content_state/presumed_spam.rb +4 -1
- data/app/models/content_state/publication_pending.rb +4 -4
- data/app/models/content_state/published.rb +7 -8
- data/app/models/content_state/spam.rb +0 -1
- data/app/models/content_state/unclassified.rb +12 -3
- data/app/models/content_state/withdrawn.rb +5 -6
- data/app/models/email_notifier.rb +1 -1
- data/app/models/feedback.rb +31 -11
- data/app/models/notification.rb +4 -0
- data/app/models/notification_mailer.rb +8 -8
- data/app/models/page.rb +19 -5
- data/app/models/ping.rb +27 -40
- data/app/models/sidebar.rb +241 -11
- data/app/models/tag.rb +12 -1
- data/app/models/text_filter.rb +33 -39
- data/app/models/theme.rb +9 -0
- data/app/models/trackback.rb +1 -5
- data/app/models/user.rb +7 -5
- data/app/views/accounts/login.rhtml +19 -15
- data/app/views/accounts/logout.rhtml +4 -4
- data/app/views/accounts/signup.rhtml +9 -9
- data/app/views/admin/base/_recent_comments.rhtml +2 -2
- data/app/views/admin/base/_recent_trackbacks.rhtml +2 -2
- data/app/views/admin/blacklist/_blacklist_patterns.rhtml +4 -4
- data/app/views/admin/blacklist/_form.rhtml +3 -3
- data/app/views/admin/blacklist/_quick_post.rhtml +7 -6
- data/app/views/admin/blacklist/destroy.rhtml +5 -5
- data/app/views/admin/blacklist/edit.rhtml +7 -7
- data/app/views/admin/blacklist/list.rhtml +2 -2
- data/app/views/admin/cache/list.rhtml +2 -2
- data/app/views/admin/categories/_categories.rhtml +3 -3
- data/app/views/admin/categories/_form.rhtml +1 -1
- data/app/views/admin/categories/_quick_post.rhtml +5 -5
- data/app/views/admin/categories/destroy.rhtml +7 -7
- data/app/views/admin/categories/edit.rhtml +6 -6
- data/app/views/admin/categories/list.rhtml +7 -4
- data/app/views/admin/categories/reorder.rhtml +1 -1
- data/app/views/admin/categories/show.rhtml +6 -6
- data/app/views/admin/comments/_form.rhtml +4 -4
- data/app/views/admin/comments/comments.rhtml +1 -1
- data/app/views/admin/comments/destroy.rhtml +6 -6
- data/app/views/admin/comments/edit.rhtml +8 -8
- data/app/views/admin/comments/list.rhtml +11 -11
- data/app/views/admin/comments/new.rhtml +7 -7
- data/app/views/admin/comments/show.rhtml +7 -7
- data/app/views/admin/content/_articles.rhtml +12 -10
- data/app/views/admin/content/_attachment.rhtml +15 -17
- data/app/views/admin/content/_form.rhtml +68 -45
- data/app/views/admin/content/_pages.rhtml +2 -2
- data/app/views/admin/content/_quick_post.rhtml +6 -6
- data/app/views/admin/content/_show_categories.rhtml +2 -2
- data/app/views/admin/content/_show_resources.rhtml +2 -2
- data/app/views/admin/content/destroy.rhtml +8 -8
- data/app/views/admin/content/edit.rhtml +8 -26
- data/app/views/admin/content/list.rhtml +4 -4
- data/app/views/admin/content/new.rhtml +5 -25
- data/app/views/admin/content/preview.rhtml +9 -2
- data/app/views/admin/content/show.rhtml +10 -9
- data/app/views/admin/feedback/_item.rhtml +2 -2
- data/app/views/admin/feedback/list.rhtml +21 -20
- data/app/views/admin/general/index.rhtml +261 -239
- data/app/views/admin/general/update_database.rhtml +15 -15
- data/app/views/admin/pages/_form.rhtml +32 -15
- data/app/views/admin/pages/_pages.rhtml +9 -8
- data/app/views/admin/pages/_quick_post.rhtml +2 -2
- data/app/views/admin/pages/destroy.rhtml +7 -7
- data/app/views/admin/pages/edit.rhtml +7 -26
- data/app/views/admin/pages/list.rhtml +4 -3
- data/app/views/admin/pages/new.rhtml +5 -22
- data/app/views/admin/pages/preview.rhtml +1 -1
- data/app/views/admin/pages/show.rhtml +5 -5
- data/app/views/admin/resources/_itunes_category_edit.rhtml +2 -2
- data/app/views/admin/resources/_metadata_add.rhtml +13 -13
- data/app/views/admin/resources/_metadata_edit.rhtml +14 -14
- data/app/views/admin/resources/_mime_edit.rhtml +5 -5
- data/app/views/admin/resources/_pages.rhtml +2 -2
- data/app/views/admin/resources/_resources.rhtml +8 -8
- data/app/views/admin/resources/destroy.rhtml +7 -7
- data/app/views/admin/resources/list.rhtml +6 -3
- data/app/views/admin/resources/new.rhtml +7 -3
- data/app/views/admin/shared/_edit.rhtml +17 -0
- data/app/views/admin/sidebar/_active.rhtml +5 -5
- data/app/views/admin/sidebar/_availables.rhtml +1 -1
- data/app/views/admin/sidebar/_publish.rhtml +1 -1
- data/app/views/admin/sidebar/_target.rhtml +1 -1
- data/app/views/admin/sidebar/index.rhtml +9 -5
- data/app/views/admin/textfilters/_form.rhtml +13 -5
- data/app/views/admin/textfilters/_macros.rhtml +4 -4
- data/app/views/admin/textfilters/_textfilters.rhtml +6 -6
- data/app/views/admin/textfilters/destroy.rhtml +5 -8
- data/app/views/admin/textfilters/edit.rhtml +2 -5
- data/app/views/admin/textfilters/list.rhtml +4 -2
- data/app/views/admin/textfilters/macro_help.rhtml +1 -1
- data/app/views/admin/textfilters/new.rhtml +9 -7
- data/app/views/admin/textfilters/show.rhtml +5 -5
- data/app/views/admin/textfilters/show_help.rhtml +3 -3
- data/app/views/admin/themes/index.rhtml +8 -2
- data/app/views/admin/trackbacks/_form.rhtml +4 -4
- data/app/views/admin/trackbacks/destroy.rhtml +4 -4
- data/app/views/admin/trackbacks/edit.rhtml +6 -6
- data/app/views/admin/trackbacks/list.rhtml +10 -10
- data/app/views/admin/trackbacks/new.rhtml +6 -6
- data/app/views/admin/trackbacks/show.rhtml +8 -8
- data/app/views/admin/users/_form.rhtml +10 -10
- data/app/views/admin/users/_user.rhtml +6 -6
- data/app/views/admin/users/destroy.rhtml +7 -7
- data/app/views/admin/users/edit.rhtml +9 -5
- data/app/views/admin/users/list.rhtml +2 -2
- data/app/views/admin/users/new.rhtml +9 -7
- data/app/views/admin/users/show.rhtml +10 -10
- data/app/views/articles/_article.rhtml +3 -3
- data/app/views/articles/_comment.rhtml +3 -3
- data/app/views/articles/_comment_box.rhtml +6 -6
- data/app/views/articles/_trackback.rhtml +1 -1
- data/app/views/articles/archives.rhtml +3 -3
- data/app/views/articles/comment_preview.rhtml +2 -2
- data/app/views/articles/groupings.rhtml +1 -1
- data/app/views/articles/index.rhtml +2 -2
- data/app/views/articles/read.rhtml +15 -15
- data/app/views/articles/view_page.rhtml +1 -1
- data/app/views/layouts/administration.rhtml +11 -17
- data/app/views/layouts/minimal.rhtml +13 -0
- data/app/views/live/search.rhtml +1 -1
- data/app/views/notification_mailer/_mail_footer.rhtml +2 -2
- data/app/views/notification_mailer/article.rhtml +1 -1
- data/app/views/notification_mailer/comment.rhtml +4 -4
- data/app/views/settings/done.rhtml +1 -1
- data/app/views/settings/install.rhtml +3 -3
- data/app/views/shared/_search.rhtml +4 -4
- data/app/views/xml/_atom10_item_article.rxml +9 -7
- data/app/views/xml/_atom10_item_comment.rxml +2 -3
- data/app/views/xml/_atom10_item_trackback.rxml +1 -1
- data/app/views/xml/_googlesitemap_item_article.rxml +2 -2
- data/app/views/xml/_googlesitemap_item_category.rxml +1 -1
- data/app/views/xml/_googlesitemap_item_page.rxml +2 -2
- data/app/views/xml/_googlesitemap_item_tag.rxml +2 -2
- data/app/views/xml/_itunes_item_resource.rxml +2 -4
- data/app/views/xml/_rss20_item_article.rxml +4 -10
- data/app/views/xml/_rss20_item_comment.rxml +2 -2
- data/app/views/xml/rsd.rxml +4 -4
- data/bin/typo +0 -1
- data/config/boot.rb +4 -3
- data/config/environment.rb +37 -28
- data/config/environments/test.rb +1 -1
- data/config/routes.rb +6 -5
- data/db/migrate/051_fix_canonical_server_url.rb +17 -0
- data/db/migrate/052_remove_cached_html.rb +11 -0
- data/db/migrate/053_promote_canonical_server_url.rb +22 -0
- data/db/migrate/054_upgrade_sidebar_objects.rb +26 -0
- data/db/migrate/055_link_sidebars_to_blog.rb +17 -0
- data/db/migrate/056_create_notifications.rb +32 -0
- data/db/migrate/057_add_categorization_model.rb +45 -0
- data/db/migrate/058_separate_entries_and_feedback.rb +68 -0
- data/db/migrate/059_cleanup_feedback_table.rb +25 -0
- data/db/migrate/060_cleanup_contents_table.rb +29 -0
- data/db/migrate/061_convert_title_prefix_setting.rb +25 -0
- data/db/schema.mysql.sql +139 -108
- data/db/schema.postgresql.sql +140 -108
- data/db/schema.rb +97 -75
- data/db/schema.sqlite.sql +140 -108
- data/db/schema.sqlserver.sql +144 -109
- data/db/schema_version +1 -1
- data/lang/fr_FR.rb +469 -0
- data/lib/email_notify.rb +4 -4
- data/lib/generators/sidebar/sidebar_generator.rb +15 -6
- data/lib/generators/sidebar/templates/Rakefile +22 -0
- data/lib/generators/sidebar/templates/content.rhtml +10 -0
- data/lib/generators/sidebar/templates/init.rb +4 -0
- data/lib/generators/sidebar/templates/sidebar.rb +16 -0
- data/lib/generators/sidebar/templates/unit_test.rb +8 -0
- data/lib/jabber_notify.rb +8 -7
- data/lib/memory_profiler.rb +60 -0
- data/lib/rails_patch/active_record.rb +0 -27
- data/lib/route_cache.rb +15 -0
- data/lib/sidebars/component_plugin.rb +3 -0
- data/lib/sidebars/consolidated_plugin.rb +26 -0
- data/lib/sidebars/plugin.rb +8 -13
- data/lib/spam_protection.rb +35 -23
- data/lib/tasks/release.rake +7 -7
- data/lib/text_filter_plugin.rb +55 -15
- data/lib/typo_deprecated.rb +19 -0
- data/lib/typo_version.rb +1 -1
- data/public/images/bracket.gif +0 -0
- data/public/images/cancel.png +0 -0
- data/public/images/checked.png +0 -0
- data/public/images/delete.png +0 -0
- data/public/images/edit.png +0 -0
- data/public/images/help.png +0 -0
- data/public/images/show.png +0 -0
- data/public/javascripts/codecollapse.js +8 -0
- data/public/javascripts/controls.js +41 -23
- data/public/javascripts/dragdrop.js +105 -76
- data/public/javascripts/effects.js +293 -163
- data/public/javascripts/prototype.js +900 -391
- data/public/stylesheets/administration.css +390 -318
- data/public/stylesheets/codecollapse.css +3 -0
- data/public/stylesheets/minimal.css +142 -0
- data/public/stylesheets/textmate/dawn.css +209 -0
- data/public/stylesheets/textmate/iplastic.css +142 -0
- data/public/stylesheets/textmate/space_cadet.css +99 -0
- data/public/stylesheets/textmate/textmate.css +48 -0
- data/public/stylesheets/textmate/twilight.css +227 -0
- data/script/process/inspector +3 -0
- data/spec/controllers/accounts_controller_spec.rb +184 -0
- data/spec/controllers/articles_controller_spec.rb +47 -0
- data/spec/fixtures/articles_tags.yml +19 -0
- data/spec/fixtures/blacklist_patterns.yml +10 -0
- data/spec/fixtures/blogs.yml +77 -0
- data/spec/fixtures/categories.yml +35 -0
- data/{test/fixtures/articles_categories.yml → spec/fixtures/categorizations.yml} +0 -0
- data/spec/fixtures/contents.yml +215 -0
- data/spec/fixtures/feedback.yml +159 -0
- data/spec/fixtures/notifications.yml +0 -0
- data/spec/fixtures/page_caches.yml +7 -0
- data/spec/fixtures/redirects.yml +13 -0
- data/spec/fixtures/resources.yml +24 -0
- data/spec/fixtures/sidebars.yml +12 -0
- data/spec/fixtures/tags.yml +13 -0
- data/spec/fixtures/text_filters.yml +42 -0
- data/spec/fixtures/triggers.yml +1 -0
- data/spec/fixtures/users.yml +56 -0
- data/spec/fixtures/whiteboards.yml +13 -0
- data/spec/helpers/admin_base_helper_spec.rb +13 -0
- data/spec/models/amazon_sidebar_spec.rb +40 -0
- data/spec/models/audioscrobbler_spec.rb +134 -0
- data/spec/models/blog_spec.rb +28 -0
- data/spec/models/cache_support_spec.rb +55 -0
- data/spec/models/category_spec.rb +48 -0
- data/spec/models/configuration_spec.rb +108 -0
- data/spec/models/content_state_spec.rb +1010 -0
- data/spec/models/delegate_to_content_state_spec.rb +126 -0
- data/spec/models/delicious_spec.rb +101 -0
- data/spec/models/flickr_spec.rb +128 -0
- data/spec/models/metafragment_spec.rb +65 -0
- data/spec/models/page_cache_spec.rb +35 -0
- data/spec/models/page_spec.rb +88 -0
- data/spec/models/ping_spec.rb +133 -0
- data/spec/models/redirect_spec.rb +17 -0
- data/spec/models/resource_spec.rb +43 -0
- data/spec/models/static_sidebar_spec.rb +17 -0
- data/spec/models/tag_spec.rb +54 -0
- data/spec/models/text_filter_spec.rb +38 -0
- data/spec/models/theme_spec.rb +45 -0
- data/spec/models/trackback_spec.rb +60 -0
- data/spec/models/trigger_spec.rb +41 -0
- data/spec/models/user_spec.rb +105 -0
- data/test/fixtures/blogs.yml +5 -4
- data/test/fixtures/categorizations.yml +31 -0
- data/test/fixtures/contents.yml +2 -160
- data/test/fixtures/feedback.yml +159 -0
- data/test/fixtures/sidebars.yml +11 -4
- data/test/functional/accounts_controller_test.rb +6 -10
- data/test/functional/admin/article_preview_test.rb +21 -6
- data/test/functional/admin/blacklist_controller_test.rb +11 -11
- data/test/functional/admin/categories_controller_test.rb +13 -13
- data/test/functional/admin/comments_controller_test.rb +21 -21
- data/test/functional/admin/content_controller_test.rb +30 -38
- data/test/functional/admin/feedback_controller_test.rb +12 -12
- data/test/functional/admin/general_controller_test.rb +2 -2
- data/test/functional/admin/pages_controller_test.rb +3 -18
- data/test/functional/admin/resources_controller_test.rb +7 -7
- data/test/functional/admin/textfilters_controller_test.rb +2 -2
- data/test/functional/admin/themes_controller_test.rb +1 -1
- data/test/functional/admin/trackbacks_controller_test.rb +21 -21
- data/test/functional/admin/users_controller_test.rb +21 -18
- data/test/functional/articles_controller_test.rb +62 -46
- data/test/functional/backend_controller_test.rb +6 -6
- data/test/functional/redirect_controller_test.rb +3 -3
- data/test/functional/textfilter_controller_test.rb +10 -12
- data/test/functional/theme_controller_test.rb +1 -1
- data/test/functional/xml_controller_test.rb +7 -5
- data/test/mocks/themes/azure/layouts/default.rhtml +2 -2
- data/test/test_helper.rb +75 -0
- data/test/unit/amazon_sidebar_test.rb +36 -0
- data/test/unit/article_test.rb +36 -4
- data/test/unit/blog_test.rb +5 -36
- data/test/unit/cache_support_test.rb +62 -0
- data/test/unit/category_test.rb +6 -1
- data/test/unit/comment_test.rb +34 -9
- data/test/unit/content_state/factory_test.rb +8 -0
- data/test/unit/content_state/feedback_states_test.rb +71 -0
- data/test/unit/magnolia_test.rb +1 -1
- data/test/unit/notification_test.rb +10 -0
- data/test/unit/page_test.rb +20 -0
- data/test/unit/ping_test.rb +1 -1
- data/test/unit/sidebar_test.rb +2 -7
- data/test/unit/static_sidebar_test.rb +19 -0
- data/test/unit/tag_test.rb +6 -1
- data/test/unit/text_filter_test.rb +21 -21
- data/test/unit/theme_test.rb +1 -1
- data/test/unit/trackback_test.rb +16 -1
- data/themes/azure/layouts/default.rhtml +2 -2
- data/themes/scribbish/layouts/default.rhtml +2 -2
- data/themes/scribbish/stylesheets/content.css +6 -8
- data/themes/scribbish/views/articles/_article.rhtml +10 -10
- data/themes/scribbish/views/articles/_comment.rhtml +16 -12
- data/themes/scribbish/views/articles/_comment_form.rhtml +25 -22
- data/themes/scribbish/views/articles/_search.rhtml +14 -13
- data/themes/scribbish/views/articles/comment_preview.rhtml +3 -3
- data/themes/scribbish/views/articles/index.rhtml +1 -1
- data/themes/scribbish/views/articles/read.rhtml +8 -8
- data/vendor/cached_model/History.txt +30 -0
- data/vendor/cached_model/LICENSE.txt +30 -0
- data/vendor/cached_model/Manifest.txt +7 -0
- data/vendor/cached_model/README.txt +96 -0
- data/vendor/cached_model/Rakefile +25 -0
- data/vendor/cached_model/lib/cached_model.rb +287 -0
- data/vendor/cached_model/test/test_cached_model.rb +593 -0
- data/vendor/flickr/flickr.rb +1 -1
- data/vendor/memcache-client/History.txt +25 -0
- data/vendor/memcache-client/LICENSE.txt +30 -0
- data/vendor/memcache-client/Manifest.txt +8 -0
- data/vendor/memcache-client/README.txt +46 -0
- data/vendor/memcache-client/Rakefile +23 -0
- data/vendor/memcache-client/lib/memcache.rb +491 -0
- data/vendor/memcache-client/lib/memcache_util.rb +71 -0
- data/vendor/memcache-client/test/test_mem_cache.rb +284 -0
- data/vendor/plugins/action_view_patch/Rakefile +22 -0
- data/vendor/plugins/action_view_patch/init.rb +1 -0
- data/vendor/plugins/action_view_patch/lib/action_view_patch.rb +18 -0
- data/vendor/plugins/action_view_patch/test/action_view_patch_test.rb +56 -0
- data/vendor/plugins/aimpresence_sidebar/Rakefile +22 -0
- data/vendor/plugins/aimpresence_sidebar/init.rb +4 -0
- data/vendor/plugins/aimpresence_sidebar/lib/aimpresence_sidebar.rb +21 -0
- data/vendor/plugins/aimpresence_sidebar/test/aimpresence_sidebar_test.rb +33 -0
- data/vendor/plugins/aimpresence_sidebar/views/content.rhtml +4 -0
- data/vendor/plugins/amazon_sidebar/init.rb +5 -0
- data/vendor/plugins/amazon_sidebar/lib/amazon_sidebar.rb +16 -0
- data/vendor/plugins/amazon_sidebar/views/content.rhtml +4 -0
- data/vendor/plugins/archives_sidebar/Rakefile +22 -0
- data/vendor/plugins/archives_sidebar/init.rb +5 -0
- data/{components/plugins/sidebars/archives_controller.rb → vendor/plugins/archives_sidebar/lib/archives_sidebar.rb} +7 -6
- data/vendor/plugins/archives_sidebar/test/archives_sidebar_test.rb +8 -0
- data/{components/plugins/sidebars/archives → vendor/plugins/archives_sidebar/views}/content.rhtml +2 -2
- data/vendor/plugins/audioscrobbler_sidebar/Rakefile +22 -0
- data/vendor/plugins/audioscrobbler_sidebar/init.rb +5 -0
- data/{app/models/aggregations → vendor/plugins/audioscrobbler_sidebar/lib}/audioscrobbler.rb +0 -0
- data/{components/plugins/sidebars/audioscrobbler_controller.rb → vendor/plugins/audioscrobbler_sidebar/lib/audioscrobbler_sidebar.rb} +7 -4
- data/vendor/plugins/audioscrobbler_sidebar/test/audioscrobbler_sidebar_test.rb +8 -0
- data/{components/plugins/sidebars/audioscrobbler → vendor/plugins/audioscrobbler_sidebar/views}/content.rhtml +4 -4
- data/vendor/plugins/backpack_sidebar/Rakefile +22 -0
- data/vendor/plugins/backpack_sidebar/init.rb +5 -0
- data/{app/models/aggregations → vendor/plugins/backpack_sidebar/lib}/backpack.rb +0 -0
- data/{components/plugins/sidebars/backpack_controller.rb → vendor/plugins/backpack_sidebar/lib/backpack_sidebar.rb} +6 -3
- data/vendor/plugins/backpack_sidebar/test/backpack_sidebar_test.rb +8 -0
- data/{components/plugins/sidebars/backpack → vendor/plugins/backpack_sidebar/views}/content.rhtml +4 -4
- data/vendor/plugins/category_sidebar/Rakefile +22 -0
- data/vendor/plugins/category_sidebar/init.rb +5 -0
- data/{components/plugins/sidebars/category_controller.rb → vendor/plugins/category_sidebar/lib/category_sidebar.rb} +3 -5
- data/vendor/plugins/category_sidebar/test/category_sidebar_test.rb +8 -0
- data/vendor/plugins/category_sidebar/views/content.rhtml +10 -0
- data/vendor/plugins/delicious_sidebar/Rakefile +22 -0
- data/vendor/plugins/delicious_sidebar/init.rb +5 -0
- data/{app/models/aggregations → vendor/plugins/delicious_sidebar/lib}/delicious.rb +0 -0
- data/{components/plugins/sidebars/delicious_controller.rb → vendor/plugins/delicious_sidebar/lib/delicious_sidebar.rb} +16 -10
- data/vendor/plugins/delicious_sidebar/test/delicious_sidebar_test.rb +8 -0
- data/vendor/plugins/delicious_sidebar/views/content.rhtml +20 -0
- data/vendor/plugins/flickr_sidebar/Rakefile +22 -0
- data/vendor/plugins/flickr_sidebar/init.rb +5 -0
- data/{app/models/aggregations → vendor/plugins/flickr_sidebar/lib}/flickr.rb +1 -1
- data/vendor/plugins/flickr_sidebar/lib/flickr_sidebar.rb +15 -0
- data/vendor/plugins/flickr_sidebar/test/flickr_sidebar_test.rb +8 -0
- data/{components/plugins/sidebars/flickr → vendor/plugins/flickr_sidebar/views}/content.rhtml +5 -5
- data/vendor/plugins/fortythree_sidebar/Rakefile +22 -0
- data/vendor/plugins/fortythree_sidebar/init.rb +5 -0
- data/{app/models/aggregations → vendor/plugins/fortythree_sidebar/lib}/fortythree.rb +0 -0
- data/{components/plugins/sidebars/fortythree_controller.rb → vendor/plugins/fortythree_sidebar/lib/fortythree_sidebar.rb} +5 -4
- data/vendor/plugins/fortythree_sidebar/test/fortythree_sidebar_test.rb +8 -0
- data/vendor/plugins/fortythree_sidebar/views/content.rhtml +8 -0
- data/vendor/plugins/fortythreeplaces_sidebar/Rakefile +22 -0
- data/vendor/plugins/fortythreeplaces_sidebar/init.rb +5 -0
- data/vendor/plugins/fortythreeplaces_sidebar/lib/fortythree.rb +62 -0
- data/{components/plugins/sidebars/fortythreeplaces_controller.rb → vendor/plugins/fortythreeplaces_sidebar/lib/fortythreeplaces_sidebar.rb} +5 -4
- data/vendor/plugins/fortythreeplaces_sidebar/test/fortythreeplaces_sidebar_test.rb +8 -0
- data/vendor/plugins/fortythreeplaces_sidebar/views/content.rhtml +8 -0
- data/vendor/plugins/haml/MIT-LICENSE +20 -0
- data/vendor/plugins/haml/REFERENCE +662 -0
- data/vendor/plugins/haml/Rakefile +171 -0
- data/vendor/plugins/haml/VERSION +1 -0
- data/vendor/plugins/haml/bin/haml +18 -0
- data/vendor/plugins/haml/init.rb +3 -0
- data/vendor/plugins/haml/lib/haml/buffer.rb +224 -0
- data/vendor/plugins/haml/lib/haml/engine.rb +557 -0
- data/vendor/plugins/haml/lib/haml/helpers.rb +220 -0
- data/vendor/plugins/haml/lib/haml/helpers/action_view_mods.rb +54 -0
- data/vendor/plugins/haml/lib/haml/template.rb +138 -0
- data/vendor/plugins/haml/test/benchmark.rb +62 -0
- data/vendor/plugins/haml/test/engine_test.rb +93 -0
- data/vendor/plugins/haml/test/helper_test.rb +105 -0
- data/vendor/plugins/haml/test/mocks/article.rb +6 -0
- data/vendor/plugins/haml/test/profile.rb +45 -0
- data/vendor/plugins/haml/test/results/content_for_layout.xhtml +16 -0
- data/vendor/plugins/haml/test/results/eval_suppressed.xhtml +2 -0
- data/vendor/plugins/haml/test/results/helpers.xhtml +50 -0
- data/vendor/plugins/haml/test/results/helpful.xhtml +5 -0
- data/vendor/plugins/haml/test/results/just_stuff.xhtml +38 -0
- data/vendor/plugins/haml/test/results/list.xhtml +12 -0
- data/vendor/plugins/haml/test/results/original_engine.xhtml +24 -0
- data/vendor/plugins/haml/test/results/partials.xhtml +20 -0
- data/vendor/plugins/haml/test/results/silent_script.xhtml +74 -0
- data/vendor/plugins/haml/test/results/standard.xhtml +42 -0
- data/vendor/plugins/haml/test/results/tag_parsing.xhtml +28 -0
- data/vendor/plugins/haml/test/results/very_basic.xhtml +7 -0
- data/vendor/plugins/haml/test/results/whitespace_handling.xhtml +51 -0
- data/vendor/plugins/haml/test/rhtml/standard.rhtml +51 -0
- data/vendor/plugins/haml/test/runner.rb +15 -0
- data/vendor/plugins/haml/test/template_test.rb +137 -0
- data/vendor/plugins/haml/test/templates/_partial.haml +7 -0
- data/vendor/plugins/haml/test/templates/_text_area.haml +3 -0
- data/vendor/plugins/haml/test/templates/content_for_layout.haml +10 -0
- data/vendor/plugins/haml/test/templates/eval_suppressed.haml +5 -0
- data/vendor/plugins/haml/test/templates/helpers.haml +39 -0
- data/vendor/plugins/haml/test/templates/helpful.haml +6 -0
- data/vendor/plugins/haml/test/templates/just_stuff.haml +34 -0
- data/vendor/plugins/haml/test/templates/list.haml +12 -0
- data/vendor/plugins/haml/test/templates/original_engine.haml +17 -0
- data/vendor/plugins/haml/test/templates/partialize.haml +1 -0
- data/vendor/plugins/haml/test/templates/partials.haml +12 -0
- data/vendor/plugins/haml/test/templates/silent_script.haml +40 -0
- data/vendor/plugins/haml/test/templates/standard.haml +40 -0
- data/vendor/plugins/haml/test/templates/tag_parsing.haml +24 -0
- data/vendor/plugins/haml/test/templates/very_basic.haml +4 -0
- data/vendor/plugins/haml/test/templates/whitespace_handling.haml +66 -0
- data/vendor/plugins/localization/CHANGELOG +1 -0
- data/vendor/plugins/localization/README +85 -0
- data/vendor/plugins/localization/init.rb +3 -0
- data/vendor/plugins/localization/lib/localization.rb +46 -0
- data/vendor/plugins/magnolia_sidebar/Rakefile +22 -0
- data/vendor/plugins/magnolia_sidebar/init.rb +5 -0
- data/{app/models/aggregations/magnolia.rb → vendor/plugins/magnolia_sidebar/lib/magnolia_aggregation.rb} +0 -0
- data/vendor/plugins/magnolia_sidebar/lib/magnolia_sidebar.rb +16 -0
- data/vendor/plugins/magnolia_sidebar/test/magnolia_sidebar_test.rb +8 -0
- data/vendor/plugins/magnolia_sidebar/views/content.rhtml +12 -0
- data/vendor/plugins/recent_comments_sidebar/Rakefile +22 -0
- data/vendor/plugins/recent_comments_sidebar/init.rb +5 -0
- data/vendor/plugins/recent_comments_sidebar/lib/recent_comments_sidebar.rb +16 -0
- data/vendor/plugins/recent_comments_sidebar/test/recent_comments_sidebar_test.rb +8 -0
- data/{components/plugins/sidebars/recent_comments → vendor/plugins/recent_comments_sidebar/views}/content.rhtml +2 -2
- data/vendor/plugins/static_sidebar/init.rb +4 -0
- data/{components/plugins/sidebars/static_controller.rb → vendor/plugins/static_sidebar/lib/static_sidebar.rb} +4 -7
- data/vendor/plugins/static_sidebar/views/content.rhtml +2 -0
- data/vendor/plugins/tada_sidebar/Rakefile +22 -0
- data/vendor/plugins/tada_sidebar/init.rb +5 -0
- data/{app/models/aggregations → vendor/plugins/tada_sidebar/lib}/tada.rb +0 -0
- data/{components/plugins/sidebars/tada_controller.rb → vendor/plugins/tada_sidebar/lib/tada_sidebar.rb} +8 -4
- data/vendor/plugins/tada_sidebar/test/tada_sidebar_test.rb +8 -0
- data/{components/plugins/sidebars/tada → vendor/plugins/tada_sidebar/views}/content.rhtml +4 -4
- data/vendor/plugins/tag_sidebar/Rakefile +22 -0
- data/vendor/plugins/tag_sidebar/init.rb +5 -0
- data/vendor/plugins/tag_sidebar/lib/tag_sidebar.rb +24 -0
- data/vendor/plugins/tag_sidebar/test/tag_sidebar_test.rb +8 -0
- data/vendor/plugins/tag_sidebar/views/content.rhtml +8 -0
- data/vendor/plugins/technorati_sidebar/Rakefile +22 -0
- data/vendor/plugins/technorati_sidebar/init.rb +5 -0
- data/{app/models/aggregations → vendor/plugins/technorati_sidebar/lib}/technorati.rb +0 -0
- data/{components/plugins/sidebars/technorati_controller.rb → vendor/plugins/technorati_sidebar/lib/technorati_sidebar.rb} +8 -4
- data/vendor/plugins/technorati_sidebar/test/technorati_sidebar_test.rb +8 -0
- data/vendor/plugins/technorati_sidebar/views/content.rhtml +8 -0
- data/vendor/plugins/typo_textfilter_amazon/README +5 -0
- data/vendor/plugins/typo_textfilter_amazon/Rakefile +22 -0
- data/vendor/plugins/typo_textfilter_amazon/init.rb +4 -0
- data/vendor/plugins/typo_textfilter_amazon/install.rb +1 -0
- data/vendor/plugins/typo_textfilter_amazon/lib/typo_textfilter_amazon.rb +45 -0
- data/vendor/plugins/typo_textfilter_amazon/tasks/typo_textfilter_amazon_tasks.rake +4 -0
- data/vendor/plugins/typo_textfilter_amazon/test/typo_textfilter_amazon_test.rb +8 -0
- data/vendor/plugins/typo_textfilter_code/README +4 -0
- data/vendor/plugins/typo_textfilter_code/Rakefile +22 -0
- data/vendor/plugins/typo_textfilter_code/init.rb +4 -0
- data/vendor/plugins/typo_textfilter_code/install.rb +1 -0
- data/vendor/plugins/typo_textfilter_code/lib/typo_textfilter_code.rb +62 -0
- data/vendor/plugins/typo_textfilter_code/tasks/typo_textfilter_code_tasks.rake +4 -0
- data/vendor/plugins/typo_textfilter_code/test/typo_textfilter_code_test.rb +8 -0
- data/vendor/plugins/typo_textfilter_flickr/README +4 -0
- data/vendor/plugins/typo_textfilter_flickr/Rakefile +22 -0
- data/vendor/plugins/typo_textfilter_flickr/init.rb +4 -0
- data/vendor/plugins/typo_textfilter_flickr/install.rb +1 -0
- data/vendor/plugins/typo_textfilter_flickr/lib/typo_textfilter_flickr.rb +79 -0
- data/vendor/plugins/typo_textfilter_flickr/tasks/typo_textfilter_flickr_tasks.rake +4 -0
- data/vendor/plugins/typo_textfilter_flickr/test/typo_textfilter_flickr_test.rb +8 -0
- data/vendor/plugins/typo_textfilter_htmlfilter/README +4 -0
- data/vendor/plugins/typo_textfilter_htmlfilter/Rakefile +22 -0
- data/vendor/plugins/typo_textfilter_htmlfilter/init.rb +2 -0
- data/vendor/plugins/typo_textfilter_htmlfilter/install.rb +1 -0
- data/vendor/plugins/typo_textfilter_htmlfilter/lib/typo_textfilter_htmlfilter.rb +12 -0
- data/vendor/plugins/typo_textfilter_htmlfilter/tasks/typo_textfilter_htmlfilter_tasks.rake +4 -0
- data/vendor/plugins/typo_textfilter_htmlfilter/test/typo_textfilter_htmlfilter_test.rb +8 -0
- data/vendor/plugins/typo_textfilter_lightbox/README +4 -0
- data/vendor/plugins/typo_textfilter_lightbox/Rakefile +22 -0
- data/vendor/plugins/typo_textfilter_lightbox/init.rb +2 -0
- data/vendor/plugins/typo_textfilter_lightbox/install.rb +1 -0
- data/{components/plugins/textfilters/lightbox_controller.rb → vendor/plugins/typo_textfilter_lightbox/lib/typo_textfilter_lightbox.rb} +64 -61
- data/vendor/plugins/typo_textfilter_lightbox/tasks/typo_textfilter_lightbox_tasks.rake +4 -0
- data/vendor/plugins/typo_textfilter_lightbox/test/typo_textfilter_lightbox_test.rb +8 -0
- data/vendor/plugins/typo_textfilter_markdown/README +4 -0
- data/vendor/plugins/typo_textfilter_markdown/Rakefile +22 -0
- data/vendor/plugins/typo_textfilter_markdown/init.rb +2 -0
- data/vendor/plugins/typo_textfilter_markdown/install.rb +1 -0
- data/{components/plugins/textfilters/markdown_controller.rb → vendor/plugins/typo_textfilter_markdown/lib/typo_textfilter_markdown.rb} +13 -9
- data/vendor/plugins/typo_textfilter_markdown/tasks/typo_textfilter_markdown_tasks.rake +4 -0
- data/vendor/plugins/typo_textfilter_markdown/test/typo_textfilter_markdown_test.rb +8 -0
- data/vendor/plugins/typo_textfilter_none/README +4 -0
- data/vendor/plugins/typo_textfilter_none/Rakefile +22 -0
- data/vendor/plugins/typo_textfilter_none/init.rb +2 -0
- data/vendor/plugins/typo_textfilter_none/install.rb +1 -0
- data/vendor/plugins/typo_textfilter_none/lib/typo_textfilter_none.rb +12 -0
- data/vendor/plugins/typo_textfilter_none/tasks/typo_textfilter_none_tasks.rake +4 -0
- data/vendor/plugins/typo_textfilter_none/test/typo_textfilter_none_test.rb +8 -0
- data/vendor/plugins/typo_textfilter_smartypants/README +4 -0
- data/vendor/plugins/typo_textfilter_smartypants/Rakefile +22 -0
- data/vendor/plugins/typo_textfilter_smartypants/init.rb +2 -0
- data/vendor/plugins/typo_textfilter_smartypants/install.rb +1 -0
- data/vendor/plugins/typo_textfilter_smartypants/lib/typo_textfilter_smartypants.rb +12 -0
- data/vendor/plugins/typo_textfilter_smartypants/tasks/typo_textfilter_smartypants_tasks.rake +4 -0
- data/vendor/plugins/typo_textfilter_smartypants/test/typo_textfilter_smartypants_test.rb +8 -0
- data/vendor/plugins/typo_textfilter_sparkline/README +4 -0
- data/vendor/plugins/typo_textfilter_sparkline/Rakefile +22 -0
- data/vendor/plugins/typo_textfilter_sparkline/init.rb +2 -0
- data/vendor/plugins/typo_textfilter_sparkline/install.rb +1 -0
- data/vendor/plugins/typo_textfilter_sparkline/lib/typo_textfilter_sparkline.rb +92 -0
- data/vendor/plugins/typo_textfilter_sparkline/tasks/typo_textfilter_sparkline_tasks.rake +4 -0
- data/vendor/plugins/typo_textfilter_sparkline/test/typo_textfilter_sparkline_test.rb +8 -0
- data/vendor/plugins/typo_textfilter_textile/README +4 -0
- data/vendor/plugins/typo_textfilter_textile/Rakefile +22 -0
- data/vendor/plugins/typo_textfilter_textile/init.rb +2 -0
- data/vendor/plugins/typo_textfilter_textile/install.rb +1 -0
- data/vendor/plugins/typo_textfilter_textile/lib/typo_textfilter_textile.rb +18 -0
- data/vendor/plugins/typo_textfilter_textile/tasks/typo_textfilter_textile_tasks.rake +4 -0
- data/vendor/plugins/typo_textfilter_textile/test/typo_textfilter_textile_test.rb +8 -0
- data/vendor/plugins/typo_textfilter_textile_and_markdown/README +4 -0
- data/vendor/plugins/typo_textfilter_textile_and_markdown/Rakefile +22 -0
- data/vendor/plugins/typo_textfilter_textile_and_markdown/init.rb +2 -0
- data/vendor/plugins/typo_textfilter_textile_and_markdown/install.rb +1 -0
- data/vendor/plugins/typo_textfilter_textile_and_markdown/lib/typo_textfilter_textile_and_markdown.rb +12 -0
- data/vendor/plugins/typo_textfilter_textile_and_markdown/tasks/typo_textfilter_textile_and_markdown_tasks.rake +4 -0
- data/vendor/plugins/typo_textfilter_textile_and_markdown/test/typo_textfilter_textile_and_markdown_test.rb +8 -0
- data/vendor/plugins/typo_textfilter_tmcode/README +4 -0
- data/vendor/plugins/typo_textfilter_tmcode/Rakefile +22 -0
- data/vendor/plugins/typo_textfilter_tmcode/init.rb +3 -0
- data/vendor/plugins/typo_textfilter_tmcode/install.rb +1 -0
- data/vendor/plugins/typo_textfilter_tmcode/lib/typo_textfilter_tmcode.rb +86 -0
- data/vendor/plugins/typo_textfilter_tmcode/tasks/typo_textfilter_tmcode_tasks.rake +4 -0
- data/vendor/plugins/typo_textfilter_tmcode/test/typo_textfilter_tmcode_test.rb +8 -0
- data/vendor/plugins/upcoming_sidebar/Rakefile +22 -0
- data/vendor/plugins/upcoming_sidebar/init.rb +5 -0
- data/{app/models/aggregations → vendor/plugins/upcoming_sidebar/lib}/upcoming.rb +0 -0
- data/vendor/plugins/upcoming_sidebar/lib/upcoming_sidebar.rb +15 -0
- data/vendor/plugins/upcoming_sidebar/test/upcoming_sidebar_test.rb +8 -0
- data/{components/plugins/sidebars/upcoming → vendor/plugins/upcoming_sidebar/views}/content.rhtml +3 -3
- data/vendor/plugins/xbox_sidebar/Rakefile +22 -0
- data/vendor/plugins/xbox_sidebar/init.rb +5 -0
- data/{components/plugins/sidebars/xbox_controller.rb → vendor/plugins/xbox_sidebar/lib/xbox_sidebar.rb} +1 -1
- data/vendor/plugins/xbox_sidebar/test/xbox_sidebar_test.rb +8 -0
- data/vendor/plugins/xbox_sidebar/views/content.rhtml +2 -0
- data/vendor/plugins/xml_sidebar/Rakefile +22 -0
- data/vendor/plugins/xml_sidebar/init.rb +5 -0
- data/{components/plugins/sidebars/xml_controller.rb → vendor/plugins/xml_sidebar/lib/xml_sidebar.rb} +1 -1
- data/vendor/plugins/xml_sidebar/test/xml_sidebar_test.rb +8 -0
- data/vendor/plugins/xml_sidebar/views/content.rhtml +12 -0
- metadata +505 -101
- data/app/controllers/sidebar_controller.rb +0 -50
- data/app/models/content_observer.rb +0 -5
- data/components/plugins/sidebars/aimpresence/content.rhtml +0 -4
- data/components/plugins/sidebars/aimpresence_controller.rb +0 -10
- data/components/plugins/sidebars/amazon/content.rhtml +0 -4
- data/components/plugins/sidebars/amazon_controller.rb +0 -17
- data/components/plugins/sidebars/category/content.rhtml +0 -10
- data/components/plugins/sidebars/delicious/content.rhtml +0 -20
- data/components/plugins/sidebars/flickr_controller.rb +0 -16
- data/components/plugins/sidebars/fortythree/content.rhtml +0 -8
- data/components/plugins/sidebars/fortythreeplaces/content.rhtml +0 -8
- data/components/plugins/sidebars/magnolia/content.rhtml +0 -12
- data/components/plugins/sidebars/magnolia_controller.rb +0 -17
- data/components/plugins/sidebars/recent_comments_controller.rb +0 -23
- data/components/plugins/sidebars/static/content.rhtml +0 -2
- data/components/plugins/sidebars/tag/content.rhtml +0 -8
- data/components/plugins/sidebars/tag_controller.rb +0 -18
- data/components/plugins/sidebars/technorati/content.rhtml +0 -8
- data/components/plugins/sidebars/upcoming_controller.rb +0 -11
- data/components/plugins/sidebars/xbox/content.rhtml +0 -2
- data/components/plugins/sidebars/xml/content.rhtml +0 -12
- data/components/plugins/textfilters/amazon_controller.rb +0 -39
- data/components/plugins/textfilters/code_controller.rb +0 -59
- data/components/plugins/textfilters/flickr_controller.rb +0 -75
- data/components/plugins/textfilters/htmlfilter_controller.rb +0 -8
- data/components/plugins/textfilters/macropost_controller.rb +0 -14
- data/components/plugins/textfilters/macropre_controller.rb +0 -14
- data/components/plugins/textfilters/none_controller.rb +0 -8
- data/components/plugins/textfilters/smartypants_controller.rb +0 -8
- data/components/plugins/textfilters/sparkline_controller.rb +0 -88
- data/components/plugins/textfilters/textile_and_markdown_controller.rb +0 -8
- data/components/plugins/textfilters/textile_controller.rb +0 -14
- data/db/schema.mysql-v3.sql +0 -218
- data/lib/generators/sidebar/templates/components/plugins/sidebars/controller_template.rb +0 -20
- data/lib/generators/sidebar/templates/components/plugins/sidebars/views/content_template.rhtml +0 -4
- data/lib/rails_patch/components.rb +0 -14
- data/public/images/checked.gif +0 -0
- data/test/unit/observer_test.rb +0 -40
data/app/models/article.rb
CHANGED
@@ -6,12 +6,17 @@ class Article < Content
|
|
6
6
|
|
7
7
|
content_fields :body, :extended
|
8
8
|
|
9
|
-
has_many :pings,
|
10
|
-
has_many :comments,
|
11
|
-
has_many :trackbacks, :dependent =>
|
9
|
+
has_many :pings, :dependent => :destroy, :order => "created_at ASC"
|
10
|
+
has_many :comments, :dependent => :destroy, :order => "created_at ASC"
|
11
|
+
has_many :trackbacks, :dependent => :destroy, :order => "created_at ASC"
|
12
12
|
has_many :resources, :order => "created_at DESC",
|
13
13
|
:class_name => "Resource", :foreign_key => 'article_id'
|
14
|
-
|
14
|
+
has_many :categorizations
|
15
|
+
has_many :categories, :through => :categorizations, :uniq => true do
|
16
|
+
def push_with_attributes(cat, join_attrs = { :is_primary => false })
|
17
|
+
Categorization.with_scope(:create => join_attrs) { self << cat }
|
18
|
+
end
|
19
|
+
end
|
15
20
|
has_and_belongs_to_many :tags, :foreign_key => 'article_id'
|
16
21
|
belongs_to :user
|
17
22
|
has_many :triggers, :as => :pending_item
|
@@ -22,27 +27,50 @@ class Article < Content
|
|
22
27
|
self.title.gsub(/<[^>]*>/,'').to_url
|
23
28
|
end
|
24
29
|
|
25
|
-
def
|
26
|
-
|
30
|
+
def permalink_url(anchor=nil, only_path=true)
|
31
|
+
@cached_permalink_url ||= {}
|
32
|
+
@cached_permalink_url["#{anchor}#{only_path}"] ||= blog.url_for(
|
33
|
+
:year => published_at.year,
|
34
|
+
:month => sprintf("%.2d", published_at.month),
|
35
|
+
:day => sprintf("%.2d", published_at.day),
|
36
|
+
:title => permalink,
|
37
|
+
:anchor => anchor,
|
38
|
+
:only_path => only_path,
|
39
|
+
:controller => '/articles'
|
40
|
+
)
|
41
|
+
end
|
42
|
+
|
43
|
+
def trackback_url
|
44
|
+
blog.url_for(:controller => "articles", :action =>"trackback", :id => id)
|
45
|
+
end
|
46
|
+
|
47
|
+
def feed_url(format = :rss20)
|
48
|
+
blog.url_for(:controller => 'xml', :action => 'feed', :type => 'article', :format => format, :id => id)
|
49
|
+
end
|
50
|
+
|
51
|
+
def edit_url
|
52
|
+
blog.url_for(:controller => "/admin/content", :action =>"edit", :id => id)
|
53
|
+
end
|
54
|
+
|
55
|
+
def delete_url
|
56
|
+
blog.url_for(:controller => "/admin/content", :action =>"destroy", :id => id)
|
27
57
|
end
|
28
58
|
|
29
59
|
def html_urls
|
30
60
|
urls = Array.new
|
31
|
-
|
61
|
+
html.gsub(/<a [^>]*>/) do |tag|
|
32
62
|
if(tag =~ /href="([^"]+)"/)
|
33
63
|
urls.push($1)
|
34
64
|
end
|
35
65
|
end
|
36
66
|
|
37
|
-
urls
|
67
|
+
urls.uniq
|
38
68
|
end
|
39
69
|
|
40
|
-
def really_send_pings(serverurl = blog.
|
70
|
+
def really_send_pings(serverurl = blog.base_url, articleurl = nil)
|
41
71
|
return unless blog.send_outbound_pings
|
42
72
|
|
43
|
-
|
44
|
-
# avoid unnecessary evaluations of the #location() method.
|
45
|
-
articleurl ||= location(nil, false)
|
73
|
+
articleurl ||= permalink_url(nil, false)
|
46
74
|
|
47
75
|
weblogupdatesping_urls = blog.ping_urls.gsub(/ +/,'').split(/[\n\r]+/)
|
48
76
|
pingback_or_trackback_urls = self.html_urls
|
@@ -73,13 +101,13 @@ class Article < Content
|
|
73
101
|
end
|
74
102
|
|
75
103
|
def next
|
76
|
-
|
77
|
-
|
104
|
+
blog.articles.find(:first, :conditions => ['published_at > ?', published_at],
|
105
|
+
:order => 'published_at asc')
|
78
106
|
end
|
79
107
|
|
80
108
|
def previous
|
81
|
-
|
82
|
-
|
109
|
+
blog.articles.find(:first, :conditions => ['published_at < ?', published_at],
|
110
|
+
:order => 'published_at desc')
|
83
111
|
end
|
84
112
|
|
85
113
|
# Count articles on a certain date
|
@@ -137,17 +165,17 @@ class Article < Content
|
|
137
165
|
User.find_boolean(:all, :notify_on_new_articles)
|
138
166
|
end
|
139
167
|
|
140
|
-
def notify_user_via_email(
|
168
|
+
def notify_user_via_email(user)
|
141
169
|
if user.notify_via_email?
|
142
|
-
EmailNotify.send_article(
|
170
|
+
EmailNotify.send_article(self, user)
|
143
171
|
end
|
144
172
|
end
|
145
173
|
|
146
|
-
def notify_user_via_jabber(
|
174
|
+
def notify_user_via_jabber(user)
|
147
175
|
if user.notify_via_jabber?
|
148
176
|
JabberNotify.send_message(user, "New post",
|
149
177
|
"A new message was posted to #{blog.blog_name}",
|
150
|
-
|
178
|
+
html(:body))
|
151
179
|
end
|
152
180
|
end
|
153
181
|
|
@@ -171,11 +199,52 @@ class Article < Content
|
|
171
199
|
trackbacks.select {|c| c.published?}
|
172
200
|
end
|
173
201
|
|
202
|
+
# Bloody rails reloading. Nasty workaround.
|
203
|
+
def body=(newval)
|
204
|
+
if self[:body] != newval
|
205
|
+
changed
|
206
|
+
self[:body] = newval
|
207
|
+
end
|
208
|
+
self[:body]
|
209
|
+
end
|
210
|
+
|
211
|
+
def body_html
|
212
|
+
typo_deprecated "Use html(:body)"
|
213
|
+
html(:body)
|
214
|
+
end
|
215
|
+
|
216
|
+
def extended=(newval)
|
217
|
+
if self[:extended] != newval
|
218
|
+
changed
|
219
|
+
self[:extended] = newval
|
220
|
+
end
|
221
|
+
self[:extended]
|
222
|
+
end
|
223
|
+
|
224
|
+
def extended_html
|
225
|
+
typo_deprecated "Use html(:extended)"
|
226
|
+
html(:extended)
|
227
|
+
end
|
228
|
+
|
229
|
+
def self.html_map(field=nil)
|
230
|
+
html_map = { :body => true, :extended => true }
|
231
|
+
if field
|
232
|
+
html_map[field.to_sym]
|
233
|
+
else
|
234
|
+
html_map
|
235
|
+
end
|
236
|
+
end
|
237
|
+
|
238
|
+
def content_fields
|
239
|
+
[:body, :extended]
|
240
|
+
end
|
241
|
+
|
174
242
|
protected
|
175
243
|
|
176
|
-
before_create :set_defaults, :create_guid
|
244
|
+
before_create :set_defaults, :create_guid
|
177
245
|
before_save :set_published_at
|
178
246
|
after_save :keywords_to_tags
|
247
|
+
after_create :add_notifications
|
179
248
|
|
180
249
|
def set_published_at
|
181
250
|
if self.published and self[:published_at].nil?
|
@@ -199,20 +268,11 @@ class Article < Content
|
|
199
268
|
end
|
200
269
|
|
201
270
|
def add_notifications
|
202
|
-
# Grr, how do I do :conditions => 'notify_on_new_articles = true' when on MySQL boolean DB tables
|
203
|
-
# are integers, Postgres booleans are booleans, and sqlite is basically just a string?
|
204
|
-
#
|
205
|
-
# I'm punting for now and doing the test in Ruby. Feel free to rewrite.
|
206
|
-
|
207
271
|
self.notify_users = User.find_boolean(:all, :notify_on_new_articles)
|
208
272
|
self.notify_users << self.user if (self.user.notify_watch_my_articles? rescue false)
|
209
273
|
self.notify_users.uniq!
|
210
274
|
end
|
211
275
|
|
212
|
-
def default_text_filter_config_key
|
213
|
-
'text_filter'
|
214
|
-
end
|
215
|
-
|
216
276
|
def self.time_delta(year, month = nil, day = nil)
|
217
277
|
from = Time.mktime(year, month || 1, day || 1)
|
218
278
|
|
@@ -224,8 +284,6 @@ class Article < Content
|
|
224
284
|
end
|
225
285
|
|
226
286
|
def find_published(what = :all, options = {})
|
227
|
-
options[:include] ||= []
|
228
|
-
options[:include] += [:user]
|
229
287
|
super(what, options)
|
230
288
|
end
|
231
289
|
|
data/app/models/blog.rb
CHANGED
@@ -1,7 +1,5 @@
|
|
1
1
|
# BlogRequest is a fake Request object, created so blog.url_for will work.
|
2
|
-
# This isn't enabled yet, but it will be soon...
|
3
2
|
class BlogRequest
|
4
|
-
include Reloadable
|
5
3
|
|
6
4
|
attr_accessor :protocol, :host_with_port, :path, :symbolized_path_parameters, :relative_url_root
|
7
5
|
|
@@ -12,7 +10,12 @@ class BlogRequest
|
|
12
10
|
end
|
13
11
|
end
|
14
12
|
|
15
|
-
|
13
|
+
# The Blog class represents one blog. It stores most configuration settings
|
14
|
+
# and is linked to most of the assorted content classes via has_many.
|
15
|
+
#
|
16
|
+
# Typo decides which Blog object to use by searching for a Blog base_url that
|
17
|
+
# matches the base_url computed for each request.
|
18
|
+
class Blog < CachedModel
|
16
19
|
include ConfigManager
|
17
20
|
|
18
21
|
has_many :contents
|
@@ -21,9 +24,9 @@ class Blog < ActiveRecord::Base
|
|
21
24
|
has_many :comments
|
22
25
|
has_many :pages, :order => "id DESC"
|
23
26
|
has_many(:published_articles, :class_name => "Article",
|
24
|
-
:conditions =>
|
27
|
+
:conditions => {:published => true},
|
25
28
|
:include => [:categories, :tags],
|
26
|
-
:order => "contents.
|
29
|
+
:order => "contents.published_at DESC") do
|
27
30
|
def before(date = Time.now)
|
28
31
|
find(:all, :conditions => ["contents.created_at < ?", date])
|
29
32
|
end
|
@@ -31,15 +34,16 @@ class Blog < ActiveRecord::Base
|
|
31
34
|
|
32
35
|
has_many :pages
|
33
36
|
has_many :comments
|
37
|
+
has_many :sidebars, :order => 'active_position ASC'
|
34
38
|
|
35
39
|
serialize :settings, Hash
|
36
40
|
|
37
41
|
# Description
|
38
42
|
setting :blog_name, :string, 'My Shiny Weblog!'
|
39
43
|
setting :blog_subtitle, :string, ''
|
40
|
-
setting :title_prefix, :
|
44
|
+
setting :title_prefix, :integer, 0
|
41
45
|
setting :geourl_location, :string, ''
|
42
|
-
setting :canonical_server_url, :string, ''
|
46
|
+
setting :canonical_server_url, :string, '' # Deprecated
|
43
47
|
|
44
48
|
# Spam
|
45
49
|
setting :sp_global, :boolean, false
|
@@ -65,6 +69,7 @@ class Blog < ActiveRecord::Base
|
|
65
69
|
setting :limit_rss_display, :integer, 10
|
66
70
|
setting :default_allow_pings, :boolean, false
|
67
71
|
setting :default_allow_comments, :boolean, true
|
72
|
+
setting :default_moderate_comments, :boolean, false
|
68
73
|
setting :link_to_author, :boolean, false
|
69
74
|
setting :show_extended_on_rss, :boolean, true
|
70
75
|
setting :theme, :string, 'azure'
|
@@ -78,8 +83,26 @@ class Blog < ActiveRecord::Base
|
|
78
83
|
setting :jabber_address, :string, ''
|
79
84
|
setting :jabber_password, :string, ''
|
80
85
|
|
81
|
-
def
|
82
|
-
|
86
|
+
def initialize(*args)
|
87
|
+
super
|
88
|
+
# Yes, this is weird - PDC
|
89
|
+
begin
|
90
|
+
self.settings ||= {}
|
91
|
+
rescue Exception => e
|
92
|
+
self.settings = {}
|
93
|
+
end
|
94
|
+
end
|
95
|
+
|
96
|
+
# Find the Blog that matches a specific base URL. If no Blog object is found
|
97
|
+
# that matches, then grab the default blog. If *that* fails, then create a new
|
98
|
+
# Blog. The last case should only be used when Typo is first installed.
|
99
|
+
def self.find_blog(base_url)
|
100
|
+
(Blog.find_by_base_url(base_url) rescue nil)|| Blog.default || Blog.new
|
101
|
+
end
|
102
|
+
|
103
|
+
# The default Blog. This is the lowest-numbered blog, almost always id==1.
|
104
|
+
def self.default
|
105
|
+
find(:first, :order => 'id')
|
83
106
|
end
|
84
107
|
|
85
108
|
def ping_article!(settings)
|
@@ -89,93 +112,78 @@ class Blog < ActiveRecord::Base
|
|
89
112
|
trackback = published_articles.find(article_id).trackbacks.create!(settings)
|
90
113
|
end
|
91
114
|
|
92
|
-
|
115
|
+
# Check that all required blog settings have a value.
|
93
116
|
def is_ok?
|
94
117
|
settings.has_key?('blog_name')
|
95
118
|
end
|
96
119
|
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
def []=(key, value)
|
102
|
-
self.send("#{key}=", value)
|
103
|
-
end
|
104
|
-
|
105
|
-
def has_key?(key)
|
106
|
-
self.class.fields.has_key?(key.to_s)
|
107
|
-
end
|
108
|
-
|
109
|
-
def initialize(*args)
|
110
|
-
super
|
111
|
-
self.settings ||= { }
|
112
|
-
end
|
113
|
-
|
114
|
-
def self.default
|
115
|
-
find(:first, :order => 'id')
|
116
|
-
end
|
117
|
-
|
118
|
-
@@controller_stack = []
|
119
|
-
cattr_accessor :controller_stack
|
120
|
-
|
121
|
-
def self.before(controller)
|
122
|
-
controller_stack << controller
|
120
|
+
# The +Theme+ object for the current theme.
|
121
|
+
def current_theme
|
122
|
+
@cached_theme ||= Theme.find(theme)
|
123
123
|
end
|
124
124
|
|
125
|
-
|
126
|
-
|
127
|
-
|
125
|
+
# Generate a URL based on the +base_url+. This allows us to generate URLs
|
126
|
+
# without needing a controller handy, so we can produce URLs from within models
|
127
|
+
# where appropriate.
|
128
|
+
#
|
129
|
+
# It also uses our new RouteCache, so repeated URL generation requests should be
|
130
|
+
# fast, as they bypass all of Rails' route logic.
|
131
|
+
def url_for(options = {}, *extra_params)
|
132
|
+
case options
|
133
|
+
when String then options # They asked for 'url_for "/some/path"', so return it unedited.
|
134
|
+
when Hash
|
135
|
+
unless RouteCache[options]
|
136
|
+
options.reverse_merge!(:only_path => true, :controller => '/articles',
|
137
|
+
:action => 'permalink')
|
138
|
+
@url ||= ActionController::UrlRewriter.new(BlogRequest.new(self.base_url), {})
|
139
|
+
RouteCache[options] = @url.rewrite(options)
|
140
|
+
end
|
141
|
+
|
142
|
+
return RouteCache[options]
|
143
|
+
else
|
144
|
+
raise "Invalid URL in url_for: #{options.inspect}"
|
128
145
|
end
|
129
|
-
controller_stack.pop
|
130
146
|
end
|
131
147
|
|
132
|
-
|
133
|
-
|
148
|
+
# The URL for a static file.
|
149
|
+
def file_url(filename)
|
150
|
+
"#{base_url}/files/#{filename}"
|
134
151
|
end
|
135
152
|
|
136
|
-
|
137
|
-
|
153
|
+
# The base server URL.
|
154
|
+
def server_url
|
155
|
+
base_url
|
138
156
|
end
|
139
157
|
|
140
|
-
|
141
|
-
|
158
|
+
# Deprecated
|
159
|
+
def canonical_server_url
|
160
|
+
typo_deprecated "Use base_url instead"
|
161
|
+
base_url
|
142
162
|
end
|
143
163
|
|
144
|
-
def
|
145
|
-
|
146
|
-
|
147
|
-
when Hash
|
148
|
-
options.reverse_merge!(:only_path => true, :controller => '/articles',
|
149
|
-
:action => 'permalink')
|
150
|
-
url = ActionController::UrlRewriter.new(request, {})
|
151
|
-
url.rewrite(options)
|
152
|
-
else
|
153
|
-
options.location(*extra_params)
|
154
|
-
end
|
164
|
+
def [](key) # :nodoc:
|
165
|
+
typo_deprecated "Use blog.#{key}"
|
166
|
+
self.send(key)
|
155
167
|
end
|
156
168
|
|
157
|
-
def
|
158
|
-
|
159
|
-
|
160
|
-
:day => sprintf("%.2d", article.published_at.day),
|
161
|
-
:title => article.permalink, :anchor => anchor,
|
162
|
-
:only_path => only_path,
|
163
|
-
:controller => '/articles')
|
169
|
+
def []=(key, value) # :nodoc:
|
170
|
+
typo_deprecated "Use blog.#{key}="
|
171
|
+
self.send("#{key}=", value)
|
164
172
|
end
|
165
173
|
|
166
|
-
def
|
167
|
-
|
168
|
-
|
169
|
-
else
|
170
|
-
settings[:canonical_server_url]
|
171
|
-
end
|
174
|
+
def has_key?(key) # :nodoc:
|
175
|
+
typo_deprecated "Why?"
|
176
|
+
self.class.fields.has_key?(key.to_s)
|
172
177
|
end
|
173
178
|
|
174
|
-
|
179
|
+
def find_already_published(content_type) # :nodoc:
|
180
|
+
typo_deprecated "Use #{content_type}.find_already_published"
|
181
|
+
self.send(content_type).find_already_published
|
182
|
+
end
|
175
183
|
|
176
|
-
def
|
177
|
-
|
178
|
-
|
184
|
+
def current_theme_path # :nodoc:
|
185
|
+
typo_deprecated "use current_theme.path"
|
186
|
+
Theme.themes_root + "/" + theme
|
179
187
|
end
|
180
188
|
end
|
181
189
|
|
data/app/models/blog_sweeper.rb
CHANGED
@@ -1,23 +1,48 @@
|
|
1
1
|
class BlogSweeper < ActionController::Caching::Sweeper
|
2
|
-
observe Article, Category,
|
2
|
+
observe Article, Category, Feedback, Page, Blog, Sidebar, User
|
3
3
|
|
4
4
|
def after_save(record)
|
5
|
+
logger.info "Expiring #{record}, with controller: #{controller}"
|
5
6
|
expire_for(record)
|
6
7
|
end
|
7
8
|
|
8
9
|
def after_destroy(record)
|
9
|
-
expire_for(record)
|
10
|
+
expire_for(record, true)
|
10
11
|
end
|
11
12
|
|
12
|
-
def expire_for(record)
|
13
|
+
def expire_for(record, destroying = false)
|
13
14
|
case record
|
14
|
-
when Blog, Sidebar, Category, Comment, Trackback, Article, User
|
15
|
-
PageCache.sweep_all
|
16
|
-
expire_fragment(/.*/)
|
17
15
|
when Page
|
18
|
-
|
16
|
+
sweep_pages(record)
|
17
|
+
when Content
|
18
|
+
if record.invalidates_cache?(destroying)
|
19
|
+
sweep_all
|
20
|
+
end
|
21
|
+
when Sidebar, Category
|
22
|
+
sweep_articles
|
23
|
+
sweep_pages(record)
|
24
|
+
when Blog, User
|
25
|
+
sweep_all
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
29
|
+
def sweep_all
|
30
|
+
PageCache.sweep_all
|
31
|
+
expire_fragment(/.*/)
|
32
|
+
end
|
33
|
+
|
34
|
+
def sweep_articles
|
35
|
+
PageCache.sweep('/articles/%')
|
36
|
+
expire_fragment(%r{.*/articles/.*})
|
37
|
+
end
|
38
|
+
|
39
|
+
def sweep_pages(record)
|
40
|
+
PageCache.sweep("/pages/#{record.name rescue ''}.html")
|
19
41
|
expire_fragment(/.*\/pages\/.*/)
|
20
42
|
expire_fragment(/.*\/view_page.*/)
|
21
|
-
|
43
|
+
end
|
44
|
+
|
45
|
+
def logger
|
46
|
+
@logger ||= RAILS_DEFAULT_LOGGER || Logger.new(STDERR)
|
22
47
|
end
|
23
48
|
end
|