community_engine 2.0.0.beta1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/.gitignore +15 -0
- data/.gitmodules +0 -0
- data/.travis.yml +9 -0
- data/CHANGELOG +118 -0
- data/Gemfile +3 -0
- data/LICENSE +30 -0
- data/README.markdown +188 -0
- data/Rakefile +54 -0
- data/UPGRADING.markdown +93 -0
- data/about.yml +7 -0
- data/app/assets/images/auth/facebook_32.png +0 -0
- data/app/assets/images/auth/facebook_64.png +0 -0
- data/app/assets/images/auth/google_32.png +0 -0
- data/app/assets/images/auth/google_64.png +0 -0
- data/app/assets/images/auth/linked_in_32.png +0 -0
- data/app/assets/images/auth/linked_in_64.png +0 -0
- data/app/assets/images/auth/open_id_32.png +0 -0
- data/app/assets/images/auth/remove.png +0 -0
- data/app/assets/images/auth/twitter_32.png +0 -0
- data/app/assets/images/auth/twitter_64.png +0 -0
- data/app/assets/images/bg_h6btn.gif +0 -0
- data/app/assets/images/bg_navbar.gif +0 -0
- data/app/assets/images/clearbits/bg_rounded.gif +0 -0
- data/app/assets/images/clearbits/comment.gif +0 -0
- data/app/assets/images/clearbits/lock.gif +0 -0
- data/app/assets/images/clearbits/smile.gif +0 -0
- data/app/assets/images/close.gif +0 -0
- data/app/assets/images/cropper/marqueeHoriz.gif +0 -0
- data/app/assets/images/cropper/marqueeVert.gif +0 -0
- data/app/assets/images/feed.png +0 -0
- data/app/assets/images/icon_missing_medium.gif +0 -0
- data/app/assets/images/icon_missing_thumb.gif +0 -0
- data/app/assets/images/icons/31.png +0 -0
- data/app/assets/images/icons/52.png +0 -0
- data/app/assets/images/icons/accept.png +0 -0
- data/app/assets/images/icons/activity_default.png +0 -0
- data/app/assets/images/icons/add.png +0 -0
- data/app/assets/images/icons/book.png +0 -0
- data/app/assets/images/icons/bullet_arrow_down.png +0 -0
- data/app/assets/images/icons/bullet_arrow_down_50.png +0 -0
- data/app/assets/images/icons/clipping.png +0 -0
- data/app/assets/images/icons/comment.png +0 -0
- data/app/assets/images/icons/comments.png +0 -0
- data/app/assets/images/icons/date.png +0 -0
- data/app/assets/images/icons/delete.png +0 -0
- data/app/assets/images/icons/email.png +0 -0
- data/app/assets/images/icons/email_edit.png +0 -0
- data/app/assets/images/icons/email_go.png +0 -0
- data/app/assets/images/icons/email_open.png +0 -0
- data/app/assets/images/icons/group_go.png +0 -0
- data/app/assets/images/icons/heart.png +0 -0
- data/app/assets/images/icons/heart_add.png +0 -0
- data/app/assets/images/icons/heart_off.png +0 -0
- data/app/assets/images/icons/ical.gif +0 -0
- data/app/assets/images/icons/page_white.png +0 -0
- data/app/assets/images/icons/page_white_magnify.png +0 -0
- data/app/assets/images/icons/picture.png +0 -0
- data/app/assets/images/icons/poll.png +0 -0
- data/app/assets/images/icons/post.png +0 -0
- data/app/assets/images/icons/printer.png +0 -0
- data/app/assets/images/icons/rss.png +0 -0
- data/app/assets/images/icons/slides.png +0 -0
- data/app/assets/images/icons/tag_blue.png +0 -0
- data/app/assets/images/icons/user.png +0 -0
- data/app/assets/images/icons/user_add.png +0 -0
- data/app/assets/images/icons/user_edit.png +0 -0
- data/app/assets/images/icons/user_go.png +0 -0
- data/app/assets/images/icons/vote.png +0 -0
- data/app/assets/images/icons/world.png +0 -0
- data/app/assets/images/icons/wrench.png +0 -0
- data/app/assets/images/logo.gif +0 -0
- data/app/assets/images/reply_background.png +0 -0
- data/app/assets/images/search.gif +0 -0
- data/app/assets/images/spinner.gif +0 -0
- data/app/assets/images/spinner_black.gif +0 -0
- data/app/assets/images/spinner_bounce.gif +0 -0
- data/app/assets/images/swf/choose.png +0 -0
- data/app/assets/images/swf/line_grapher.swf +0 -0
- data/app/assets/images/swf/swfupload.swf +0 -0
- data/app/assets/images/thumb.gif +0 -0
- data/app/assets/javascripts/builder.js +136 -0
- data/app/assets/javascripts/calendarview.js +839 -0
- data/app/assets/javascripts/community_engine.js +20 -0
- data/app/assets/javascripts/cropper.css +182 -0
- data/app/assets/javascripts/cropper.js +566 -0
- data/app/assets/javascripts/forum.js +73 -0
- data/app/assets/javascripts/lightbox.js +151 -0
- data/app/assets/javascripts/prototip-min.js +27 -0
- data/app/assets/javascripts/rails.js +202 -0
- data/app/assets/javascripts/tinymce/plugins/curblyadvimage/css/advimage.css +84 -0
- data/app/assets/javascripts/tinymce/plugins/curblyadvimage/editor_plugin.js +52 -0
- data/app/assets/javascripts/tinymce/plugins/curblyadvimage/editor_plugin_src.js +45 -0
- data/app/assets/javascripts/tinymce/plugins/curblyadvimage/image.htm +180 -0
- data/app/assets/javascripts/tinymce/plugins/curblyadvimage/img/sample.gif +0 -0
- data/app/assets/javascripts/tinymce/plugins/curblyadvimage/js/functions.js +508 -0
- data/app/assets/javascripts/tinymce/plugins/curblyadvimage/langs/en.js +3 -0
- data/app/assets/javascripts/tinymce/plugins/curblyadvimage/langs/en_dlg.js +43 -0
- data/app/assets/stylesheets/community_engine.css +6 -0
- data/app/assets/stylesheets/forum.css +605 -0
- data/app/assets/stylesheets/lightbox.css +38 -0
- data/app/assets/stylesheets/prototip.css +73 -0
- data/app/assets/stylesheets/reset-fonts-grids.css +8 -0
- data/app/assets/stylesheets/screen.css +977 -0
- data/app/controllers/activities_controller.rb +38 -0
- data/app/controllers/admin_controller.rb +80 -0
- data/app/controllers/ads_controller.rb +85 -0
- data/app/controllers/albums_controller.rb +106 -0
- data/app/controllers/authorizations_controller.rb +41 -0
- data/app/controllers/base_controller.rb +151 -0
- data/app/controllers/categories_controller.rb +118 -0
- data/app/controllers/clippings_controller.rb +192 -0
- data/app/controllers/comment_sweeper.rb +35 -0
- data/app/controllers/comments_controller.rb +179 -0
- data/app/controllers/event_sweeper.rb +24 -0
- data/app/controllers/events_controller.rb +173 -0
- data/app/controllers/favorite_sweeper.rb +29 -0
- data/app/controllers/favorites_controller.rb +36 -0
- data/app/controllers/forums_controller.rb +71 -0
- data/app/controllers/friendships_controller.rb +126 -0
- data/app/controllers/homepage_features_controller.rb +68 -0
- data/app/controllers/invitations_controller.rb +46 -0
- data/app/controllers/messages_controller.rb +95 -0
- data/app/controllers/metro_areas_controller.rb +68 -0
- data/app/controllers/moderators_controller.rb +26 -0
- data/app/controllers/monitorships_controller.rb +20 -0
- data/app/controllers/page_sweeper.rb +33 -0
- data/app/controllers/pages_controller.rb +70 -0
- data/app/controllers/password_resets_controller.rb +52 -0
- data/app/controllers/photo_manager_controller.rb +11 -0
- data/app/controllers/photos_controller.rb +189 -0
- data/app/controllers/post_sweeper.rb +36 -0
- data/app/controllers/posts_controller.rb +252 -0
- data/app/controllers/rsvps_controller.rb +77 -0
- data/app/controllers/sb_posts_controller.rb +149 -0
- data/app/controllers/sessions_controller.rb +34 -0
- data/app/controllers/sitemap_controller.rb +21 -0
- data/app/controllers/statistics_controller.rb +34 -0
- data/app/controllers/taggable_sweeper.rb +38 -0
- data/app/controllers/tags_controller.rb +104 -0
- data/app/controllers/theme_controller.rb +60 -0
- data/app/controllers/topics_controller.rb +122 -0
- data/app/controllers/users_controller.rb +426 -0
- data/app/controllers/vote_sweeper.rb +16 -0
- data/app/controllers/votes_controller.rb +24 -0
- data/app/helpers/base_helper.rb +290 -0
- data/app/helpers/forums_helper.rb +31 -0
- data/app/helpers/friendships_helper.rb +16 -0
- data/app/helpers/monitorships_helper.rb +2 -0
- data/app/helpers/posts_helper.rb +17 -0
- data/app/helpers/sitemap_helper.rb +7 -0
- data/app/helpers/users_helper.rb +6 -0
- data/app/models/ad.rb +43 -0
- data/app/models/album.rb +12 -0
- data/app/models/asset.rb +3 -0
- data/app/models/authorization.rb +60 -0
- data/app/models/category.rb +20 -0
- data/app/models/choice.rb +13 -0
- data/app/models/clipping.rb +78 -0
- data/app/models/clipping_image.rb +9 -0
- data/app/models/comment.rb +122 -0
- data/app/models/country.rb +24 -0
- data/app/models/event.rb +61 -0
- data/app/models/facebook_profile.rb +32 -0
- data/app/models/facebook_publisher.rb +45 -0
- data/app/models/favorite.rb +47 -0
- data/app/models/forum.rb +22 -0
- data/app/models/friendship.rb +64 -0
- data/app/models/friendship_status.rb +3 -0
- data/app/models/homepage_feature.rb +15 -0
- data/app/models/invitation.rb +36 -0
- data/app/models/message.rb +84 -0
- data/app/models/message_thread.rb +33 -0
- data/app/models/metro_area.rb +16 -0
- data/app/models/moderatorship.rb +8 -0
- data/app/models/monitorship.rb +6 -0
- data/app/models/page.rb +8 -0
- data/app/models/photo.rb +83 -0
- data/app/models/poll.rb +39 -0
- data/app/models/post.rb +201 -0
- data/app/models/role.rb +5 -0
- data/app/models/rsvp.rb +24 -0
- data/app/models/sb_post.rb +67 -0
- data/app/models/state.rb +4 -0
- data/app/models/topic.rb +72 -0
- data/app/models/twitter_profile.rb +20 -0
- data/app/models/user.rb +483 -0
- data/app/models/user_notifier.rb +140 -0
- data/app/models/user_session.rb +14 -0
- data/app/models/vote.rb +19 -0
- data/app/views/activities/_activity.html.haml +56 -0
- data/app/views/activities/_icon.html.haml +14 -0
- data/app/views/activities/_unhandled_item.html.haml +1 -0
- data/app/views/activities/destroy.js.rjs +1 -0
- data/app/views/activities/index.html.haml +16 -0
- data/app/views/activities/network.html.haml +14 -0
- data/app/views/admin/comments.html.haml +71 -0
- data/app/views/admin/events.html.haml +33 -0
- data/app/views/admin/messages.html.haml +4 -0
- data/app/views/admin/users.html.haml +69 -0
- data/app/views/ads/edit.html.haml +46 -0
- data/app/views/ads/index.html.haml +43 -0
- data/app/views/ads/new.html.haml +44 -0
- data/app/views/ads/show.html.haml +36 -0
- data/app/views/albums/_form.html.haml +14 -0
- data/app/views/albums/edit.html.haml +16 -0
- data/app/views/albums/new.html.haml +15 -0
- data/app/views/albums/show.html.haml +32 -0
- data/app/views/base/_homepage_banner_message.html.haml +19 -0
- data/app/views/base/advertise.html.haml +8 -0
- data/app/views/base/plaxo.html.haml +5 -0
- data/app/views/base/site_index.html.haml +35 -0
- data/app/views/categories/_tips.html.haml +11 -0
- data/app/views/categories/edit.html.haml +34 -0
- data/app/views/categories/index.html.haml +30 -0
- data/app/views/categories/new.html.haml +9 -0
- data/app/views/categories/show.html.haml +45 -0
- data/app/views/clippings/_clipping.html.haml +18 -0
- data/app/views/clippings/_images.html.haml +3 -0
- data/app/views/clippings/_meta.html.haml +26 -0
- data/app/views/clippings/edit.html.haml +26 -0
- data/app/views/clippings/index.html.haml +35 -0
- data/app/views/clippings/load_images_from_uri.js.rjs +1 -0
- data/app/views/clippings/new.html.haml +29 -0
- data/app/views/clippings/new_clipping.html.haml +91 -0
- data/app/views/clippings/show.html.haml +56 -0
- data/app/views/clippings/site_index.html.haml +34 -0
- data/app/views/comments/_comment.html.haml +42 -0
- data/app/views/comments/_comment_form.html.haml +50 -0
- data/app/views/comments/_edit_form.html.haml +29 -0
- data/app/views/comments/create.js.rjs +20 -0
- data/app/views/comments/edit.js.rjs +7 -0
- data/app/views/comments/index.html.haml +23 -0
- data/app/views/comments/update.js.rjs +9 -0
- data/app/views/events/_event.html.haml +32 -0
- data/app/views/events/_subscribe.html.haml +7 -0
- data/app/views/events/edit.html.haml +34 -0
- data/app/views/events/index.html.haml +22 -0
- data/app/views/events/new.html.haml +32 -0
- data/app/views/events/show.html.haml +29 -0
- data/app/views/facebook/_fb_require.html.haml +11 -0
- data/app/views/favorites/_favorite.html.haml +5 -0
- data/app/views/favorites/create.js.rjs +17 -0
- data/app/views/favorites/destroy.js.rjs +14 -0
- data/app/views/favorites/index.html.haml +10 -0
- data/app/views/favorites/show.html.haml +13 -0
- data/app/views/forums/_form.html.haml +21 -0
- data/app/views/forums/edit.html.haml +11 -0
- data/app/views/forums/index.html.haml +70 -0
- data/app/views/forums/new.html.haml +9 -0
- data/app/views/forums/show.html.haml +85 -0
- data/app/views/friendships/_friendship.html.haml +16 -0
- data/app/views/friendships/_friendships.html.erb +14 -0
- data/app/views/friendships/accepted.html.haml +13 -0
- data/app/views/friendships/denied.html.haml +8 -0
- data/app/views/friendships/index.html.erb +3 -0
- data/app/views/friendships/index.xml.builder +29 -0
- data/app/views/friendships/pending.html.haml +7 -0
- data/app/views/friendships/show.html.haml +12 -0
- data/app/views/homepage_features/edit.html.haml +31 -0
- data/app/views/homepage_features/index.html.haml +30 -0
- data/app/views/homepage_features/new.html.haml +30 -0
- data/app/views/homepage_features/show.html.haml +29 -0
- data/app/views/invitations/index.html.erb +16 -0
- data/app/views/invitations/new.html.haml +33 -0
- data/app/views/layouts/application.html.haml +59 -0
- data/app/views/messages/_form.html.haml +24 -0
- data/app/views/messages/_inbox.html.haml +41 -0
- data/app/views/messages/_sent.html.haml +34 -0
- data/app/views/messages/_sidebar_nav.html.haml +9 -0
- data/app/views/messages/index.html.haml +8 -0
- data/app/views/messages/new.html.haml +10 -0
- data/app/views/messages/show.html.haml +40 -0
- data/app/views/metro_areas/edit.html.haml +16 -0
- data/app/views/metro_areas/index.html.haml +28 -0
- data/app/views/metro_areas/new.html.haml +16 -0
- data/app/views/metro_areas/show.html.haml +22 -0
- data/app/views/moderators/_toggle.html.erb +14 -0
- data/app/views/moderators/create.js.rjs +5 -0
- data/app/views/moderators/destroy.js.rjs +1 -0
- data/app/views/monitorships/create.js.rjs +4 -0
- data/app/views/monitorships/destroy.js.rjs +4 -0
- data/app/views/pages/_form.html.haml +25 -0
- data/app/views/pages/edit.html.haml +16 -0
- data/app/views/pages/edit.html.haml~ +16 -0
- data/app/views/pages/index.html.haml +34 -0
- data/app/views/pages/index.html.haml~ +28 -0
- data/app/views/pages/new.html.haml +14 -0
- data/app/views/pages/show.html.haml +8 -0
- data/app/views/pages/show.html.haml~ +6 -0
- data/app/views/password_resets/edit.html.haml +16 -0
- data/app/views/password_resets/new.html.haml +13 -0
- data/app/views/photo_manager/index.html.haml +49 -0
- data/app/views/photos/_manage_photos.html.haml +14 -0
- data/app/views/photos/_show_image_list.html.haml +24 -0
- data/app/views/photos/edit.html.haml +39 -0
- data/app/views/photos/index.html.haml +28 -0
- data/app/views/photos/index.xml.builder +9 -0
- data/app/views/photos/manage_photos.js.rjs +5 -0
- data/app/views/photos/new.html.haml +51 -0
- data/app/views/photos/recent.html.haml +8 -0
- data/app/views/photos/show.html.haml +53 -0
- data/app/views/polls/_edit.html.haml +15 -0
- data/app/views/polls/_excerpt.html.haml +4 -0
- data/app/views/polls/_new.html.haml +10 -0
- data/app/views/polls/_poll_ui.html.haml +37 -0
- data/app/views/polls/_polls_sidebar.html.haml +8 -0
- data/app/views/posts/_author_profile.html.haml +21 -0
- data/app/views/posts/_favorited_post.html.haml +10 -0
- data/app/views/posts/_post.html.haml +29 -0
- data/app/views/posts/_send_to_friend.html.erb +29 -0
- data/app/views/posts/_sidebar_post.html.haml +1 -0
- data/app/views/posts/edit.html.haml +48 -0
- data/app/views/posts/featured.html.haml +19 -0
- data/app/views/posts/index.html.haml +23 -0
- data/app/views/posts/manage.html.haml +66 -0
- data/app/views/posts/new.html.haml +67 -0
- data/app/views/posts/popular.html.haml +35 -0
- data/app/views/posts/preview.html.haml +27 -0
- data/app/views/posts/recent.html.haml +29 -0
- data/app/views/posts/show.html.haml +85 -0
- data/app/views/rsvps/edit.html.haml +9 -0
- data/app/views/rsvps/new.html.haml +9 -0
- data/app/views/sb_posts/_dummy_forum_post.html.erb +13 -0
- data/app/views/sb_posts/_edit.html.erb +31 -0
- data/app/views/sb_posts/_post.xml.builder +10 -0
- data/app/views/sb_posts/_reply_form.html.haml +37 -0
- data/app/views/sb_posts/_sb_post.html.haml +34 -0
- data/app/views/sb_posts/create.js.rjs +16 -0
- data/app/views/sb_posts/edit.html.erb +13 -0
- data/app/views/sb_posts/edit.js.rjs +6 -0
- data/app/views/sb_posts/index.html.haml +55 -0
- data/app/views/sb_posts/index.xml.builder +20 -0
- data/app/views/sb_posts/monitored.html.erb +55 -0
- data/app/views/sb_posts/monitored.xml.builder +15 -0
- data/app/views/sb_posts/update.js.rjs +5 -0
- data/app/views/sessions/new.html.haml +27 -0
- data/app/views/shared/_admin_nav.html.haml +19 -0
- data/app/views/shared/_bio_help.html.haml +4 -0
- data/app/views/shared/_box.html.haml +3 -0
- data/app/views/shared/_contact.html.haml +5 -0
- data/app/views/shared/_explore.html.haml +9 -0
- data/app/views/shared/_footer_content.html.haml +13 -0
- data/app/views/shared/_header.html.haml +42 -0
- data/app/views/shared/_location_chooser.html.haml +21 -0
- data/app/views/shared/_login_sidebar.html.haml +14 -0
- data/app/views/shared/_messages.html.haml +8 -0
- data/app/views/shared/_scripts_and_styles.html.haml +12 -0
- data/app/views/shared/_user_menu.html.haml +21 -0
- data/app/views/sitemap/index.html.haml +21 -0
- data/app/views/sitemap/index.xml.builder +28 -0
- data/app/views/statistics/activities.xml.builder +33 -0
- data/app/views/statistics/index.html.haml +56 -0
- data/app/views/tags/edit.html.haml +19 -0
- data/app/views/tags/index.html.haml +25 -0
- data/app/views/tags/manage.html.haml +37 -0
- data/app/views/tags/show.html.haml +65 -0
- data/app/views/topics/_form.html.haml +28 -0
- data/app/views/topics/_recent_topics_sidebar.haml +22 -0
- data/app/views/topics/edit.html.haml +10 -0
- data/app/views/topics/new.html.haml +21 -0
- data/app/views/topics/show.html.haml +107 -0
- data/app/views/topics/show.xml.builder +15 -0
- data/app/views/user_notifier/activation.text.erb +11 -0
- data/app/views/user_notifier/comment_notice.text.erb +8 -0
- data/app/views/user_notifier/follow_up_comment_notice.text.erb +15 -0
- data/app/views/user_notifier/follow_up_comment_notice_anonymous.text.erb +18 -0
- data/app/views/user_notifier/forgot_username.text.erb +8 -0
- data/app/views/user_notifier/friendship_accepted.text.erb +8 -0
- data/app/views/user_notifier/friendship_request.text.erb +8 -0
- data/app/views/user_notifier/message_notification.text.erb +14 -0
- data/app/views/user_notifier/new_forum_post_notice.text.erb +14 -0
- data/app/views/user_notifier/password_reset_instructions.text.erb +10 -0
- data/app/views/user_notifier/post_recommendation.text.erb +32 -0
- data/app/views/user_notifier/signup_invitation.text.erb +14 -0
- data/app/views/user_notifier/signup_notification.text.erb +16 -0
- data/app/views/users/_dashboard_nav.html.haml +40 -0
- data/app/views/users/_omniauth_connect.html.haml +21 -0
- data/app/views/users/_profile_completeness.html.haml +21 -0
- data/app/views/users/_profile_user_info_sidebar.html.haml +50 -0
- data/app/views/users/_search_options.html.haml +10 -0
- data/app/views/users/_sidebar_user.html.haml +8 -0
- data/app/views/users/_user.html.haml +31 -0
- data/app/views/users/crop_profile_photo.html.haml +40 -0
- data/app/views/users/dashboard.html.haml +44 -0
- data/app/views/users/edit.html.haml +75 -0
- data/app/views/users/edit_account.html.haml +64 -0
- data/app/views/users/forgot_username.html.haml +13 -0
- data/app/views/users/index.html.haml +18 -0
- data/app/views/users/invite.html.haml +31 -0
- data/app/views/users/new.html.haml +54 -0
- data/app/views/users/resend_activation.html.haml +13 -0
- data/app/views/users/show.html.haml +103 -0
- data/app/views/users/signup_completed.html.haml +8 -0
- data/app/views/users/statistics.html.haml +28 -0
- data/app/views/users/upload_profile_photo.html.haml +15 -0
- data/app/views/users/welcome_about.html.haml +66 -0
- data/app/views/users/welcome_invite.html.haml +33 -0
- data/app/views/users/welcome_photo.html.haml +29 -0
- data/app/views/votes/create.js.rjs +6 -0
- data/community_engine.gemspec +55 -0
- data/config/application_config.rb +162 -0
- data/config/initializers/cropper.rb +19 -0
- data/config/initializers/mce_options.rb +40 -0
- data/config/initializers/recaptcha_constants.rb +6 -0
- data/config/initializers/white_list.rb +7 -0
- data/config/locales/de-DE.yml +1271 -0
- data/config/locales/en.yml +1658 -0
- data/config/locales/es-AR.yml +758 -0
- data/config/locales/es-ES.yml +340 -0
- data/config/locales/es-MX.yml +672 -0
- data/config/locales/fr-FR.yml +1509 -0
- data/config/locales/ja-JP.yml +1321 -0
- data/config/locales/ru-RU.yml +97 -0
- data/config/locales/sr-CP.yml +89 -0
- data/config/locales/sv-SE.yml +1320 -0
- data/config/routes.rb +242 -0
- data/db/migrate/001_create_users.rb +26 -0
- data/db/migrate/002_add_activation_code_to_user.rb +11 -0
- data/db/migrate/003_create_photos.rb +22 -0
- data/db/migrate/004_add_tag_support.rb +21 -0
- data/db/migrate/005_create_friendships.rb +14 -0
- data/db/migrate/006_add_comments_tables.rb +18 -0
- data/db/migrate/007_create_friendship_statuses.rb +13 -0
- data/db/migrate/008_add_friendship_statuses.rb +14 -0
- data/db/migrate/009_create_clippings.rb +16 -0
- data/db/migrate/010_create_invitations.rb +14 -0
- data/db/migrate/011_create_homepage_features.rb +22 -0
- data/db/migrate/012_create_posts.rb +19 -0
- data/db/migrate/013_create_states.rb +13 -0
- data/db/migrate/014_add_states.rb +11 -0
- data/db/migrate/015_create_metro_areas.rb +15 -0
- data/db/migrate/016_add_metro_areas.rb +295 -0
- data/db/migrate/017_add_sessions_table.rb +20 -0
- data/db/migrate/018_create_categories.rb +11 -0
- data/db/migrate/019_change_comment_to_text_field.rb +10 -0
- data/db/migrate/020_create_login_slug.rb +9 -0
- data/db/migrate/021_add_category_names.rb +8 -0
- data/db/migrate/023_add_denied_friendship_status.rb +13 -0
- data/db/migrate/024_add_notification_preferences.rb +13 -0
- data/db/migrate/025_create_countries.rb +11 -0
- data/db/migrate/026_add_countries.rb +230 -0
- data/db/migrate/027_add_us_to_existing_metro_areas.rb +9 -0
- data/db/migrate/028_add_country_id_to_users.rb +9 -0
- data/db/migrate/029_add_us_to_users_with_states.rb +14 -0
- data/db/migrate/030_add_users_counter_cache.rb +9 -0
- data/db/migrate/031_news_to_talk.rb +10 -0
- data/db/migrate/033_featured_users.rb +9 -0
- data/db/migrate/034_add_last_login.rb +9 -0
- data/db/migrate/035_track_emailed.rb +9 -0
- data/db/migrate/036_create_skills.rb +11 -0
- data/db/migrate/037_create_offerings.rb +12 -0
- data/db/migrate/038_add_zag_to_users.rb +13 -0
- data/db/migrate/039_create_activities_table.rb +17 -0
- data/db/migrate/040_add_category_tips.rb +9 -0
- data/db/migrate/041_create_events_table.rb +19 -0
- data/db/migrate/042_add_privacy_to_users.rb +10 -0
- data/db/migrate/043_sql_session_store_setup.rb +39 -0
- data/db/migrate/044_category_improvements.rb +11 -0
- data/db/migrate/045_adding_indexes.rb +39 -0
- data/db/migrate/046_adding_ads.rb +20 -0
- data/db/migrate/047_add_polls.rb +30 -0
- data/db/migrate/049_add_activities_count.rb +9 -0
- data/db/migrate/050_create_initial_schema.rb +73 -0
- data/db/migrate/051_add_audience_limitation_to_ads.rb +9 -0
- data/db/migrate/052_create_assets.rb +21 -0
- data/db/migrate/053_create_favoritables.rb +23 -0
- data/db/migrate/054_add_published_as_to_posts.rb +13 -0
- data/db/migrate/055_add_published_at_to_posts.rb +15 -0
- data/db/migrate/056_create_roles.rb +28 -0
- data/db/migrate/057_add_more_indexes.rb +19 -0
- data/db/migrate/058_add_anonymous_commenting_fields.rb +15 -0
- data/db/migrate/059_create_messages.rb +16 -0
- data/db/migrate/060_still_more_indexes.rb +19 -0
- data/db/migrate/061_postgres_compatibility_changes.rb +9 -0
- data/db/migrate/062_add_notify_to_comments.rb +11 -0
- data/db/migrate/063_create_albums.rb +15 -0
- data/db/migrate/064_add_album_id_to_photos.rb +9 -0
- data/db/migrate/065_add_view_count_to_albums.rb +9 -0
- data/db/migrate/066_add_view_count_to_photos.rb +9 -0
- data/db/migrate/067_create_static_pages.rb +22 -0
- data/db/migrate/068_create_rsvps.rb +13 -0
- data/db/migrate/069_create_pages.rb +29 -0
- data/db/migrate/070_add_pages.rb +11 -0
- data/db/migrate/071_authlogic_compatibility_changes.rb +43 -0
- data/db/migrate/072_add_allow_rsvp_to_events.rb +9 -0
- data/db/migrate/073_add_taggings_count_to_tags.rb +9 -0
- data/db/migrate/074_add_threading_to_messages.rb +19 -0
- data/db/migrate/075_add_anonymous_forum_posting.rb +16 -0
- data/db/migrate/076_add_comment_notification_toggle.rb +9 -0
- data/db/migrate/077_paperclip_changes.rb +36 -0
- data/db/migrate/078_create_authorizations.rb +20 -0
- data/db/migrate/079_create_slugs.rb +18 -0
- data/db/sample/users.rb +55 -0
- data/generators/ce_plugin/USAGE +7 -0
- data/generators/ce_plugin/ce_plugin_generator.rb +25 -0
- data/generators/ce_plugin/templates/README +13 -0
- data/generators/ce_plugin/templates/desert_routes.rb +3 -0
- data/generators/ce_plugin/templates/init.rb +8 -0
- data/generators/ce_plugin/templates/plugin.rb +1 -0
- data/generators/plugin_migration/plugin_migration_generator.rb +101 -0
- data/generators/plugin_migration/templates/plugin_migration.erb +13 -0
- data/lang/TRANSLATION.markdown +32 -0
- data/lib/community_engine/authenticated_system.rb +167 -0
- data/lib/community_engine/authenticated_test_helper.rb +113 -0
- data/lib/community_engine/community_engine_sha1_crypto_method.rb +12 -0
- data/lib/community_engine/engine.rb +39 -0
- data/lib/community_engine/engines_extensions.rb +7 -0
- data/lib/community_engine/i18n_extensions.rb +31 -0
- data/lib/community_engine/localized_application.rb +83 -0
- data/lib/community_engine/rails_asset_extensions.rb +131 -0
- data/lib/community_engine/url_upload.rb +15 -0
- data/lib/community_engine/version.rb +10 -0
- data/lib/community_engine/viewable.rb +12 -0
- data/lib/community_engine.rb +34 -0
- data/lib/tag_hacks.rb +24 -0
- data/lib/tasks/community_engine_tasks.rake +87 -0
- data/public/favicon.ico +0 -0
- data/sample_files/s3.yml +17 -0
- data/test/fixtures/ads.yml +13 -0
- data/test/fixtures/albums.yml +16 -0
- data/test/fixtures/categories.yml +16 -0
- data/test/fixtures/clippings.yml +15 -0
- data/test/fixtures/comments.yml +55 -0
- data/test/fixtures/countries.yml +13 -0
- data/test/fixtures/events.yml +61 -0
- data/test/fixtures/files/Granite.bmp +0 -0
- data/test/fixtures/files/library.jpg +0 -0
- data/test/fixtures/forums.yml +10 -0
- data/test/fixtures/friendship_statuses.yml +10 -0
- data/test/fixtures/friendships.yml +15 -0
- data/test/fixtures/homepage_features.yml +13 -0
- data/test/fixtures/invitations.yml +5 -0
- data/test/fixtures/messages.yml +24 -0
- data/test/fixtures/metro_areas.yml +24 -0
- data/test/fixtures/moderatorships.yml +4 -0
- data/test/fixtures/monitorships.yml +10 -0
- data/test/fixtures/pages.yml +26 -0
- data/test/fixtures/photos.yml +29 -0
- data/test/fixtures/posts.yml +49 -0
- data/test/fixtures/roles.yml +9 -0
- data/test/fixtures/rsvps.yml +7 -0
- data/test/fixtures/sb_posts.yml +90 -0
- data/test/fixtures/states.yml +7 -0
- data/test/fixtures/taggings.yml +15 -0
- data/test/fixtures/tags.yml +11 -0
- data/test/fixtures/topics.yml +63 -0
- data/test/fixtures/users.yml +222 -0
- data/test/functional/activities_controller_test.rb +62 -0
- data/test/functional/admin_controller_test.rb +60 -0
- data/test/functional/ads_controller_test.rb +51 -0
- data/test/functional/albums_controller_test.rb +120 -0
- data/test/functional/base_controller_test.rb +27 -0
- data/test/functional/categories_controller_test.rb +51 -0
- data/test/functional/clippings_controller_test.rb +123 -0
- data/test/functional/comments_controller_test.rb +215 -0
- data/test/functional/events_controller_test.rb +104 -0
- data/test/functional/favorites_controller_test.rb +53 -0
- data/test/functional/forums_controller_test.rb +95 -0
- data/test/functional/friendships_controller_test.rb +98 -0
- data/test/functional/homepage_features_controller_test.rb +69 -0
- data/test/functional/invitations_controller_test.rb +45 -0
- data/test/functional/messages_controller_test.rb +154 -0
- data/test/functional/metro_areas_controller_test.rb +63 -0
- data/test/functional/moderators_controller_test.rb +22 -0
- data/test/functional/monitorships_controller_test.rb +72 -0
- data/test/functional/pages_controller_test.rb +95 -0
- data/test/functional/password_reset_controller_test.rb +34 -0
- data/test/functional/photo_manager_controller_test.rb +21 -0
- data/test/functional/photos_controller_test.rb +203 -0
- data/test/functional/posts_controller_test.rb +224 -0
- data/test/functional/rsvps_controller_test.rb +92 -0
- data/test/functional/sb_posts_controller_test.rb +193 -0
- data/test/functional/sessions_controller_test.rb +55 -0
- data/test/functional/sitemap_controller_test.rb +9 -0
- data/test/functional/statistics_controller_test.rb +18 -0
- data/test/functional/tags_controller_test.rb +52 -0
- data/test/functional/theme_controller_test.rb +11 -0
- data/test/functional/topics_controller_test.rb +201 -0
- data/test/functional/users_controller_test.rb +460 -0
- data/test/functional/votes_controller_test.rb +27 -0
- data/test/test_helper.rb +103 -0
- data/test/testapp/.gitignore +4 -0
- data/test/testapp/README +256 -0
- data/test/testapp/Rakefile +7 -0
- data/test/testapp/app/controllers/application_controller.rb +3 -0
- data/test/testapp/app/helpers/application_helper.rb +2 -0
- data/test/testapp/config/application.rb +45 -0
- data/test/testapp/config/application_config.rb +1 -0
- data/test/testapp/config/boot.rb +10 -0
- data/test/testapp/config/database.yml +22 -0
- data/test/testapp/config/environment.rb +6 -0
- data/test/testapp/config/environments/development.rb +25 -0
- data/test/testapp/config/environments/production.rb +49 -0
- data/test/testapp/config/environments/test.rb +35 -0
- data/test/testapp/config/initializers/backtrace_silencers.rb +7 -0
- data/test/testapp/config/initializers/inflections.rb +10 -0
- data/test/testapp/config/initializers/mime_types.rb +5 -0
- data/test/testapp/config/initializers/secret_token.rb +7 -0
- data/test/testapp/config/initializers/session_store.rb +8 -0
- data/test/testapp/config/locales/en.yml +5 -0
- data/test/testapp/config/routes.rb +3 -0
- data/test/testapp/config.ru +4 -0
- data/test/testapp/db/schema.rb +456 -0
- data/test/testapp/db/seeds.rb +7 -0
- data/test/testapp/doc/README_FOR_APP +2 -0
- data/test/testapp/lib/tasks/.gitkeep +0 -0
- data/test/testapp/public/404.html +26 -0
- data/test/testapp/public/422.html +26 -0
- data/test/testapp/public/500.html +26 -0
- data/test/testapp/public/favicon.ico +0 -0
- data/test/testapp/public/images/rails.png +0 -0
- data/test/testapp/public/robots.txt +5 -0
- data/test/testapp/script/rails +6 -0
- data/test/testapp/test/performance/browsing_test.rb +9 -0
- data/test/testapp/test/test_helper.rb +13 -0
- data/test/testapp/vendor/plugins/.gitkeep +0 -0
- data/test/unit/ad_test.rb +34 -0
- data/test/unit/asset_test.rb +15 -0
- data/test/unit/authorization_test.rb +55 -0
- data/test/unit/category_test.rb +22 -0
- data/test/unit/choice_test.rb +9 -0
- data/test/unit/clipping_image_test.rb +17 -0
- data/test/unit/clipping_test.rb +52 -0
- data/test/unit/comment_test.rb +107 -0
- data/test/unit/country_test.rb +15 -0
- data/test/unit/event_test.rb +75 -0
- data/test/unit/favorite_test.rb +71 -0
- data/test/unit/forum_test.rb +23 -0
- data/test/unit/friendship_status_test.rb +10 -0
- data/test/unit/friendship_test.rb +38 -0
- data/test/unit/homepage_feature_test.rb +10 -0
- data/test/unit/invitation_test.rb +27 -0
- data/test/unit/message_test.rb +49 -0
- data/test/unit/message_thread_test.rb +80 -0
- data/test/unit/metro_area_test.rb +10 -0
- data/test/unit/moderatorship_test.rb +30 -0
- data/test/unit/monitorships_test.rb +38 -0
- data/test/unit/page_test.rb +25 -0
- data/test/unit/photo_test.rb +42 -0
- data/test/unit/poll_test.rb +25 -0
- data/test/unit/post_test.rb +212 -0
- data/test/unit/rsvp_test.rb +33 -0
- data/test/unit/sb_post_test.rb +152 -0
- data/test/unit/state_test.rb +10 -0
- data/test/unit/tag_test.rb +22 -0
- data/test/unit/topic_test.rb +111 -0
- data/test/unit/user_notifier_test.rb +108 -0
- data/test/unit/user_test.rb +259 -0
- data/test/unit/vote_test.rb +9 -0
- data/vendor/plugins/activity_tracker/README +4 -0
- data/vendor/plugins/activity_tracker/Rakefile +22 -0
- data/vendor/plugins/activity_tracker/generators/activity_migration/USAGE +13 -0
- data/vendor/plugins/activity_tracker/generators/activity_migration/activity_migration_generator.rb +11 -0
- data/vendor/plugins/activity_tracker/generators/activity_migration/templates/migration.rb +17 -0
- data/vendor/plugins/activity_tracker/init.rb +1 -0
- data/vendor/plugins/activity_tracker/install.rb +1 -0
- data/vendor/plugins/activity_tracker/lib/activity.rb +40 -0
- data/vendor/plugins/activity_tracker/lib/activity_tracker.rb +80 -0
- data/vendor/plugins/activity_tracker/tasks/activity_tracker_tasks.rake +4 -0
- data/vendor/plugins/activity_tracker/test/abstract_unit.rb +47 -0
- data/vendor/plugins/activity_tracker/test/activity_tracker_test.rb +48 -0
- data/vendor/plugins/activity_tracker/test/database.yml +18 -0
- data/vendor/plugins/activity_tracker/test/debug.log +3329 -0
- data/vendor/plugins/activity_tracker/test/fixtures/test_post.rb +5 -0
- data/vendor/plugins/activity_tracker/test/fixtures/test_posts.yml +3 -0
- data/vendor/plugins/activity_tracker/test/fixtures/test_user.rb +4 -0
- data/vendor/plugins/activity_tracker/test/fixtures/test_users.yml +6 -0
- data/vendor/plugins/activity_tracker/test/schema.rb +21 -0
- data/vendor/plugins/activity_tracker/uninstall.rb +1 -0
- data/vendor/plugins/acts_as_list/README +23 -0
- data/vendor/plugins/acts_as_list/init.rb +3 -0
- data/vendor/plugins/acts_as_list/lib/active_record/acts/list.rb +256 -0
- data/vendor/plugins/acts_as_list/test/list_test.rb +332 -0
- data/vendor/plugins/acts_as_publishable/README +3 -0
- data/vendor/plugins/acts_as_publishable/Rakefile +22 -0
- data/vendor/plugins/acts_as_publishable/generators/publishing/publishing_generator.rb +34 -0
- data/vendor/plugins/acts_as_publishable/generators/publishing/templates/migration.rb +13 -0
- data/vendor/plugins/acts_as_publishable/init.rb +3 -0
- data/vendor/plugins/acts_as_publishable/install.rb +3 -0
- data/vendor/plugins/acts_as_publishable/lib/acts_as_publishable.rb +81 -0
- data/vendor/plugins/acts_as_publishable/test/acts_as_publishable_test.rb +8 -0
- data/vendor/plugins/acts_as_publishable/uninstall.rb +1 -0
- data/vendor/plugins/auto_complete/README +23 -0
- data/vendor/plugins/auto_complete/Rakefile +22 -0
- data/vendor/plugins/auto_complete/init.rb +2 -0
- data/vendor/plugins/auto_complete/lib/auto_complete.rb +47 -0
- data/vendor/plugins/auto_complete/lib/auto_complete_macros_helper.rb +143 -0
- data/vendor/plugins/auto_complete/test/auto_complete_test.rb +67 -0
- data/vendor/plugins/enumerations_mixin/LICENSE +20 -0
- data/vendor/plugins/enumerations_mixin/README_ENUMERATIONS +163 -0
- data/vendor/plugins/enumerations_mixin/init.rb +21 -0
- data/vendor/plugins/enumerations_mixin/lib/active_record/acts/enumerated.rb +177 -0
- data/vendor/plugins/enumerations_mixin/lib/active_record/aggregations/has_enumerated.rb +60 -0
- data/vendor/plugins/enumerations_mixin/lib/active_record/virtual_enumerations.rb +68 -0
- data/vendor/plugins/enumerations_mixin/virtual_enumerations_sample.rb +76 -0
- data/vendor/plugins/prototype_legacy_helper/README.markdown +13 -0
- data/vendor/plugins/prototype_legacy_helper/init.rb +1 -0
- data/vendor/plugins/prototype_legacy_helper/lib/prototype_legacy_helper.rb +432 -0
- data/vendor/plugins/prototype_legacy_helper/test/test_prototype_helper.rb +297 -0
- data/vendor/plugins/resource_feeder/README +4 -0
- data/vendor/plugins/resource_feeder/Rakefile +22 -0
- data/vendor/plugins/resource_feeder/init.rb +2 -0
- data/vendor/plugins/resource_feeder/lib/resource_feeder/atom.rb +71 -0
- data/vendor/plugins/resource_feeder/lib/resource_feeder/rss.rb +71 -0
- data/vendor/plugins/resource_feeder/lib/resource_feeder.rb +2 -0
- data/vendor/plugins/resource_feeder/test/atom_feed_test.rb +85 -0
- data/vendor/plugins/resource_feeder/test/rss_feed_test.rb +61 -0
- data/vendor/plugins/resource_feeder/test/test_helper.rb +60 -0
- data/vendor/plugins/respond_to_parent/MIT-LICENSE +20 -0
- data/vendor/plugins/respond_to_parent/README +47 -0
- data/vendor/plugins/respond_to_parent/Rakefile +22 -0
- data/vendor/plugins/respond_to_parent/init.rb +1 -0
- data/vendor/plugins/respond_to_parent/install.rb +1 -0
- data/vendor/plugins/respond_to_parent/lib/responds_to_parent.rb +70 -0
- data/vendor/plugins/respond_to_parent/test/responds_to_parent_test.rb +10 -0
- data/vendor/plugins/respond_to_parent/test/test_helper.rb +6 -0
- data/vendor/plugins/respond_to_parent/uninstall.rb +1 -0
- data/vendor/plugins/tiny_mce/CHANGELOG_PLUGIN.rdoc +91 -0
- data/vendor/plugins/tiny_mce/CHANGELOG_TINYMCE +1226 -0
- data/vendor/plugins/tiny_mce/DEV_UPGRADE_NOTES.rdoc +12 -0
- data/vendor/plugins/tiny_mce/init.rb +2 -0
- data/vendor/plugins/tiny_mce/install.rb +18 -0
- data/vendor/plugins/tiny_mce/lib/tiny_mce/base.rb +33 -0
- data/vendor/plugins/tiny_mce/lib/tiny_mce/configuration.rb +114 -0
- data/vendor/plugins/tiny_mce/lib/tiny_mce/exceptions.rb +14 -0
- data/vendor/plugins/tiny_mce/lib/tiny_mce/helpers.rb +43 -0
- data/vendor/plugins/tiny_mce/lib/tiny_mce/railtie.rb +13 -0
- data/vendor/plugins/tiny_mce/lib/tiny_mce/spell_checker.rb +67 -0
- data/vendor/plugins/tiny_mce/lib/tiny_mce/valid_tinymce_langs.yml +25 -0
- data/vendor/plugins/tiny_mce/lib/tiny_mce/valid_tinymce_options.yml +167 -0
- data/vendor/plugins/tiny_mce/lib/tiny_mce.rb +24 -0
- data/vendor/plugins/white_list/README +35 -0
- data/vendor/plugins/white_list/Rakefile +22 -0
- data/vendor/plugins/white_list/init.rb +35 -0
- data/vendor/plugins/white_list/lib/white_list_helper.rb +61 -0
- data/vendor/plugins/white_list/test/white_list_test.rb +120 -0
- metadata +1073 -0
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
class Comment < ActiveRecord::Base
|
|
2
|
+
include ActsAsCommentable::Comment
|
|
3
|
+
include Rakismet::Model
|
|
4
|
+
rakismet_attrs :author => :author_name, :comment_type => 'comment', :content => :comment, :user_ip => :author_ip
|
|
5
|
+
attr_protected :akismet_attrs
|
|
6
|
+
|
|
7
|
+
belongs_to :commentable, :polymorphic => true
|
|
8
|
+
belongs_to :user, :inverse_of => :comments_as_author, :foreign_key => 'user_id', :class_name => "User"
|
|
9
|
+
belongs_to :recipient, :class_name => "User", :foreign_key => "recipient_id"
|
|
10
|
+
|
|
11
|
+
validates_presence_of :comment
|
|
12
|
+
validates_presence_of :commentable_id, :commentable_type
|
|
13
|
+
validates_length_of :comment, :maximum => 2000
|
|
14
|
+
|
|
15
|
+
before_save :whitelist_attributes
|
|
16
|
+
|
|
17
|
+
validates_presence_of :user, :unless => Proc.new{|record| configatron.allow_anonymous_commenting }
|
|
18
|
+
validates_presence_of :author_email, :unless => Proc.new{|record| record.user } #require email unless logged in
|
|
19
|
+
validates_presence_of :author_ip, :unless => Proc.new{|record| record.user} #log ip unless logged in
|
|
20
|
+
validates_format_of :author_url, :with => /(^$)|(^(http|https):\/\/[a-z0-9]+([\-\.]{1}[a-z0-9]+)*\.[a-z]{2,5}(([0-9]{1,5})?\/.*)?$)/ix, :unless => Proc.new{|record| record.user }
|
|
21
|
+
validate :check_spam
|
|
22
|
+
|
|
23
|
+
acts_as_activity :user, :if => Proc.new{|record| record.user } #don't record an activity if there's no user
|
|
24
|
+
|
|
25
|
+
def self.find_photo_comments_for(user)
|
|
26
|
+
Comment.find(:all, :conditions => ["recipient_id = ? AND commentable_type = ?", user.id, 'Photo'], :order => 'created_at DESC')
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
def previous_commenters_to_notify
|
|
30
|
+
# only send a notification on recent comments
|
|
31
|
+
# limit the number of emails we'll send (or posting will be slooowww)
|
|
32
|
+
User.find(:all,
|
|
33
|
+
:conditions => ["users.id NOT IN (?) AND users.notify_comments = ?
|
|
34
|
+
AND commentable_id = ? AND commentable_type = ?
|
|
35
|
+
AND comments.notify_by_email = ?
|
|
36
|
+
AND comments.created_at > ?", [user_id, recipient_id.to_i], true, commentable_id, commentable_type, true, 2.weeks.ago],
|
|
37
|
+
:include => :comments_as_author, :limit => 20)
|
|
38
|
+
end
|
|
39
|
+
|
|
40
|
+
def commentable_name
|
|
41
|
+
type = self.commentable_type.underscore
|
|
42
|
+
case type
|
|
43
|
+
when 'user'
|
|
44
|
+
commentable.login
|
|
45
|
+
when 'post'
|
|
46
|
+
commentable.title
|
|
47
|
+
when 'clipping'
|
|
48
|
+
commentable.description || "Clipping from #{commentable.user.login}"
|
|
49
|
+
when 'photo'
|
|
50
|
+
commentable.description || "Photo from #{commentable.user.login}"
|
|
51
|
+
else
|
|
52
|
+
commentable.class.to_s.humanize
|
|
53
|
+
end
|
|
54
|
+
end
|
|
55
|
+
|
|
56
|
+
def title_for_rss
|
|
57
|
+
"Comment from #{username}"
|
|
58
|
+
end
|
|
59
|
+
|
|
60
|
+
def username
|
|
61
|
+
user ? user.login : (author_name.blank? ? 'Anonymous' : author_name)
|
|
62
|
+
end
|
|
63
|
+
|
|
64
|
+
def self.find_recent(options = {:limit => 5})
|
|
65
|
+
find(:all, :conditions => "created_at > '#{14.days.ago.iso8601}'", :order => "created_at DESC", :limit => options[:limit])
|
|
66
|
+
end
|
|
67
|
+
|
|
68
|
+
def can_be_deleted_by(person)
|
|
69
|
+
person && (person.admin? || person.id.eql?(user_id) || person.id.eql?(recipient_id) )
|
|
70
|
+
end
|
|
71
|
+
|
|
72
|
+
def should_notify_recipient?
|
|
73
|
+
return unless recipient && recipient.email
|
|
74
|
+
return false if recipient.eql?(user)
|
|
75
|
+
return false unless recipient.notify_comments?
|
|
76
|
+
true
|
|
77
|
+
end
|
|
78
|
+
|
|
79
|
+
def notify_previous_commenters
|
|
80
|
+
previous_commenters_to_notify.each do |commenter|
|
|
81
|
+
UserNotifier.follow_up_comment_notice(commenter, self).deliver if commenter.email
|
|
82
|
+
end
|
|
83
|
+
end
|
|
84
|
+
|
|
85
|
+
def notify_previous_anonymous_commenters
|
|
86
|
+
anonymous_commenters_emails = commentable.comments.map{|c| c.author_email if (c.notify_by_email? && !c.user && !c.author_email.eql?(self.author_email) && c.author_email) }.uniq.compact
|
|
87
|
+
anonymous_commenters_emails.each do |email|
|
|
88
|
+
UserNotifier.follow_up_comment_notice_anonymous(email, self).deliver
|
|
89
|
+
end
|
|
90
|
+
end
|
|
91
|
+
|
|
92
|
+
def send_notifications
|
|
93
|
+
return if commentable.respond_to?(:send_comment_notifications?) && !commentable.send_comment_notifications?
|
|
94
|
+
UserNotifier.comment_notice(self).deliver if should_notify_recipient?
|
|
95
|
+
self.notify_previous_commenters
|
|
96
|
+
self.notify_previous_anonymous_commenters if configatron.allow_anonymous_commenting
|
|
97
|
+
end
|
|
98
|
+
|
|
99
|
+
def token_for(email)
|
|
100
|
+
Digest::SHA1.hexdigest("#{id}--#{email}--#{created_at}")
|
|
101
|
+
end
|
|
102
|
+
|
|
103
|
+
def unsubscribe_notifications(email)
|
|
104
|
+
commentable.comments.find_all_by_author_email(email).each do |previous_comment|
|
|
105
|
+
previous_comment.update_attribute :notify_by_email, false
|
|
106
|
+
end
|
|
107
|
+
end
|
|
108
|
+
|
|
109
|
+
def check_spam
|
|
110
|
+
if !configatron.akismet_key.nil? && self.spam?
|
|
111
|
+
self.errors.add(:base, :comment_spam_error.l)
|
|
112
|
+
end
|
|
113
|
+
end
|
|
114
|
+
|
|
115
|
+
|
|
116
|
+
protected
|
|
117
|
+
def whitelist_attributes
|
|
118
|
+
self.comment = white_list(self.comment)
|
|
119
|
+
end
|
|
120
|
+
|
|
121
|
+
|
|
122
|
+
end
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
class Country < ActiveRecord::Base
|
|
2
|
+
has_many :metro_areas
|
|
3
|
+
|
|
4
|
+
def self.get(name)
|
|
5
|
+
case name
|
|
6
|
+
when :us
|
|
7
|
+
c = 'United States'
|
|
8
|
+
end
|
|
9
|
+
self.find_by_name(c)
|
|
10
|
+
end
|
|
11
|
+
|
|
12
|
+
def self.find_countries_with_metros
|
|
13
|
+
Country.joins(:metro_areas).where('metro_areas.id IS NOT NULL').order('countries.name ASC').all.uniq
|
|
14
|
+
end
|
|
15
|
+
|
|
16
|
+
def states
|
|
17
|
+
State.joins(:metro_areas).where("metro_areas.id in (?)", metro_area_ids ).order('states.name ASC').all.uniq
|
|
18
|
+
end
|
|
19
|
+
|
|
20
|
+
def metro_area_ids
|
|
21
|
+
metro_areas.map{|m| m.id }.to_ary
|
|
22
|
+
end
|
|
23
|
+
|
|
24
|
+
end
|
data/app/models/event.rb
ADDED
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
class Event < ActiveRecord::Base
|
|
2
|
+
acts_as_activity :user
|
|
3
|
+
validates_presence_of :name
|
|
4
|
+
validates_presence_of :start_time
|
|
5
|
+
validates_presence_of :end_time
|
|
6
|
+
validates_presence_of :user
|
|
7
|
+
validate :start_time_cannot_be_before_end_time
|
|
8
|
+
|
|
9
|
+
belongs_to :user
|
|
10
|
+
belongs_to :metro_area
|
|
11
|
+
has_many :rsvps, :dependent=>:destroy
|
|
12
|
+
has_many :attendees, :source=>:user, :through=>:rsvps
|
|
13
|
+
|
|
14
|
+
attr_protected :user_id
|
|
15
|
+
|
|
16
|
+
#Procs used to make sure time is calculated at runtime
|
|
17
|
+
scope :upcoming, lambda {
|
|
18
|
+
where('end_time > ?' , Time.now).order('start_time ASC')
|
|
19
|
+
}
|
|
20
|
+
scope :past, lambda {
|
|
21
|
+
where('end_time <= ?' , Time.now).order('start_time DESC')
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
acts_as_commentable
|
|
26
|
+
|
|
27
|
+
# Used by acts_as_commentable
|
|
28
|
+
def owner
|
|
29
|
+
self.user
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
def rsvped?(user)
|
|
33
|
+
self.rsvps.find_by_user_id(user)
|
|
34
|
+
end
|
|
35
|
+
|
|
36
|
+
def attendees_for_user(user)
|
|
37
|
+
self.rsvps.find_by_user_id(user).attendees_count
|
|
38
|
+
end
|
|
39
|
+
|
|
40
|
+
def attendees_count
|
|
41
|
+
self.rsvps.sum(:attendees_count)
|
|
42
|
+
end
|
|
43
|
+
|
|
44
|
+
def time_and_date
|
|
45
|
+
if spans_days?
|
|
46
|
+
string = "#{start_time.strftime("%B %d")} to #{end_time.strftime("%B %d %Y")}"
|
|
47
|
+
else
|
|
48
|
+
string = "#{start_time.strftime("%B %d, %Y")}, #{start_time.strftime("%I:%M %p")} - #{end_time.strftime("%I:%M %p")}"
|
|
49
|
+
end
|
|
50
|
+
end
|
|
51
|
+
|
|
52
|
+
def spans_days?
|
|
53
|
+
(end_time - start_time) >= 86400
|
|
54
|
+
end
|
|
55
|
+
|
|
56
|
+
protected
|
|
57
|
+
def start_time_cannot_be_before_end_time
|
|
58
|
+
errors.add("start_time", " must be before end time") unless start_time && end_time && (start_time < end_time)
|
|
59
|
+
end
|
|
60
|
+
|
|
61
|
+
end
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
module FacebookProfile
|
|
2
|
+
def self.included(base)
|
|
3
|
+
base.class_eval do
|
|
4
|
+
include InstanceMethods
|
|
5
|
+
end
|
|
6
|
+
end
|
|
7
|
+
|
|
8
|
+
module InstanceMethods
|
|
9
|
+
|
|
10
|
+
def fb_friend_ids
|
|
11
|
+
graph.get_connections('/me', 'friends').map{|h| h['id'].to_i}
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
def fb_friends_with?(user)
|
|
15
|
+
fb_friend_ids.include?(user.profile[:id])
|
|
16
|
+
end
|
|
17
|
+
|
|
18
|
+
def graph
|
|
19
|
+
@graph ||= Koala::Facebook::API.new(facebook_authorization.token)
|
|
20
|
+
end
|
|
21
|
+
|
|
22
|
+
def facebook?
|
|
23
|
+
facebook_authorization
|
|
24
|
+
end
|
|
25
|
+
|
|
26
|
+
def facebook_authorization
|
|
27
|
+
self.authorizations.where(:provider => "facebook").first
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
end
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
class FacebookPublisher
|
|
2
|
+
include Rails.application.routes.url_helpers
|
|
3
|
+
include ActionView::Helpers::TextHelper
|
|
4
|
+
include ActionView::Helpers::SanitizeHelper
|
|
5
|
+
extend ActionView::Helpers::SanitizeHelper::ClassMethods
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
def self.connected(user)
|
|
9
|
+
text = "I joined #{configatron.community_name}."
|
|
10
|
+
if user.friends_ids.any?
|
|
11
|
+
text += " There are #{pluralize user.friends_ids.size,'friends'} in my network."
|
|
12
|
+
else
|
|
13
|
+
text += " Want to join me?"
|
|
14
|
+
end
|
|
15
|
+
|
|
16
|
+
href = home_url
|
|
17
|
+
|
|
18
|
+
user.graph.put_wall_post(text, :link => href, :name => configatron.community_name )
|
|
19
|
+
end
|
|
20
|
+
|
|
21
|
+
def self.comment_created_hash(comment, url)
|
|
22
|
+
{
|
|
23
|
+
:method => 'feed',
|
|
24
|
+
:link => url,
|
|
25
|
+
:name => "I left a comment on #{configatron.community_name}",
|
|
26
|
+
:description => comment
|
|
27
|
+
}.to_json
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
def self.blog_post_created_hash(post)
|
|
31
|
+
hash = {
|
|
32
|
+
:method => "feed",
|
|
33
|
+
:name => post.title,
|
|
34
|
+
:description => strip_tags(post.post),
|
|
35
|
+
:link => user_post_url(post.user, post, :host => default_host),
|
|
36
|
+
}
|
|
37
|
+
hash[:picture] = post.first_image_in_body unless post.first_image_in_body.nil?
|
|
38
|
+
hash.to_json
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
def self.default_host
|
|
42
|
+
configatron.app_host
|
|
43
|
+
end
|
|
44
|
+
|
|
45
|
+
end
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
class Favorite < ActiveRecord::Base
|
|
2
|
+
acts_as_activity :user
|
|
3
|
+
belongs_to :favoritable, :polymorphic => true
|
|
4
|
+
belongs_to :user
|
|
5
|
+
|
|
6
|
+
validates_presence_of :favoritable
|
|
7
|
+
|
|
8
|
+
validates_presence_of :ip_address
|
|
9
|
+
|
|
10
|
+
after_save :update_counter_on_favoritable
|
|
11
|
+
after_destroy :update_counter_on_favoritable
|
|
12
|
+
|
|
13
|
+
validates_uniqueness_of :user_id, :scope => [:favoritable_type, :favoritable_id], :allow_nil => true, :message => 'has already favorited this item.'
|
|
14
|
+
validates_uniqueness_of :ip_address, :scope => [:favoritable_type, :favoritable_id], :message => 'has already favorited this item.', :if => Proc.new{|f| f.user.nil? }
|
|
15
|
+
|
|
16
|
+
#named scopes
|
|
17
|
+
scope :recent, :order => "created_at DESC"
|
|
18
|
+
scope :by_user, lambda { |user|
|
|
19
|
+
{:conditions => ["user_id = ?", user.id] }
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
def update_counter_on_favoritable
|
|
24
|
+
if favoritable && favoritable.respond_to?(:favorited_count)
|
|
25
|
+
favoritable.update_attribute(:favorited_count, favoritable.favorites.count.to_s )
|
|
26
|
+
end
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
def self.find_favorites_by_user(user)
|
|
30
|
+
find(:all,
|
|
31
|
+
:conditions => ["user_id = ?", user.id],
|
|
32
|
+
:order => "created_at DESC"
|
|
33
|
+
)
|
|
34
|
+
end
|
|
35
|
+
|
|
36
|
+
def self.find_by_user_or_ip_address(favoritable = nil, user = nil, remote_ip = nil)
|
|
37
|
+
return false unless favoritable && (user || remote_ip)
|
|
38
|
+
|
|
39
|
+
if user
|
|
40
|
+
favorite = self.find(:first, :conditions => ["user_id = ? AND favoritable_type = ? AND favoritable_id = ?", user.id, favoritable.class.to_s, favoritable.id])
|
|
41
|
+
else
|
|
42
|
+
favorite = self.find(:first, :conditions => ["ip_address = ? AND favoritable_type = ? AND favoritable_id = ?", remote_ip, favoritable.class.to_s, favoritable.id])
|
|
43
|
+
end
|
|
44
|
+
return favorite
|
|
45
|
+
end
|
|
46
|
+
|
|
47
|
+
end
|
data/app/models/forum.rb
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
class Forum < ActiveRecord::Base
|
|
2
|
+
acts_as_taggable
|
|
3
|
+
acts_as_list
|
|
4
|
+
|
|
5
|
+
validates_presence_of :name
|
|
6
|
+
|
|
7
|
+
has_many :moderatorships, :dependent => :destroy
|
|
8
|
+
has_many :moderators, :through => :moderatorships, :source => :user
|
|
9
|
+
|
|
10
|
+
has_many :topics, :dependent => :destroy
|
|
11
|
+
|
|
12
|
+
has_many :sb_posts
|
|
13
|
+
|
|
14
|
+
belongs_to :owner, :polymorphic => true
|
|
15
|
+
|
|
16
|
+
format_attribute :description
|
|
17
|
+
|
|
18
|
+
def to_param
|
|
19
|
+
id.to_s << "-" << (name ? name.parameterize : '' )
|
|
20
|
+
end
|
|
21
|
+
|
|
22
|
+
end
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
class Friendship < ActiveRecord::Base
|
|
2
|
+
|
|
3
|
+
@@daily_request_limit = 12
|
|
4
|
+
cattr_accessor :daily_request_limit
|
|
5
|
+
|
|
6
|
+
belongs_to :user
|
|
7
|
+
belongs_to :friend, :class_name => "User", :foreign_key => "friend_id"
|
|
8
|
+
has_enumerated :friendship_status, :class_name => 'FriendshipStatus', :foreign_key => 'friendship_status_id'
|
|
9
|
+
|
|
10
|
+
validates_presence_of :friendship_status
|
|
11
|
+
validates_presence_of :user
|
|
12
|
+
validates_presence_of :friend
|
|
13
|
+
validates_uniqueness_of :friend_id, :scope => :user_id
|
|
14
|
+
validate :cannot_request_if_daily_limit_reached
|
|
15
|
+
validates_each :user_id do |record, attr, value|
|
|
16
|
+
record.errors.add attr, 'can not be same as friend' if record.user_id.eql?(record.friend_id)
|
|
17
|
+
end
|
|
18
|
+
|
|
19
|
+
# named scopes
|
|
20
|
+
scope :accepted, lambda {
|
|
21
|
+
#hack: prevents FriendshipStatus[:accepted] from getting called before the friendship_status records are in the db (only matters in testing ENV)
|
|
22
|
+
{:conditions => ["friendship_status_id = ?", FriendshipStatus[:accepted].id] }
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
def cannot_request_if_daily_limit_reached
|
|
26
|
+
if new_record? && initiator && user.has_reached_daily_friend_request_limit?
|
|
27
|
+
errors.add(:base, "Sorry, you'll have to wait a little while before requesting any more friendships.")
|
|
28
|
+
end
|
|
29
|
+
end
|
|
30
|
+
|
|
31
|
+
before_validation(:on => :create){:set_pending}
|
|
32
|
+
after_save :notify_requester, :if => Proc.new{|fr| fr.accepted? && fr.initiator }
|
|
33
|
+
|
|
34
|
+
attr_protected :friendship_status_id
|
|
35
|
+
|
|
36
|
+
def reverse
|
|
37
|
+
Friendship.find(:first, :conditions => ['user_id = ? and friend_id = ?', self.friend_id, self.user_id])
|
|
38
|
+
end
|
|
39
|
+
|
|
40
|
+
def denied?
|
|
41
|
+
friendship_status.eql?(FriendshipStatus[:denied])
|
|
42
|
+
end
|
|
43
|
+
|
|
44
|
+
def pending?
|
|
45
|
+
friendship_status.eql?(FriendshipStatus[:pending])
|
|
46
|
+
end
|
|
47
|
+
|
|
48
|
+
def accepted?
|
|
49
|
+
friendship_status.eql?(FriendshipStatus[:accepted])
|
|
50
|
+
end
|
|
51
|
+
|
|
52
|
+
def self.friends?(user, friend)
|
|
53
|
+
find(:first, :conditions => ["user_id = ? AND friend_id = ? AND friendship_status_id = ?", user.id, friend.id, FriendshipStatus[:accepted].id ])
|
|
54
|
+
end
|
|
55
|
+
|
|
56
|
+
def notify_requester
|
|
57
|
+
UserNotifier.friendship_accepted(self).deliver
|
|
58
|
+
end
|
|
59
|
+
|
|
60
|
+
private
|
|
61
|
+
def set_pending
|
|
62
|
+
friendship_status_id = FriendshipStatus[:pending].id
|
|
63
|
+
end
|
|
64
|
+
end
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
class HomepageFeature < ActiveRecord::Base
|
|
2
|
+
has_attached_file :image, configatron.feature.paperclip_options.to_hash
|
|
3
|
+
validates_attachment_presence :image
|
|
4
|
+
validates_attachment_content_type :image, :content_type => configatron.feature.validation_options.content_type
|
|
5
|
+
validates_attachment_size :image, :less_than => configatron.feature.validation_options.max_size.to_i.megabytes
|
|
6
|
+
|
|
7
|
+
attr_accessible :url, :title, :description, :image
|
|
8
|
+
|
|
9
|
+
validates_presence_of :url
|
|
10
|
+
|
|
11
|
+
def self.find_features
|
|
12
|
+
find(:all, :order => "created_at DESC")
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
end
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
class Invitation < ActiveRecord::Base
|
|
2
|
+
acts_as_activity :user
|
|
3
|
+
|
|
4
|
+
belongs_to :user
|
|
5
|
+
|
|
6
|
+
after_save :send_invite
|
|
7
|
+
|
|
8
|
+
validates_presence_of :user
|
|
9
|
+
validates_presence_of :email_addresses
|
|
10
|
+
validates_length_of :email_addresses, :minimum => 6
|
|
11
|
+
validates_length_of :email_addresses, :maximum => 1500
|
|
12
|
+
|
|
13
|
+
validates_each :email_addresses do |record, attr, email_addresses |
|
|
14
|
+
invalid_emails = []
|
|
15
|
+
email_addresses = email_addresses || ''
|
|
16
|
+
emails = email_addresses.split(",").collect{|email| email.strip }.uniq
|
|
17
|
+
|
|
18
|
+
emails.each{ |email|
|
|
19
|
+
unless email =~ /[\w._%-]+@[\w.-]+.[a-zA-Z]{2,4}/
|
|
20
|
+
invalid_emails << email
|
|
21
|
+
end
|
|
22
|
+
}
|
|
23
|
+
unless invalid_emails.empty?
|
|
24
|
+
record.errors.add(:email_addresses, " included invalid addresses: <ul>"+invalid_emails.collect{|email| '<li>'+email+'</li>' }.join+"</ul>")
|
|
25
|
+
record.email_addresses = (emails - invalid_emails).join(', ')
|
|
26
|
+
end
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
def send_invite
|
|
30
|
+
emails = self.email_addresses.split(",").collect{|email| email.strip }.uniq
|
|
31
|
+
emails.each{|email|
|
|
32
|
+
UserNotifier.signup_invitation(email, self.user, self.message).deliver
|
|
33
|
+
}
|
|
34
|
+
end
|
|
35
|
+
|
|
36
|
+
end
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
class Message < ActiveRecord::Base
|
|
2
|
+
attr_accessor :to
|
|
3
|
+
attr_accessor :reply_to
|
|
4
|
+
|
|
5
|
+
belongs_to :sender, :class_name => 'User', :foreign_key => 'sender_id', :inverse_of => :sent_messages
|
|
6
|
+
belongs_to :recipient, :class_name => 'User', :foreign_key => 'recipient_id', :inverse_of => :received_messages
|
|
7
|
+
|
|
8
|
+
belongs_to :parent, :class_name => "Message", :foreign_key => "parent_id", :inverse_of => :children
|
|
9
|
+
has_many :children, :class_name => "Message", :foreign_key => "parent_id", :inverse_of => :parent
|
|
10
|
+
has_many :message_threads
|
|
11
|
+
|
|
12
|
+
scope :parent_messages, where("parent_id IS NULL")
|
|
13
|
+
scope :already_read, where("read_at IS NOT NULL")
|
|
14
|
+
scope :unread, where("read_at IS NULL")
|
|
15
|
+
|
|
16
|
+
validates_presence_of :body, :subject
|
|
17
|
+
validates_presence_of :recipient, :message => "is invalid"
|
|
18
|
+
validate :ensure_not_sending_to_self
|
|
19
|
+
|
|
20
|
+
after_create :notify_recipient
|
|
21
|
+
after_create :update_message_threads
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
# Ensures the passed user is either the sender or the recipient then returns the message.
|
|
25
|
+
# If the reader is the recipient and the message has yet not been read, it marks the read_at timestamp.
|
|
26
|
+
def self.read(id, reader)
|
|
27
|
+
message = find(id, :conditions => ["sender_id = ? OR recipient_id = ?", reader, reader])
|
|
28
|
+
if message.read_at.nil? && reader == message.recipient
|
|
29
|
+
message.read_at = Time.now
|
|
30
|
+
message.save!
|
|
31
|
+
end
|
|
32
|
+
message
|
|
33
|
+
end
|
|
34
|
+
|
|
35
|
+
# Returns true or false value based on whether the a message has been read by its recipient.
|
|
36
|
+
def read?
|
|
37
|
+
self.read_at.nil? ? false : true
|
|
38
|
+
end
|
|
39
|
+
|
|
40
|
+
# Marks a message as deleted by either the sender or the recipient, which ever the user that was passed is.
|
|
41
|
+
# Once both have marked it deleted, it is destroyed.
|
|
42
|
+
def mark_deleted(user)
|
|
43
|
+
self.sender_deleted = true if self.sender == user
|
|
44
|
+
self.recipient_deleted = true if self.recipient == user
|
|
45
|
+
self.sender_deleted && self.recipient_deleted ? self.destroy : save!
|
|
46
|
+
end
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
def ensure_not_sending_to_self
|
|
50
|
+
errors.add(:base, "You may not send a message to yourself.") if self.recipient && self.recipient.eql?(self.sender)
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
def notify_recipient
|
|
54
|
+
UserNotifier.message_notification(self).deliver
|
|
55
|
+
end
|
|
56
|
+
|
|
57
|
+
def update_message_threads
|
|
58
|
+
recipients_thread = MessageThread.find_or_create_by_recipient_id_and_parent_message_id(self.recipient_id, (self.parent_id || self.id))
|
|
59
|
+
recipients_thread.attributes = {:sender => sender, :recipient => recipient, :message => self, :parent_message => (self.parent || self)}
|
|
60
|
+
recipients_thread.save
|
|
61
|
+
|
|
62
|
+
if parent
|
|
63
|
+
senders_thread = MessageThread.find_or_create_by_recipient_id_and_parent_message_id(self.sender_id, self.parent_id)
|
|
64
|
+
senders_thread.message = self
|
|
65
|
+
senders_thread.save
|
|
66
|
+
end
|
|
67
|
+
end
|
|
68
|
+
|
|
69
|
+
def self.new_reply(sender, message_thread = nil, params = {})
|
|
70
|
+
message = new(params[:message])
|
|
71
|
+
message.to ||= params[:to] if params[:to]
|
|
72
|
+
|
|
73
|
+
if message_thread
|
|
74
|
+
message.parent = message_thread.parent_message
|
|
75
|
+
message.reply_to = message_thread.message
|
|
76
|
+
message.to = message_thread.sender.login
|
|
77
|
+
message.subject = message_thread.parent_message.subject
|
|
78
|
+
message.sender = sender
|
|
79
|
+
end
|
|
80
|
+
|
|
81
|
+
message
|
|
82
|
+
end
|
|
83
|
+
|
|
84
|
+
end
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
class MessageThread < ActiveRecord::Base
|
|
2
|
+
belongs_to :message
|
|
3
|
+
belongs_to :parent_message, :class_name => 'Message'
|
|
4
|
+
belongs_to :sender, :class_name => 'User', :foreign_key => "sender_id"
|
|
5
|
+
belongs_to :recipient, :class_name => 'User', :foreign_key => "recipient_id"
|
|
6
|
+
|
|
7
|
+
before_destroy :mark_messages_deleted
|
|
8
|
+
|
|
9
|
+
def subject
|
|
10
|
+
parent_message.subject
|
|
11
|
+
end
|
|
12
|
+
|
|
13
|
+
def creator_name
|
|
14
|
+
parent_message.sender.eql?(recipient) ? 'Me' : parent_message.sender.login
|
|
15
|
+
end
|
|
16
|
+
|
|
17
|
+
def self.for(message, user)
|
|
18
|
+
find(:first, :conditions => {:parent_message_id => (message.parent_id || message.id), :recipient_id => user.id})
|
|
19
|
+
end
|
|
20
|
+
|
|
21
|
+
def mark_messages_deleted
|
|
22
|
+
parent_message.mark_deleted(recipient)
|
|
23
|
+
parent_message.children.each do |child|
|
|
24
|
+
child.mark_deleted(recipient)
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
def read?
|
|
29
|
+
message.recipient.eql?(recipient) ? message.read? : 'read'
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
end
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
class MetroArea < ActiveRecord::Base
|
|
2
|
+
has_many :users
|
|
3
|
+
belongs_to :state
|
|
4
|
+
belongs_to :country
|
|
5
|
+
|
|
6
|
+
#validates_presence_of :state, :if => Proc.new { |user| user.country.eql?(Country.get(:us)) }
|
|
7
|
+
validates_presence_of :country_id
|
|
8
|
+
validates_presence_of :name
|
|
9
|
+
|
|
10
|
+
acts_as_commentable
|
|
11
|
+
|
|
12
|
+
def to_s
|
|
13
|
+
name
|
|
14
|
+
end
|
|
15
|
+
|
|
16
|
+
end
|