jacobat-refinerycms 0.9.6.14
Sign up to get free protection for your applications and to get access to all the features.
- data/.gems +8 -0
- data/.gitignore +23 -0
- data/.yardopts +31 -0
- data/Gemfile +12 -0
- data/Rakefile +70 -0
- data/VERSION +1 -0
- data/app/controllers/admin/base_controller.rb +8 -0
- data/app/controllers/application.rb +3 -0
- data/app/controllers/application_controller.rb +7 -0
- data/app/helpers/application_helper.rb +7 -0
- data/bin/refinery +84 -0
- data/bin/refinery-override +76 -0
- data/bin/refinery-update-core +92 -0
- data/config/amazon_s3.yml.example +18 -0
- data/config/application.rb +88 -0
- data/config/boot.rb +110 -0
- data/config/database.yml.example +20 -0
- data/config/environment.rb +5 -0
- data/config/environments/development.rb +26 -0
- data/config/environments/production.rb +26 -0
- data/config/environments/test.rb +22 -0
- data/config/initializers/inflections.rb +10 -0
- data/config/initializers/mime_types.rb +5 -0
- data/config/preinitializer.rb +27 -0
- data/config/rackspace_cloudfiles.yml.example +14 -0
- data/config/routes.rb +20 -0
- data/contributors.md +20 -0
- data/db/migrate/20091029034951_remove_blurb_from_news_items.rb +9 -0
- data/db/migrate/20091109012126_add_missing_indexes.rb +25 -0
- data/db/migrate/20091130040711_add_down_for_maintenance_page.rb +15 -0
- data/db/migrate/20091207033335_add_superuser_to_users.rb +12 -0
- data/db/migrate/20100114092849_add_themes_table.rb +19 -0
- data/db/migrate/20100127004649_add_reset_code_to_users.rb +9 -0
- data/db/migrate/20100202034802_remove_custom_title_image_id_and_image_id_from_pages.rb +13 -0
- data/db/migrate/20100204011654_change_part_titles_to_titleized_version_for_new_format.rb +13 -0
- data/db/migrate/20100223211536_remove_themes_table.rb +17 -0
- data/db/schema.rb +150 -0
- data/db/seeds.rb +121 -0
- data/doc/.yardoc/checksums +0 -0
- data/doc/.yardoc/objects/root.dat +0 -0
- data/doc/.yardoc/proxy_types +0 -0
- data/lib/refinery_initializer.rb +23 -0
- data/license.md +21 -0
- data/public/.htaccess +40 -0
- data/public/404.html +29 -0
- data/public/422.html +30 -0
- data/public/500.html +29 -0
- data/public/favicon.ico +0 -0
- data/public/images/refinery/add.png +0 -0
- data/public/images/refinery/admin_bg.png +0 -0
- data/public/images/refinery/ajax-loader.gif +0 -0
- data/public/images/refinery/branch-end.gif +0 -0
- data/public/images/refinery/branch-start.gif +0 -0
- data/public/images/refinery/branch.gif +0 -0
- data/public/images/refinery/header_background.png +0 -0
- data/public/images/refinery/hover-gradient.jpg +0 -0
- data/public/images/refinery/icons/accept.png +0 -0
- data/public/images/refinery/icons/add.png +0 -0
- data/public/images/refinery/icons/application_edit.png +0 -0
- data/public/images/refinery/icons/application_go.png +0 -0
- data/public/images/refinery/icons/arrow_left.png +0 -0
- data/public/images/refinery/icons/arrow_switch.png +0 -0
- data/public/images/refinery/icons/arrow_up.png +0 -0
- data/public/images/refinery/icons/cancel.png +0 -0
- data/public/images/refinery/icons/cog_add.png +0 -0
- data/public/images/refinery/icons/cog_edit.png +0 -0
- data/public/images/refinery/icons/cross.png +0 -0
- data/public/images/refinery/icons/delete.png +0 -0
- data/public/images/refinery/icons/edit.png +0 -0
- data/public/images/refinery/icons/email_edit.png +0 -0
- data/public/images/refinery/icons/email_go.png +0 -0
- data/public/images/refinery/icons/email_open.png +0 -0
- data/public/images/refinery/icons/eye.png +0 -0
- data/public/images/refinery/icons/image_add.png +0 -0
- data/public/images/refinery/icons/image_edit.png +0 -0
- data/public/images/refinery/icons/layout_add.png +0 -0
- data/public/images/refinery/icons/layout_edit.png +0 -0
- data/public/images/refinery/icons/page_add.png +0 -0
- data/public/images/refinery/icons/page_edit.png +0 -0
- data/public/images/refinery/icons/page_white_edit.png +0 -0
- data/public/images/refinery/icons/page_white_put.png +0 -0
- data/public/images/refinery/icons/star.png +0 -0
- data/public/images/refinery/icons/tick.png +0 -0
- data/public/images/refinery/icons/user_add.png +0 -0
- data/public/images/refinery/icons/user_comment.png +0 -0
- data/public/images/refinery/icons/user_edit.png +0 -0
- data/public/images/refinery/logo-large.png +0 -0
- data/public/images/refinery/logo-medium.png +0 -0
- data/public/images/refinery/logo-small-medium.png +0 -0
- data/public/images/refinery/logo-small.png +0 -0
- data/public/images/refinery/logo.png +0 -0
- data/public/images/refinery/nav-3-background.gif +0 -0
- data/public/images/refinery/page_bg.png +0 -0
- data/public/images/refinery/resolve_digital_footer_logo.png +0 -0
- data/public/images/thickbox/cross.png +0 -0
- data/public/images/thickbox/loadingAnimation.gif +0 -0
- data/public/images/thickbox/macFFBgHack.png +0 -0
- data/public/images/wymeditor/skins/refinery/blockquote.png +0 -0
- data/public/images/wymeditor/skins/refinery/center.png +0 -0
- data/public/images/wymeditor/skins/refinery/css.png +0 -0
- data/public/images/wymeditor/skins/refinery/h1.png +0 -0
- data/public/images/wymeditor/skins/refinery/h2.png +0 -0
- data/public/images/wymeditor/skins/refinery/h3.png +0 -0
- data/public/images/wymeditor/skins/refinery/h4.png +0 -0
- data/public/images/wymeditor/skins/refinery/h5.png +0 -0
- data/public/images/wymeditor/skins/refinery/h6.png +0 -0
- data/public/images/wymeditor/skins/refinery/icons.png +0 -0
- data/public/images/wymeditor/skins/refinery/iframe/lbl-blockquote.png +0 -0
- data/public/images/wymeditor/skins/refinery/iframe/lbl-h1.png +0 -0
- data/public/images/wymeditor/skins/refinery/iframe/lbl-h2.png +0 -0
- data/public/images/wymeditor/skins/refinery/iframe/lbl-h3.png +0 -0
- data/public/images/wymeditor/skins/refinery/iframe/lbl-h4.png +0 -0
- data/public/images/wymeditor/skins/refinery/iframe/lbl-h5.png +0 -0
- data/public/images/wymeditor/skins/refinery/iframe/lbl-h6.png +0 -0
- data/public/images/wymeditor/skins/refinery/iframe/lbl-p.png +0 -0
- data/public/images/wymeditor/skins/refinery/iframe/lbl-pre.png +0 -0
- data/public/images/wymeditor/skins/refinery/justify.png +0 -0
- data/public/images/wymeditor/skins/refinery/left.png +0 -0
- data/public/images/wymeditor/skins/refinery/paragraph.png +0 -0
- data/public/images/wymeditor/skins/refinery/right.png +0 -0
- data/public/images/wymeditor/skins/wymeditor_icon.png +0 -0
- data/public/javascripts/admin.js +5 -0
- data/public/javascripts/application.js +1 -0
- data/public/javascripts/jquery/GPL-LICENSE.txt +278 -0
- data/public/javascripts/jquery/MIT-LICENSE.txt +20 -0
- data/public/javascripts/jquery-ui-1.8rc1.min.js +375 -0
- data/public/javascripts/jquery.js +6078 -0
- data/public/javascripts/refinery/admin.js +705 -0
- data/public/javascripts/refinery/boot_wym.js +154 -0
- data/public/javascripts/thickbox.js +350 -0
- data/public/javascripts/wymeditor/jquery.refinery.wymeditor.js +4975 -0
- data/public/javascripts/wymeditor/lang/ca.js +45 -0
- data/public/javascripts/wymeditor/lang/cs.js +45 -0
- data/public/javascripts/wymeditor/lang/de.js +45 -0
- data/public/javascripts/wymeditor/lang/en.js +48 -0
- data/public/javascripts/wymeditor/lang/es.js +45 -0
- data/public/javascripts/wymeditor/lang/fa.js +46 -0
- data/public/javascripts/wymeditor/lang/fr.js +45 -0
- data/public/javascripts/wymeditor/lang/he.js +45 -0
- data/public/javascripts/wymeditor/lang/hu.js +45 -0
- data/public/javascripts/wymeditor/lang/it.js +45 -0
- data/public/javascripts/wymeditor/lang/nb.js +45 -0
- data/public/javascripts/wymeditor/lang/nl.js +45 -0
- data/public/javascripts/wymeditor/lang/nn.js +45 -0
- data/public/javascripts/wymeditor/lang/pl.js +45 -0
- data/public/javascripts/wymeditor/lang/pt-br.js +45 -0
- data/public/javascripts/wymeditor/lang/pt.js +45 -0
- data/public/javascripts/wymeditor/lang/ru.js +45 -0
- data/public/javascripts/wymeditor/lang/sv.js +45 -0
- data/public/javascripts/wymeditor/lang/tr.js +45 -0
- data/public/javascripts/wymeditor/lang/zh_cn.js +47 -0
- data/public/javascripts/wymeditor/skins/refinery/skin.js +40 -0
- data/public/robots.txt +2 -0
- data/public/stylesheets/application.css +5 -0
- data/public/stylesheets/formatting.css +5 -0
- data/public/stylesheets/home.css +5 -0
- data/public/stylesheets/ie6.css +0 -0
- data/public/stylesheets/ie7.css +0 -0
- data/public/stylesheets/refinery/application.css +45 -0
- data/public/stylesheets/refinery/formatting.css +53 -0
- data/public/stylesheets/refinery/home.css +0 -0
- data/public/stylesheets/refinery/refinery.css +1233 -0
- data/public/stylesheets/refinery/theme.css +36 -0
- data/public/stylesheets/refinery/thickbox.css +165 -0
- data/public/stylesheets/refinery/tooltips.css +38 -0
- data/public/stylesheets/theme.css +1 -0
- data/public/stylesheets/wymeditor/skins/refinery/skin.css +218 -0
- data/public/stylesheets/wymeditor/skins/refinery/wymiframe.css +92 -0
- data/public/wymeditor/GPL-license.txt +278 -0
- data/public/wymeditor/MIT-license.txt +20 -0
- data/public/wymeditor/README +35 -0
- data/readme.md +181 -0
- data/script/about +3 -0
- data/script/console +3 -0
- data/script/dbconsole +3 -0
- data/script/destroy +3 -0
- data/script/generate +3 -0
- data/script/performance/benchmarker +3 -0
- data/script/performance/profiler +3 -0
- data/script/performance/request +3 -0
- data/script/plugin +3 -0
- data/script/process/inspector +3 -0
- data/script/process/reaper +3 -0
- data/script/process/spawner +3 -0
- data/script/runner +3 -0
- data/script/server +3 -0
- data/test/files/The world!.gif +0 -0
- data/test/files/car-wallpapers19.jpg +0 -0
- data/test/files/teng.pdf +0 -0
- data/test/fixtures/images.yml +14 -0
- data/test/fixtures/inquiries.yml +22 -0
- data/test/fixtures/news_items.yml +14 -0
- data/test/fixtures/page_parts.yml +9 -0
- data/test/fixtures/pages.yml +94 -0
- data/test/fixtures/refinery_settings.yml +3 -0
- data/test/fixtures/resources.yml +4 -0
- data/test/fixtures/users.yml +16 -0
- data/test/functional/dashboard_controller_test.rb +24 -0
- data/test/performance/browsing_test.rb +9 -0
- data/test/test_helper.rb +43 -0
- data/test/unit/image_test.rb +27 -0
- data/test/unit/inquiry_test.rb +41 -0
- data/test/unit/news_items_test.rb +33 -0
- data/test/unit/page_part_test.rb +19 -0
- data/test/unit/page_test.rb +133 -0
- data/test/unit/refinery_setting_test.rb +57 -0
- data/test/unit/resource_test.rb +33 -0
- data/themes/demolicious/LICENSE +21 -0
- data/themes/demolicious/README +1 -0
- data/themes/demolicious/images/footer_background.png +0 -0
- data/themes/demolicious/images/header_background.png +0 -0
- data/themes/demolicious/stylesheets/application.css +94 -0
- data/themes/demolicious/stylesheets/formatting.css +36 -0
- data/themes/demolicious/stylesheets/home.css +8 -0
- data/themes/demolicious/stylesheets/ie6.css +0 -0
- data/themes/demolicious/stylesheets/ie7.css +0 -0
- data/themes/demolicious/views/layouts/application.html.erb +20 -0
- data/themes/demolicious/views/pages/home.html.erb +1 -0
- data/themes/demolicious/views/pages/show.html.erb +1 -0
- data/themes/hemingway/LICENSE +7 -0
- data/themes/hemingway/README +3 -0
- data/themes/hemingway/images/archives.gif +0 -0
- data/themes/hemingway/images/footer_black.gif +0 -0
- data/themes/hemingway/images/kyle-header.jpg +0 -0
- data/themes/hemingway/images/readon_black.gif +0 -0
- data/themes/hemingway/images/search.gif +0 -0
- data/themes/hemingway/images/spinner.gif +0 -0
- data/themes/hemingway/images/trackback_pingback.gif +0 -0
- data/themes/hemingway/stylesheets/application.css +713 -0
- data/themes/hemingway/stylesheets/formatting.css +1 -0
- data/themes/hemingway/stylesheets/home.css +1 -0
- data/themes/hemingway/views/layouts/application.html.erb +55 -0
- data/todo.md +23 -0
- data/vendor/cache/aasm-2.1.3.gem +0 -0
- data/vendor/cache/actionmailer-2.3.5.gem +0 -0
- data/vendor/cache/actionpack-2.3.5.gem +0 -0
- data/vendor/cache/activerecord-2.3.5.gem +0 -0
- data/vendor/cache/activeresource-2.3.5.gem +0 -0
- data/vendor/cache/activesupport-2.3.5.gem +0 -0
- data/vendor/cache/friendly_id-2.3.1.gem +0 -0
- data/vendor/cache/hpricot-0.8.2.gem +0 -0
- data/vendor/cache/rack-1.0.1.gem +0 -0
- data/vendor/cache/rails-2.3.5.gem +0 -0
- data/vendor/cache/rake-0.8.7.gem +0 -0
- data/vendor/cache/rubyzip-0.9.1.gem +0 -0
- data/vendor/cache/slim_scrooge-1.0.3.gem +0 -0
- data/vendor/cache/will_paginate-2.3.11.gem +0 -0
- data/vendor/plugins/acts_as_indexed/CHANGELOG +74 -0
- data/vendor/plugins/acts_as_indexed/MIT-LICENSE +20 -0
- data/vendor/plugins/acts_as_indexed/README.rdoc +114 -0
- data/vendor/plugins/acts_as_indexed/Rakefile +35 -0
- data/vendor/plugins/acts_as_indexed/init.rb +2 -0
- data/vendor/plugins/acts_as_indexed/lib/acts_as_indexed.rb +224 -0
- data/vendor/plugins/acts_as_indexed/lib/search_atom.rb +107 -0
- data/vendor/plugins/acts_as_indexed/lib/search_index.rb +329 -0
- data/vendor/plugins/acts_as_indexed/lib/will_paginate_search.rb +29 -0
- data/vendor/plugins/acts_as_indexed/test/abstract_unit.rb +47 -0
- data/vendor/plugins/acts_as_indexed/test/acts_as_indexed_test.rb +102 -0
- data/vendor/plugins/acts_as_indexed/test/database.yml +10 -0
- data/vendor/plugins/acts_as_indexed/test/fixtures/post.rb +5 -0
- data/vendor/plugins/acts_as_indexed/test/fixtures/posts.yml +31 -0
- data/vendor/plugins/acts_as_indexed/test/schema.rb +6 -0
- data/vendor/plugins/acts_as_tree/README +26 -0
- data/vendor/plugins/acts_as_tree/Rakefile +22 -0
- data/vendor/plugins/acts_as_tree/init.rb +1 -0
- data/vendor/plugins/acts_as_tree/lib/active_record/acts/tree.rb +141 -0
- data/vendor/plugins/acts_as_tree/test/abstract_unit.rb +0 -0
- data/vendor/plugins/acts_as_tree/test/acts_as_tree_test.rb +219 -0
- data/vendor/plugins/acts_as_tree/test/database.yml +0 -0
- data/vendor/plugins/acts_as_tree/test/fixtures/mixin.rb +0 -0
- data/vendor/plugins/acts_as_tree/test/fixtures/mixins.yml +0 -0
- data/vendor/plugins/acts_as_tree/test/schema.rb +0 -0
- data/vendor/plugins/attachment_fu/CHANGELOG +35 -0
- data/vendor/plugins/attachment_fu/LICENSE +20 -0
- data/vendor/plugins/attachment_fu/README +193 -0
- data/vendor/plugins/attachment_fu/Rakefile +22 -0
- data/vendor/plugins/attachment_fu/amazon_s3.yml.tpl +17 -0
- data/vendor/plugins/attachment_fu/init.rb +16 -0
- data/vendor/plugins/attachment_fu/install.rb +7 -0
- data/vendor/plugins/attachment_fu/lib/geometry.rb +93 -0
- data/vendor/plugins/attachment_fu/lib/technoweenie/attachment_fu/backends/cloud_file_backend.rb +211 -0
- data/vendor/plugins/attachment_fu/lib/technoweenie/attachment_fu/backends/db_file_backend.rb +39 -0
- data/vendor/plugins/attachment_fu/lib/technoweenie/attachment_fu/backends/file_system_backend.rb +126 -0
- data/vendor/plugins/attachment_fu/lib/technoweenie/attachment_fu/backends/s3_backend.rb +394 -0
- data/vendor/plugins/attachment_fu/lib/technoweenie/attachment_fu/processors/core_image_processor.rb +59 -0
- data/vendor/plugins/attachment_fu/lib/technoweenie/attachment_fu/processors/gd2_processor.rb +54 -0
- data/vendor/plugins/attachment_fu/lib/technoweenie/attachment_fu/processors/image_science_processor.rb +61 -0
- data/vendor/plugins/attachment_fu/lib/technoweenie/attachment_fu/processors/mini_magick_processor.rb +132 -0
- data/vendor/plugins/attachment_fu/lib/technoweenie/attachment_fu/processors/rmagick_processor.rb +57 -0
- data/vendor/plugins/attachment_fu/lib/technoweenie/attachment_fu.rb +514 -0
- data/vendor/plugins/attachment_fu/rackspace_cloudfiles.yml.tpl +14 -0
- data/vendor/plugins/attachment_fu/test/backends/db_file_test.rb +16 -0
- data/vendor/plugins/attachment_fu/test/backends/file_system_test.rb +143 -0
- data/vendor/plugins/attachment_fu/test/backends/remote/cloudfiles_test.rb +102 -0
- data/vendor/plugins/attachment_fu/test/backends/remote/s3_test.rb +119 -0
- data/vendor/plugins/attachment_fu/test/base_attachment_tests.rb +77 -0
- data/vendor/plugins/attachment_fu/test/basic_test.rb +70 -0
- data/vendor/plugins/attachment_fu/test/database.yml +18 -0
- data/vendor/plugins/attachment_fu/test/extra_attachment_test.rb +67 -0
- data/vendor/plugins/attachment_fu/test/fixtures/attachment.rb +226 -0
- data/vendor/plugins/attachment_fu/test/fixtures/files/fake/rails.png +0 -0
- data/vendor/plugins/attachment_fu/test/fixtures/files/foo.txt +1 -0
- data/vendor/plugins/attachment_fu/test/fixtures/files/rails.png +0 -0
- data/vendor/plugins/attachment_fu/test/geometry_test.rb +108 -0
- data/vendor/plugins/attachment_fu/test/processors/core_image_test.rb +37 -0
- data/vendor/plugins/attachment_fu/test/processors/gd2_test.rb +31 -0
- data/vendor/plugins/attachment_fu/test/processors/image_science_test.rb +31 -0
- data/vendor/plugins/attachment_fu/test/processors/mini_magick_test.rb +103 -0
- data/vendor/plugins/attachment_fu/test/processors/rmagick_test.rb +255 -0
- data/vendor/plugins/attachment_fu/test/schema.rb +134 -0
- data/vendor/plugins/attachment_fu/test/test_helper.rb +150 -0
- data/vendor/plugins/attachment_fu/test/validation_test.rb +55 -0
- data/vendor/plugins/attachment_fu/vendor/red_artisan/core_image/filters/color.rb +27 -0
- data/vendor/plugins/attachment_fu/vendor/red_artisan/core_image/filters/effects.rb +31 -0
- data/vendor/plugins/attachment_fu/vendor/red_artisan/core_image/filters/perspective.rb +25 -0
- data/vendor/plugins/attachment_fu/vendor/red_artisan/core_image/filters/quality.rb +25 -0
- data/vendor/plugins/attachment_fu/vendor/red_artisan/core_image/filters/scale.rb +47 -0
- data/vendor/plugins/attachment_fu/vendor/red_artisan/core_image/filters/watermark.rb +32 -0
- data/vendor/plugins/attachment_fu/vendor/red_artisan/core_image/processor.rb +123 -0
- data/vendor/plugins/authentication/README +0 -0
- data/vendor/plugins/authentication/Rakefile +0 -0
- data/vendor/plugins/authentication/app/controllers/admin/users_controller.rb +67 -0
- data/vendor/plugins/authentication/app/controllers/sessions_controller.rb +36 -0
- data/vendor/plugins/authentication/app/controllers/users_controller.rb +101 -0
- data/vendor/plugins/authentication/app/helpers/sessions_helper.rb +2 -0
- data/vendor/plugins/authentication/app/helpers/users_helper.rb +2 -0
- data/vendor/plugins/authentication/app/models/user.rb +154 -0
- data/vendor/plugins/authentication/app/models/user_mailer.rb +18 -0
- data/vendor/plugins/authentication/app/models/user_plugin.rb +5 -0
- data/vendor/plugins/authentication/app/views/admin/users/_form.html.erb +38 -0
- data/vendor/plugins/authentication/app/views/admin/users/edit.html.erb +1 -0
- data/vendor/plugins/authentication/app/views/admin/users/index.html.erb +40 -0
- data/vendor/plugins/authentication/app/views/admin/users/new.html.erb +1 -0
- data/vendor/plugins/authentication/app/views/sessions/new.html.erb +24 -0
- data/vendor/plugins/authentication/app/views/user_mailer/reset_notification.html.erb +6 -0
- data/vendor/plugins/authentication/app/views/users/forgot.html.erb +13 -0
- data/vendor/plugins/authentication/app/views/users/new.html.erb +28 -0
- data/vendor/plugins/authentication/app/views/users/reset.html.erb +18 -0
- data/vendor/plugins/authentication/authentication.md +15 -0
- data/vendor/plugins/authentication/config/routes.rb +15 -0
- data/vendor/plugins/authentication/lib/authenticated_system.rb +115 -0
- data/vendor/plugins/authentication/lib/authenticated_test_helper.rb +10 -0
- data/vendor/plugins/authentication/rails/init.rb +13 -0
- data/vendor/plugins/authentication/test/fixtures/users.yml +19 -0
- data/vendor/plugins/authentication/test/functional/admin/base_controller_test.rb +8 -0
- data/vendor/plugins/authentication/test/functional/admin/dashboard_controller_test.rb +8 -0
- data/vendor/plugins/authentication/test/functional/admin/pages_controller_test.rb +8 -0
- data/vendor/plugins/authentication/test/functional/sessions_controller_test.rb +85 -0
- data/vendor/plugins/authentication/test/functional/users_controller_test.rb +99 -0
- data/vendor/plugins/authentication/test/test_helper.rb +38 -0
- data/vendor/plugins/authentication/test/unit/user_mailer_test.rb +31 -0
- data/vendor/plugins/authentication/test/unit/user_test.rb +164 -0
- data/vendor/plugins/dashboard/app/controllers/admin/dashboard_controller.rb +28 -0
- data/vendor/plugins/dashboard/app/helpers/admin/dashboard_helper.rb +19 -0
- data/vendor/plugins/dashboard/app/views/admin/dashboard/_recent_activity.html.erb +14 -0
- data/vendor/plugins/dashboard/app/views/admin/dashboard/index.html.erb +31 -0
- data/vendor/plugins/dashboard/config/routes.rb +5 -0
- data/vendor/plugins/dashboard/dashboard.md +22 -0
- data/vendor/plugins/dashboard/rails/init.rb +6 -0
- data/vendor/plugins/images/app/controllers/admin/images_controller.rb +98 -0
- data/vendor/plugins/images/app/helpers/admin/images_helper.rb +23 -0
- data/vendor/plugins/images/app/models/image.rb +57 -0
- data/vendor/plugins/images/app/views/admin/images/_form.html.erb +31 -0
- data/vendor/plugins/images/app/views/admin/images/_grid_view.html.erb +16 -0
- data/vendor/plugins/images/app/views/admin/images/_list_view.html.erb +12 -0
- data/vendor/plugins/images/app/views/admin/images/_list_view_image.html.erb +16 -0
- data/vendor/plugins/images/app/views/admin/images/edit.html.erb +1 -0
- data/vendor/plugins/images/app/views/admin/images/index.html.erb +42 -0
- data/vendor/plugins/images/app/views/admin/images/insert.html.erb +50 -0
- data/vendor/plugins/images/app/views/admin/images/new.html.erb +1 -0
- data/vendor/plugins/images/config/routes.rb +5 -0
- data/vendor/plugins/images/images.md +53 -0
- data/vendor/plugins/images/lib/tasks/images.rake +45 -0
- data/vendor/plugins/images/rails/init.rb +14 -0
- data/vendor/plugins/inquiries/app/controllers/admin/inquiries_controller.rb +29 -0
- data/vendor/plugins/inquiries/app/controllers/admin/inquiry_settings_controller.rb +16 -0
- data/vendor/plugins/inquiries/app/controllers/inquiries_controller.rb +41 -0
- data/vendor/plugins/inquiries/app/helpers/inquiries_helper.rb +13 -0
- data/vendor/plugins/inquiries/app/models/inquiry.rb +16 -0
- data/vendor/plugins/inquiries/app/models/inquiry_mailer.rb +20 -0
- data/vendor/plugins/inquiries/app/models/inquiry_setting.rb +11 -0
- data/vendor/plugins/inquiries/app/views/admin/inquiries/_inquiry.html.erb +20 -0
- data/vendor/plugins/inquiries/app/views/admin/inquiries/index.html.erb +43 -0
- data/vendor/plugins/inquiries/app/views/admin/inquiries/show.html.erb +62 -0
- data/vendor/plugins/inquiries/app/views/admin/inquiry_settings/_confirmation_email_form.html.erb +46 -0
- data/vendor/plugins/inquiries/app/views/admin/inquiry_settings/_notification_recipients_form.html.erb +18 -0
- data/vendor/plugins/inquiries/app/views/admin/inquiry_settings/edit.html.erb +5 -0
- data/vendor/plugins/inquiries/app/views/admin/inquiry_settings/index.html.erb +31 -0
- data/vendor/plugins/inquiries/app/views/inquiries/new.html.erb +31 -0
- data/vendor/plugins/inquiries/app/views/inquiries/thank_you.html.erb +1 -0
- data/vendor/plugins/inquiries/app/views/inquiry_mailer/confirmation.html.erb +1 -0
- data/vendor/plugins/inquiries/app/views/inquiry_mailer/notification.html.erb +18 -0
- data/vendor/plugins/inquiries/config/routes.rb +8 -0
- data/vendor/plugins/inquiries/inquiries.md +31 -0
- data/vendor/plugins/inquiries/rails/init.rb +13 -0
- data/vendor/plugins/news/app/controllers/admin/news_items_controller.rb +5 -0
- data/vendor/plugins/news/app/controllers/news_items_controller.rb +20 -0
- data/vendor/plugins/news/app/models/news_item.rb +22 -0
- data/vendor/plugins/news/app/views/admin/news_items/_form.html.erb +19 -0
- data/vendor/plugins/news/app/views/admin/news_items/_news_item.html.erb +15 -0
- data/vendor/plugins/news/app/views/admin/news_items/edit.html.erb +1 -0
- data/vendor/plugins/news/app/views/admin/news_items/index.html.erb +31 -0
- data/vendor/plugins/news/app/views/admin/news_items/new.html.erb +1 -0
- data/vendor/plugins/news/app/views/news_items/_recent_posts.html.erb +8 -0
- data/vendor/plugins/news/app/views/news_items/index.html.erb +17 -0
- data/vendor/plugins/news/app/views/news_items/index.rss.builder +26 -0
- data/vendor/plugins/news/app/views/news_items/show.html.erb +13 -0
- data/vendor/plugins/news/config/routes.rb +7 -0
- data/vendor/plugins/news/news.md +20 -0
- data/vendor/plugins/news/rails/init.rb +11 -0
- data/vendor/plugins/pages/app/controllers/admin/page_dialogs_controller.rb +49 -0
- data/vendor/plugins/pages/app/controllers/admin/page_parts_controller.rb +20 -0
- data/vendor/plugins/pages/app/controllers/admin/pages_controller.rb +18 -0
- data/vendor/plugins/pages/app/controllers/pages_controller.rb +22 -0
- data/vendor/plugins/pages/app/helpers/pages_helper.rb +2 -0
- data/vendor/plugins/pages/app/models/page.rb +162 -0
- data/vendor/plugins/pages/app/models/page_part.rb +10 -0
- data/vendor/plugins/pages/app/presenters/page_presenter.rb +3 -0
- data/vendor/plugins/pages/app/views/admin/page_dialogs/_page_link.html.erb +5 -0
- data/vendor/plugins/pages/app/views/admin/page_dialogs/link_to.html.erb +149 -0
- data/vendor/plugins/pages/app/views/admin/pages/_form.html.erb +140 -0
- data/vendor/plugins/pages/app/views/admin/pages/_list.html.erb +29 -0
- data/vendor/plugins/pages/app/views/admin/pages/_page_part_field.html.erb +4 -0
- data/vendor/plugins/pages/app/views/admin/pages/_sortable_list.html.erb +4 -0
- data/vendor/plugins/pages/app/views/admin/pages/edit.html.erb +1 -0
- data/vendor/plugins/pages/app/views/admin/pages/index.html.erb +41 -0
- data/vendor/plugins/pages/app/views/admin/pages/new.html.erb +1 -0
- data/vendor/plugins/pages/app/views/pages/home.html.erb +1 -0
- data/vendor/plugins/pages/app/views/pages/show.html.erb +1 -0
- data/vendor/plugins/pages/config/routes.rb +11 -0
- data/vendor/plugins/pages/pages.md +146 -0
- data/vendor/plugins/pages/rails/init.rb +13 -0
- data/vendor/plugins/rails_indexes/MIT-LICENSE +20 -0
- data/vendor/plugins/rails_indexes/README.textile +46 -0
- data/vendor/plugins/rails_indexes/Rakefile +23 -0
- data/vendor/plugins/rails_indexes/lib/indexer.rb +305 -0
- data/vendor/plugins/rails_indexes/tasks/indexer.rake +18 -0
- data/vendor/plugins/rails_indexes/test/fixtures/app/controllers/users_controller.rb +8 -0
- data/vendor/plugins/rails_indexes/test/fixtures/app/models/address.rb +5 -0
- data/vendor/plugins/rails_indexes/test/fixtures/app/models/company.rb +11 -0
- data/vendor/plugins/rails_indexes/test/fixtures/app/models/country.rb +4 -0
- data/vendor/plugins/rails_indexes/test/fixtures/app/models/freelancer.rb +3 -0
- data/vendor/plugins/rails_indexes/test/fixtures/app/models/gift.rb +10 -0
- data/vendor/plugins/rails_indexes/test/fixtures/app/models/god.rb +3 -0
- data/vendor/plugins/rails_indexes/test/fixtures/app/models/user.rb +17 -0
- data/vendor/plugins/rails_indexes/test/fixtures/app/sweepers/user_sweeper.rb +9 -0
- data/vendor/plugins/rails_indexes/test/fixtures/schema.rb +46 -0
- data/vendor/plugins/rails_indexes/test/rails_indexes_test.rb +83 -0
- data/vendor/plugins/rails_indexes/test/test_helper.rb +30 -0
- data/vendor/plugins/refinery/app/controllers/admin/refinery_core_controller.rb +14 -0
- data/vendor/plugins/refinery/app/views/admin/_head.html.erb +11 -0
- data/vendor/plugins/refinery/app/views/admin/_menu.html.erb +23 -0
- data/vendor/plugins/refinery/app/views/layouts/admin.html.erb +34 -0
- data/vendor/plugins/refinery/app/views/layouts/application.html.erb +20 -0
- data/vendor/plugins/refinery/app/views/shared/_content_page.html.erb +36 -0
- data/vendor/plugins/refinery/app/views/shared/_footer.html.erb +5 -0
- data/vendor/plugins/refinery/app/views/shared/_google_analytics.html.erb +13 -0
- data/vendor/plugins/refinery/app/views/shared/_head.html.erb +16 -0
- data/vendor/plugins/refinery/app/views/shared/_header.html.erb +4 -0
- data/vendor/plugins/refinery/app/views/shared/_ie6check.html.erb +11 -0
- data/vendor/plugins/refinery/app/views/shared/_menu.html.erb +8 -0
- data/vendor/plugins/refinery/app/views/shared/_menu_branch.html.erb +23 -0
- data/vendor/plugins/refinery/app/views/shared/_message.html.erb +5 -0
- data/vendor/plugins/refinery/app/views/shared/_submenu.html.erb +5 -0
- data/vendor/plugins/refinery/app/views/shared/_submenu_branch.html.erb +10 -0
- data/vendor/plugins/refinery/app/views/shared/admin/_continue_editing.html.erb +4 -0
- data/vendor/plugins/refinery/app/views/shared/admin/_error_messages_for.html.erb +2 -0
- data/vendor/plugins/refinery/app/views/shared/admin/_form_actions.html.erb +13 -0
- data/vendor/plugins/refinery/app/views/shared/admin/_head_before_javascript_libraries.html.erb +0 -0
- data/vendor/plugins/refinery/app/views/shared/admin/_image_picker.html.erb +48 -0
- data/vendor/plugins/refinery/app/views/shared/admin/_make_sortable.html.erb +10 -0
- data/vendor/plugins/refinery/app/views/shared/admin/_resource_picker.html.erb +57 -0
- data/vendor/plugins/refinery/app/views/shared/admin/_search.html.erb +5 -0
- data/vendor/plugins/refinery/app/views/shared/admin/_sortable_list.html.erb +9 -0
- data/vendor/plugins/refinery/app/views/welcome.html.erb +13 -0
- data/vendor/plugins/refinery/app/views/wymiframe.html.erb +8 -0
- data/vendor/plugins/refinery/config/routes.rb +10 -0
- data/vendor/plugins/refinery/crud.md +197 -0
- data/vendor/plugins/refinery/lib/crud.rb +222 -0
- data/vendor/plugins/refinery/lib/generators/refinery/README +29 -0
- data/vendor/plugins/refinery/lib/generators/refinery/Rakefile +12 -0
- data/vendor/plugins/refinery/lib/generators/refinery/USAGE +2 -0
- data/vendor/plugins/refinery/lib/generators/refinery/install.rb +2 -0
- data/vendor/plugins/refinery/lib/generators/refinery/refinery_generator.rb +65 -0
- data/vendor/plugins/refinery/lib/generators/refinery/templates/config/routes.rb +7 -0
- data/vendor/plugins/refinery/lib/generators/refinery/templates/controller.rb +5 -0
- data/vendor/plugins/refinery/lib/generators/refinery/templates/migration.rb +44 -0
- data/vendor/plugins/refinery/lib/generators/refinery/templates/model.rb +9 -0
- data/vendor/plugins/refinery/lib/generators/refinery/templates/public_controller.rb +30 -0
- data/vendor/plugins/refinery/lib/generators/refinery/templates/rails/init.rb +10 -0
- data/vendor/plugins/refinery/lib/generators/refinery/templates/views/admin/_form.html.erb +14 -0
- data/vendor/plugins/refinery/lib/generators/refinery/templates/views/admin/_singular_name.html.erb +15 -0
- data/vendor/plugins/refinery/lib/generators/refinery/templates/views/admin/_sortable_list.html.erb +2 -0
- data/vendor/plugins/refinery/lib/generators/refinery/templates/views/admin/edit.html.erb +1 -0
- data/vendor/plugins/refinery/lib/generators/refinery/templates/views/admin/index.html.erb +42 -0
- data/vendor/plugins/refinery/lib/generators/refinery/templates/views/admin/new.html.erb +1 -0
- data/vendor/plugins/refinery/lib/generators/refinery/templates/views/index.html.erb +11 -0
- data/vendor/plugins/refinery/lib/generators/refinery/templates/views/show.html.erb +25 -0
- data/vendor/plugins/refinery/lib/refinery/activity.rb +37 -0
- data/vendor/plugins/refinery/lib/refinery/admin_base_controller.rb +56 -0
- data/vendor/plugins/refinery/lib/refinery/application_controller.rb +80 -0
- data/vendor/plugins/refinery/lib/refinery/application_helper.rb +112 -0
- data/vendor/plugins/refinery/lib/refinery/attachment_fu_patch.rb +16 -0
- data/vendor/plugins/refinery/lib/refinery/base_presenter.rb +27 -0
- data/vendor/plugins/refinery/lib/refinery/form_helpers.rb +28 -0
- data/vendor/plugins/refinery/lib/refinery/html_truncation_helper.rb +110 -0
- data/vendor/plugins/refinery/lib/refinery/initializer.rb +80 -0
- data/vendor/plugins/refinery/lib/refinery/link_renderer.rb +45 -0
- data/vendor/plugins/refinery/lib/refinery/plugin.rb +47 -0
- data/vendor/plugins/refinery/lib/refinery/plugins.rb +53 -0
- data/vendor/plugins/refinery/lib/refinery.rb +11 -0
- data/vendor/plugins/refinery/lib/tasks/doc.rake +29 -0
- data/vendor/plugins/refinery/lib/tasks/refinery.rake +34 -0
- data/vendor/plugins/refinery/lib/tasks/yard.rake +32 -0
- data/vendor/plugins/refinery/plugins.md +205 -0
- data/vendor/plugins/refinery/rails/init.rb +14 -0
- data/vendor/plugins/refinery_dialogs/app/controllers/admin/dialogs_controller.rb +26 -0
- data/vendor/plugins/refinery_dialogs/app/views/admin/dialogs/show.html.erb +20 -0
- data/vendor/plugins/refinery_dialogs/app/views/layouts/admin_dialog.html.erb +24 -0
- data/vendor/plugins/refinery_dialogs/config/routes.rb +5 -0
- data/vendor/plugins/refinery_dialogs/rails/init.rb +7 -0
- data/vendor/plugins/refinery_settings/app/controllers/admin/refinery_settings_controller.rb +5 -0
- data/vendor/plugins/refinery_settings/app/models/refinery_setting.rb +88 -0
- data/vendor/plugins/refinery_settings/app/views/admin/refinery_settings/_form.html.erb +17 -0
- data/vendor/plugins/refinery_settings/app/views/admin/refinery_settings/_refinery_setting.html.erb +12 -0
- data/vendor/plugins/refinery_settings/app/views/admin/refinery_settings/edit.html.erb +4 -0
- data/vendor/plugins/refinery_settings/app/views/admin/refinery_settings/index.html.erb +27 -0
- data/vendor/plugins/refinery_settings/app/views/admin/refinery_settings/new.html.erb +1 -0
- data/vendor/plugins/refinery_settings/config/routes.rb +5 -0
- data/vendor/plugins/refinery_settings/rails/init.rb +13 -0
- data/vendor/plugins/refinery_settings/settings.md +55 -0
- data/vendor/plugins/resources/app/controllers/admin/resources_controller.rb +94 -0
- data/vendor/plugins/resources/app/models/resource.rb +55 -0
- data/vendor/plugins/resources/app/views/admin/resources/_form.html.erb +33 -0
- data/vendor/plugins/resources/app/views/admin/resources/_resource.html.erb +14 -0
- data/vendor/plugins/resources/app/views/admin/resources/edit.html.erb +1 -0
- data/vendor/plugins/resources/app/views/admin/resources/index.html.erb +41 -0
- data/vendor/plugins/resources/app/views/admin/resources/insert.html.erb +67 -0
- data/vendor/plugins/resources/app/views/admin/resources/new.html.erb +1 -0
- data/vendor/plugins/resources/config/routes.rb +9 -0
- data/vendor/plugins/resources/rails/init.rb +12 -0
- data/vendor/plugins/resources/resources.md +9 -0
- data/vendor/plugins/themes/app/helpers/themes_helper.rb +25 -0
- data/vendor/plugins/themes/lib/theme_server.rb +30 -0
- data/vendor/plugins/themes/rails/init.rb +24 -0
- data/vendor/plugins/themes/themes.md +113 -0
- metadata +625 -0
@@ -0,0 +1,47 @@
|
|
1
|
+
module RedArtisan
|
2
|
+
module CoreImage
|
3
|
+
module Filters
|
4
|
+
module Scale
|
5
|
+
|
6
|
+
def resize(width, height)
|
7
|
+
create_core_image_context(width, height)
|
8
|
+
|
9
|
+
scale_x, scale_y = scale(width, height)
|
10
|
+
|
11
|
+
@original.affine_clamp :inputTransform => OSX::NSAffineTransform.transform do |clamped|
|
12
|
+
clamped.lanczos_scale_transform :inputScale => scale_x > scale_y ? scale_x : scale_y, :inputAspectRatio => scale_x / scale_y do |scaled|
|
13
|
+
scaled.crop :inputRectangle => vector(0, 0, width, height) do |cropped|
|
14
|
+
@target = cropped
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
def thumbnail(width, height)
|
21
|
+
create_core_image_context(width, height)
|
22
|
+
|
23
|
+
transform = OSX::NSAffineTransform.transform
|
24
|
+
transform.scaleXBy_yBy *scale(width, height)
|
25
|
+
|
26
|
+
@original.affine_transform :inputTransform => transform do |scaled|
|
27
|
+
@target = scaled
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
31
|
+
def fit(size)
|
32
|
+
original_size = @original.extent.size
|
33
|
+
scale = size.to_f / (original_size.width > original_size.height ? original_size.width : original_size.height)
|
34
|
+
resize (original_size.width * scale).to_i, (original_size.height * scale).to_i
|
35
|
+
end
|
36
|
+
|
37
|
+
private
|
38
|
+
|
39
|
+
def scale(width, height)
|
40
|
+
original_size = @original.extent.size
|
41
|
+
return width.to_f / original_size.width.to_f, height.to_f / original_size.height.to_f
|
42
|
+
end
|
43
|
+
|
44
|
+
end
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
@@ -0,0 +1,32 @@
|
|
1
|
+
module RedArtisan
|
2
|
+
module CoreImage
|
3
|
+
module Filters
|
4
|
+
module Watermark
|
5
|
+
|
6
|
+
def watermark(watermark_image, tile = false, strength = 0.1)
|
7
|
+
create_core_image_context(@original.extent.size.width, @original.extent.size.height)
|
8
|
+
|
9
|
+
if watermark_image.respond_to? :to_str
|
10
|
+
watermark_image = OSX::CIImage.from(watermark_image.to_str)
|
11
|
+
end
|
12
|
+
|
13
|
+
if tile
|
14
|
+
tile_transform = OSX::NSAffineTransform.transform
|
15
|
+
tile_transform.scaleXBy_yBy 1.0, 1.0
|
16
|
+
|
17
|
+
watermark_image.affine_tile :inputTransform => tile_transform do |tiled|
|
18
|
+
tiled.crop :inputRectangle => vector(0, 0, @original.extent.size.width, @original.extent.size.height) do |tiled_watermark|
|
19
|
+
watermark_image = tiled_watermark
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
@original.dissolve_transition :inputTargetImage => watermark_image, :inputTime => strength do |watermarked|
|
25
|
+
@target = watermarked
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
@@ -0,0 +1,123 @@
|
|
1
|
+
require 'rubygems'
|
2
|
+
require 'osx/cocoa'
|
3
|
+
require 'active_support'
|
4
|
+
|
5
|
+
require 'red_artisan/core_image/filters/scale'
|
6
|
+
require 'red_artisan/core_image/filters/color'
|
7
|
+
require 'red_artisan/core_image/filters/watermark'
|
8
|
+
require 'red_artisan/core_image/filters/quality'
|
9
|
+
require 'red_artisan/core_image/filters/perspective'
|
10
|
+
require 'red_artisan/core_image/filters/effects'
|
11
|
+
|
12
|
+
# Generic image processor for scaling images based on CoreImage via RubyCocoa.
|
13
|
+
#
|
14
|
+
# Example usage:
|
15
|
+
#
|
16
|
+
# p = Processor.new OSX::CIImage.from(path_to_image)
|
17
|
+
# p.resize(640, 480)
|
18
|
+
# p.render do |result|
|
19
|
+
# result.save('resized.jpg', OSX::NSJPEGFileType)
|
20
|
+
# end
|
21
|
+
#
|
22
|
+
# This will resize the image to the given dimensions exactly, if you'd like to ensure that aspect ratio is preserved:
|
23
|
+
#
|
24
|
+
# p = Processor.new OSX::CIImage.from(path_to_image)
|
25
|
+
# p.fit(640)
|
26
|
+
# p.render do |result|
|
27
|
+
# result.save('resized.jpg', OSX::NSJPEGFileType)
|
28
|
+
# end
|
29
|
+
#
|
30
|
+
# fit(size) will attempt its best to resize the image so that the longest width/height (depending on image orientation) will match
|
31
|
+
# the given size. The second axis will be calculated automatically based on the aspect ratio.
|
32
|
+
#
|
33
|
+
# Scaling is performed by first clamping the image so that its external bounds become infinite, this helps when scaling so that any
|
34
|
+
# rounding discrepencies in dimensions don't affect the resultant image. We then perform a Lanczos transform on the image which scales
|
35
|
+
# it to the target size. We then crop the image to the traget dimensions.
|
36
|
+
#
|
37
|
+
# If you are generating smaller images such as thumbnails where high quality rendering isn't as important, an additional method is
|
38
|
+
# available:
|
39
|
+
#
|
40
|
+
# p = Processor.new OSX::CIImage.from(path_to_image)
|
41
|
+
# p.thumbnail(100, 100)
|
42
|
+
# p.render do |result|
|
43
|
+
# result.save('resized.jpg', OSX::NSJPEGFileType)
|
44
|
+
# end
|
45
|
+
#
|
46
|
+
# This will perform a straight affine transform and scale the X and Y boundaries to the requested size. Generally, this will be faster
|
47
|
+
# than a lanczos scale transform, but with a scaling quality trade.
|
48
|
+
#
|
49
|
+
# More than welcome to intregrate any patches, improvements - feel free to mail me with ideas.
|
50
|
+
#
|
51
|
+
# Thanks to
|
52
|
+
# * Satoshi Nakagawa for working out that OCObjWrapper needs inclusion when aliasing method_missing on existing OSX::* classes.
|
53
|
+
# * Vasantha Crabb for general help and inspiration with Cocoa
|
54
|
+
# * Ben Schwarz for example image data and collaboration during performance testing
|
55
|
+
#
|
56
|
+
# Copyright (c) Marcus Crafter <crafterm@redartisan.com> released under the MIT license
|
57
|
+
#
|
58
|
+
module RedArtisan
|
59
|
+
module CoreImage
|
60
|
+
class Processor
|
61
|
+
|
62
|
+
def initialize(original)
|
63
|
+
if original.respond_to? :to_str
|
64
|
+
@original = OSX::CIImage.from(original.to_str)
|
65
|
+
else
|
66
|
+
@original = original
|
67
|
+
end
|
68
|
+
end
|
69
|
+
|
70
|
+
def render(&block)
|
71
|
+
raise "unprocessed image: #{@original}" unless @target
|
72
|
+
block.call @target
|
73
|
+
end
|
74
|
+
|
75
|
+
include Filters::Scale, Filters::Color, Filters::Watermark, Filters::Quality, Filters::Perspective, Filters::Effects
|
76
|
+
|
77
|
+
private
|
78
|
+
|
79
|
+
def create_core_image_context(width, height)
|
80
|
+
output = OSX::NSBitmapImageRep.alloc.initWithBitmapDataPlanes_pixelsWide_pixelsHigh_bitsPerSample_samplesPerPixel_hasAlpha_isPlanar_colorSpaceName_bytesPerRow_bitsPerPixel(nil, width, height, 8, 4, true, false, OSX::NSDeviceRGBColorSpace, 0, 0)
|
81
|
+
context = OSX::NSGraphicsContext.graphicsContextWithBitmapImageRep(output)
|
82
|
+
OSX::NSGraphicsContext.setCurrentContext(context)
|
83
|
+
@ci_context = context.CIContext
|
84
|
+
end
|
85
|
+
|
86
|
+
def vector(x, y, w, h)
|
87
|
+
OSX::CIVector.vectorWithX_Y_Z_W(x, y, w, h)
|
88
|
+
end
|
89
|
+
end
|
90
|
+
end
|
91
|
+
end
|
92
|
+
|
93
|
+
module OSX
|
94
|
+
class CIImage
|
95
|
+
include OCObjWrapper
|
96
|
+
|
97
|
+
def method_missing_with_filter_processing(sym, *args, &block)
|
98
|
+
f = OSX::CIFilter.filterWithName("CI#{sym.to_s.camelize}")
|
99
|
+
return method_missing_without_filter_processing(sym, *args, &block) unless f
|
100
|
+
|
101
|
+
f.setDefaults if f.respond_to? :setDefaults
|
102
|
+
f.setValue_forKey(self, 'inputImage')
|
103
|
+
options = args.last.is_a?(Hash) ? args.last : {}
|
104
|
+
options.each { |k, v| f.setValue_forKey(v, k.to_s) }
|
105
|
+
|
106
|
+
block.call f.valueForKey('outputImage')
|
107
|
+
end
|
108
|
+
|
109
|
+
alias_method_chain :method_missing, :filter_processing
|
110
|
+
|
111
|
+
def save(target, format = OSX::NSJPEGFileType, properties = nil)
|
112
|
+
bitmapRep = OSX::NSBitmapImageRep.alloc.initWithCIImage(self)
|
113
|
+
blob = bitmapRep.representationUsingType_properties(format, properties)
|
114
|
+
blob.writeToFile_atomically(target, false)
|
115
|
+
end
|
116
|
+
|
117
|
+
def self.from(filepath)
|
118
|
+
raise Errno::ENOENT, "No such file or directory - #{filepath}" unless File.exists?(filepath)
|
119
|
+
OSX::CIImage.imageWithContentsOfURL(OSX::NSURL.fileURLWithPath(filepath))
|
120
|
+
end
|
121
|
+
end
|
122
|
+
end
|
123
|
+
|
File without changes
|
File without changes
|
@@ -0,0 +1,67 @@
|
|
1
|
+
class Admin::UsersController < Admin::BaseController
|
2
|
+
|
3
|
+
crudify :user, :order => 'login', :title_attribute => 'login', :conditions => "state = 'active'"
|
4
|
+
|
5
|
+
# Protect these actions behind an admin login
|
6
|
+
before_filter :find_user, :except => [:new, :create]
|
7
|
+
before_filter :load_available_plugins, :only => [:new, :create, :edit, :update]
|
8
|
+
|
9
|
+
filter_parameter_logging 'password', 'password_confirmation'
|
10
|
+
|
11
|
+
layout 'admin'
|
12
|
+
|
13
|
+
def new
|
14
|
+
@user = User.new
|
15
|
+
@selected_plugin_titles = []
|
16
|
+
end
|
17
|
+
|
18
|
+
def create
|
19
|
+
@user = User.new(params[:user])
|
20
|
+
@selected_plugin_titles = params[:user][:plugins] || []
|
21
|
+
|
22
|
+
if @user.save
|
23
|
+
@user.plugins = @selected_plugin_titles
|
24
|
+
@user.register!
|
25
|
+
@user.activate!
|
26
|
+
flash[:notice] = "'#{@user.login}' was successfully created."
|
27
|
+
redirect_to :action => 'index'
|
28
|
+
else
|
29
|
+
render :action => 'new'
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
def edit
|
34
|
+
@user = User.find params[:id]
|
35
|
+
@selected_plugin_titles = @user.plugins.collect{|p| p.title}
|
36
|
+
end
|
37
|
+
|
38
|
+
def update
|
39
|
+
@selected_plugin_titles = params[:user][:plugins]
|
40
|
+
# Prevent the current user from locking themselves out of the User manager
|
41
|
+
if current_user.id == @user.id and !params[:user][:plugins].include?("Users")
|
42
|
+
flash.now[:error] = "You cannot remove the 'Users' plugin from the currently logged in account."
|
43
|
+
render :action => "edit"
|
44
|
+
else
|
45
|
+
@previously_selected_plugins_titles = @user.plugins.collect{|p| p.title}
|
46
|
+
if @user.update_attributes params[:user]
|
47
|
+
flash[:notice] = "'#{@user.login}' was successfully updated."
|
48
|
+
redirect_to admin_users_url
|
49
|
+
else
|
50
|
+
@user.plugins = @previously_selected_plugins_titles
|
51
|
+
@user.save
|
52
|
+
render :action => 'edit'
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
56
|
+
|
57
|
+
protected
|
58
|
+
|
59
|
+
def can_create_public_user
|
60
|
+
User.count == 0
|
61
|
+
end
|
62
|
+
|
63
|
+
def load_available_plugins
|
64
|
+
@available_plugins = Refinery::Plugins.registered.in_menu.titles.sort
|
65
|
+
end
|
66
|
+
|
67
|
+
end
|
@@ -0,0 +1,36 @@
|
|
1
|
+
class SessionsController < ApplicationController
|
2
|
+
|
3
|
+
layout 'admin'
|
4
|
+
filter_parameter_logging 'password', 'password_confirmation'
|
5
|
+
|
6
|
+
def create
|
7
|
+
self.current_user = User.authenticate(params[:session][:login], params[:session][:password])
|
8
|
+
|
9
|
+
if logged_in?
|
10
|
+
if params[:session][:remember_me] == "1"
|
11
|
+
current_user.remember_me unless current_user.remember_token?
|
12
|
+
cookies[:auth_token] = {:value => self.current_user.remember_token ,
|
13
|
+
:expires => self.current_user.remember_token_expires_at}
|
14
|
+
end
|
15
|
+
|
16
|
+
redirect_back_or_default(admin_root_url)
|
17
|
+
flash[:notice] = "Logged in successfully"
|
18
|
+
else
|
19
|
+
flash.now[:error] = "Sorry, your password or username was incorrect."
|
20
|
+
render :action => 'new'
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
def destroy
|
25
|
+
self.current_user.forget_me if logged_in?
|
26
|
+
cookies.delete :auth_token
|
27
|
+
reset_session
|
28
|
+
flash[:notice] = "You have been logged out."
|
29
|
+
redirect_back_or_default(new_session_url)
|
30
|
+
end
|
31
|
+
|
32
|
+
protected
|
33
|
+
|
34
|
+
def take_down_for_maintenance?;end
|
35
|
+
|
36
|
+
end
|
@@ -0,0 +1,101 @@
|
|
1
|
+
class UsersController < ApplicationController
|
2
|
+
|
3
|
+
# Protect these actions behind an admin login
|
4
|
+
before_filter :find_user, :only => [:suspend, :unsuspend, :destroy, :purge]
|
5
|
+
|
6
|
+
filter_parameter_logging 'password', 'password_confirmation'
|
7
|
+
|
8
|
+
layout 'admin'
|
9
|
+
|
10
|
+
def new
|
11
|
+
render :text => "User signup is disabled", :layout => true unless can_create_public_user
|
12
|
+
end
|
13
|
+
|
14
|
+
def create
|
15
|
+
unless can_create_public_user
|
16
|
+
render :text => "User signup is disabled", :layout => true
|
17
|
+
else
|
18
|
+
begin
|
19
|
+
cookies.delete :auth_token
|
20
|
+
# protects against session fixation attacks, wreaks havoc with
|
21
|
+
# request forgery protection.
|
22
|
+
# uncomment at your own risk
|
23
|
+
# reset_session
|
24
|
+
@user = User.new(params[:user])
|
25
|
+
@selected_plugin_titles = params[:user][:plugins] || []
|
26
|
+
|
27
|
+
@user.register! if @user.valid?
|
28
|
+
if @user.errors.empty?
|
29
|
+
@user.plugins = @selected_plugin_titles
|
30
|
+
self.current_user = @user
|
31
|
+
current_user.activate!
|
32
|
+
current_user.update_attribute(:superuser, true) if User.count == 1 # this is the superuser if this user is the only user.
|
33
|
+
redirect_back_or_default(admin_root_url)
|
34
|
+
flash[:notice] = "Welcome to Refinery, #{current_user.login}."
|
35
|
+
|
36
|
+
if User.count == 1 or RefinerySetting[:site_name] == "Company Name"
|
37
|
+
refinery_setting = RefinerySetting.find_by_name("site_name")
|
38
|
+
flash[:notice] << "<br/>First let's give the site a name. <a href='#{edit_admin_refinery_setting_url(refinery_setting)}'>Go here</a> to edit your website's name"
|
39
|
+
end
|
40
|
+
else
|
41
|
+
render :action => 'new'
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
def activate
|
48
|
+
self.current_user = params[:activation_code].blank? ? false : User.find_by_activation_code(params[:activation_code])
|
49
|
+
|
50
|
+
if logged_in? && !current_user.active?
|
51
|
+
current_user.activate!
|
52
|
+
flash[:notice] = "Signup complete!"
|
53
|
+
end
|
54
|
+
|
55
|
+
redirect_back_or_default(root_url)
|
56
|
+
end
|
57
|
+
|
58
|
+
def forgot
|
59
|
+
if request.post?
|
60
|
+
if (user = User.find_by_email(params[:user][:email])).present?
|
61
|
+
user.create_reset_code
|
62
|
+
|
63
|
+
begin
|
64
|
+
flash[:notice] = "An email has been sent to #{user.email} with a link to reset your password."
|
65
|
+
UserMailer.deliver_reset_notification(user, request)
|
66
|
+
rescue
|
67
|
+
logger.info "Error: email could not be sent for user password reset for user #{user.id} with email #{user.email}"
|
68
|
+
end
|
69
|
+
else
|
70
|
+
flash[:notice] = "Sorry, #{params[:user][:email]} isn't associated with any accounts. Are you sure you typed the correct email address?"
|
71
|
+
end
|
72
|
+
|
73
|
+
redirect_back_or_default(forgot_url)
|
74
|
+
end
|
75
|
+
end
|
76
|
+
|
77
|
+
def reset
|
78
|
+
@user = User.find_by_reset_code(params[:reset_code]) unless params[:reset_code].nil?
|
79
|
+
|
80
|
+
if request.post?
|
81
|
+
if @user.update_attributes(:password => params[:user][:password], :password_confirmation => params[:user][:password_confirmation])
|
82
|
+
self.current_user = @user
|
83
|
+
@user.delete_reset_code
|
84
|
+
|
85
|
+
flash[:notice] = "Password reset successfully for #{@user.email}"
|
86
|
+
redirect_back_or_default(admin_root_url)
|
87
|
+
else
|
88
|
+
render :action => :reset
|
89
|
+
end
|
90
|
+
end
|
91
|
+
end
|
92
|
+
|
93
|
+
protected
|
94
|
+
|
95
|
+
def take_down_for_maintenance?;end
|
96
|
+
|
97
|
+
def can_create_public_user
|
98
|
+
User.count == 0
|
99
|
+
end
|
100
|
+
|
101
|
+
end
|
@@ -0,0 +1,154 @@
|
|
1
|
+
require 'digest/sha1'
|
2
|
+
|
3
|
+
class User < ActiveRecord::Base
|
4
|
+
|
5
|
+
# Hack: Allow "rake gems:install" to run when this class is missing its gem dependency.
|
6
|
+
# For further clarification on why, refer to:
|
7
|
+
# https://rails.lighthouseapp.com/projects/8994/tickets/780-rake-gems-install-doesn-t-work-if-plugins-are-missing-gem-dependencies
|
8
|
+
if defined? AASM
|
9
|
+
include AASM # include the library which will give us state machine functionality.
|
10
|
+
aasm_column :state
|
11
|
+
aasm_initial_state :pending
|
12
|
+
aasm_state :passive
|
13
|
+
aasm_state :pending, :enter => :make_activation_code
|
14
|
+
aasm_state :active, :enter => :do_activate
|
15
|
+
|
16
|
+
aasm_event :register do
|
17
|
+
transitions :from => :passive, :to => :pending, :guard => Proc.new {|u| !(u.crypted_password.blank? && u.password.blank?) }
|
18
|
+
end
|
19
|
+
|
20
|
+
aasm_event :activate do
|
21
|
+
transitions :from => :pending, :to => :active
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
# Virtual attribute for the unencrypted password
|
26
|
+
attr_accessor :password
|
27
|
+
|
28
|
+
#validates_presence_of :login, :email # handled by other checks
|
29
|
+
#validates_presence_of :password, :if => :password_required? # handled by other checks
|
30
|
+
validates_presence_of :password_confirmation, :if => :password_required?
|
31
|
+
validates_length_of :password, :within => 4..40, :if => :password_required?
|
32
|
+
validates_confirmation_of :password, :if => :password_required?
|
33
|
+
validates_length_of :login, :within => 3..40
|
34
|
+
validates_length_of :email, :within => 3..100
|
35
|
+
validates_uniqueness_of :login, :email, :case_sensitive => false
|
36
|
+
before_save :encrypt_password
|
37
|
+
|
38
|
+
serialize :plugins_column # Array # this is seriously deprecated and will be removed later.
|
39
|
+
|
40
|
+
has_many :plugins, :class_name => "UserPlugin", :order => "position ASC"
|
41
|
+
|
42
|
+
# prevents a user from submitting a crafted form that bypasses activation
|
43
|
+
# anything else you want your user to change should be added here.
|
44
|
+
attr_accessible :login, :email, :password, :password_confirmation, :plugins, :reset_code
|
45
|
+
|
46
|
+
# Authenticates a user by their login name and unencrypted password. Returns the user or nil.
|
47
|
+
def self.authenticate(login, password)
|
48
|
+
u = find_in_state :first, :active, :conditions => {:login => login} # need to get the salt
|
49
|
+
u && u.authenticated?(password) ? u : nil
|
50
|
+
end
|
51
|
+
|
52
|
+
# Encrypts some data with the salt.
|
53
|
+
def self.encrypt(password, salt)
|
54
|
+
Digest::SHA1.hexdigest("--#{salt}--#{password}--")
|
55
|
+
end
|
56
|
+
|
57
|
+
# Encrypts the password with the user salt
|
58
|
+
def encrypt(password)
|
59
|
+
self.class.encrypt(password, salt)
|
60
|
+
end
|
61
|
+
|
62
|
+
def authenticated?(password)
|
63
|
+
crypted_password == encrypt(password)
|
64
|
+
end
|
65
|
+
|
66
|
+
def plugins=(plugin_titles)
|
67
|
+
unless self.new_record? # don't add plugins when the user_id is NULL.
|
68
|
+
self.plugins.delete_all
|
69
|
+
|
70
|
+
plugin_titles.each do |plugin_title|
|
71
|
+
self.plugins.find_or_create_by_title(plugin_title) if plugin_title.is_a?(String)
|
72
|
+
end
|
73
|
+
end
|
74
|
+
end
|
75
|
+
|
76
|
+
def authorized_plugins
|
77
|
+
self.plugins.collect {|p| p.title} | Refinery::Plugins.always_allowed.titles
|
78
|
+
end
|
79
|
+
|
80
|
+
def remember_token?
|
81
|
+
remember_token_expires_at && Time.now.utc < remember_token_expires_at
|
82
|
+
end
|
83
|
+
|
84
|
+
# These create and unset the fields required for remembering users between browser closes
|
85
|
+
def remember_me
|
86
|
+
remember_me_for 2.weeks
|
87
|
+
end
|
88
|
+
|
89
|
+
def remember_me_for(time)
|
90
|
+
remember_me_until time.from_now.utc
|
91
|
+
end
|
92
|
+
|
93
|
+
def remember_me_until(time)
|
94
|
+
self.remember_token_expires_at = time
|
95
|
+
self.remember_token = encrypt("#{email}--#{remember_token_expires_at}")
|
96
|
+
save(false)
|
97
|
+
end
|
98
|
+
|
99
|
+
def forget_me
|
100
|
+
self.remember_token_expires_at = nil
|
101
|
+
self.remember_token = nil
|
102
|
+
save(false)
|
103
|
+
end
|
104
|
+
|
105
|
+
# Returns true if the user has just been activated.
|
106
|
+
def recently_activated?
|
107
|
+
@activated
|
108
|
+
end
|
109
|
+
|
110
|
+
def ui_deletable?(current_user = self)
|
111
|
+
!self.superuser and User.count > 1 and (current_user.nil? or self.id != current_user.id)
|
112
|
+
end
|
113
|
+
|
114
|
+
def create_reset_code
|
115
|
+
@reset = true
|
116
|
+
code = Digest::SHA1.hexdigest( Time.now.to_s.split(//).sort_by {rand}.join )
|
117
|
+
self.attributes = {:reset_code => code[0..6]}
|
118
|
+
save(false)
|
119
|
+
end
|
120
|
+
|
121
|
+
def recently_reset?
|
122
|
+
@reset
|
123
|
+
end
|
124
|
+
|
125
|
+
def delete_reset_code
|
126
|
+
self.attributes = {:reset_code => nil}
|
127
|
+
save(false)
|
128
|
+
end
|
129
|
+
|
130
|
+
protected
|
131
|
+
|
132
|
+
# before filter
|
133
|
+
def encrypt_password
|
134
|
+
return if password.blank?
|
135
|
+
self.salt = Digest::SHA1.hexdigest("--#{Time.now.to_s}--#{login}--") if new_record?
|
136
|
+
self.crypted_password = encrypt(password)
|
137
|
+
end
|
138
|
+
|
139
|
+
def password_required?
|
140
|
+
crypted_password.blank? || !password.blank?
|
141
|
+
end
|
142
|
+
|
143
|
+
def make_activation_code
|
144
|
+
self.deleted_at = nil
|
145
|
+
self.activation_code = Digest::SHA1.hexdigest( Time.now.to_s.split(//).sort_by {rand}.join )
|
146
|
+
end
|
147
|
+
|
148
|
+
def do_activate
|
149
|
+
@activated = true
|
150
|
+
self.activated_at = Time.now.utc
|
151
|
+
self.deleted_at = self.activation_code = nil
|
152
|
+
end
|
153
|
+
|
154
|
+
end
|