Permalink
Browse files

first commit

  • Loading branch information...
Daniel Croak
Daniel Croak committed Jul 1, 2009
0 parents commit fe3e01fb9f48616839ee47493e56468cbd37c487
Showing with 11,799 additions and 0 deletions.
  1. +4 −0 .gems
  2. +10 −0 .gitignore
  3. +3 −0 Capfile
  4. +10 −0 Rakefile
  5. +9 −0 app/controllers/application_controller.rb
  6. +5 −0 app/helpers/application_helper.rb
  7. 0 app/models/.keep
  8. +5 −0 app/views/layouts/_flashes.html.erb
  9. +2 −0 app/views/layouts/_javascript.html.erb
  10. +14 −0 app/views/layouts/application.html.erb
  11. +110 −0 config/boot.rb
  12. +23 −0 config/database.yml
  13. +37 −0 config/environment.rb
  14. +19 −0 config/environments/development.rb
  15. +18 −0 config/environments/production.rb
  16. +12 −0 config/environments/staging.rb
  17. +30 −0 config/environments/test.rb
  18. +6 −0 config/initializers/action_mailer_configs.rb
  19. +11 −0 config/initializers/backtrace_silencers.rb
  20. +30 −0 config/initializers/bigdecimal-segfault-fix.rb
  21. +26 −0 config/initializers/errors.rb
  22. +3 −0 config/initializers/hoptoad.rb
  23. +10 −0 config/initializers/inflections.rb
  24. +5 −0 config/initializers/mime_types.rb
  25. +10 −0 config/initializers/mocks.rb
  26. +19 −0 config/initializers/new_rails_defaults.rb
  27. +5 −0 config/initializers/noisy_attr_accessible.rb
  28. +9 −0 config/initializers/requires.rb
  29. +15 −0 config/initializers/session_store.rb
  30. +5 −0 config/initializers/time_formats.rb
  31. +29 −0 config/routes.rb
  32. 0 db/bootstrap/.keep
  33. 0 db/migrate/.keep
  34. +2 −0 doc/README_FOR_APP
  35. +97 −0 doc/README_FOR_TEMPLATE
  36. +96 −0 lib/tasks/capistrano.rake
  37. 0 log/.keep
  38. +40 −0 public/.htaccess
  39. +30 −0 public/404.html
  40. +30 −0 public/422.html
  41. +30 −0 public/500.html
  42. +10 −0 public/dispatch.rb
  43. 0 public/favicon.ico
  44. +2 −0 public/javascripts/application.js
  45. +136 −0 public/javascripts/builder.js
  46. +963 −0 public/javascripts/controls.js
  47. +973 −0 public/javascripts/dragdrop.js
  48. +1,128 −0 public/javascripts/effects.js
  49. +4,320 −0 public/javascripts/prototype.js
  50. +58 −0 public/javascripts/scriptaculous.js
  51. +277 −0 public/javascripts/slider.js
  52. +60 −0 public/javascripts/sound.js
  53. +1 −0 public/robots.txt
  54. 0 public/stylesheets/.keep
  55. 0 public/stylesheets/screen.css
  56. +3 −0 script/about
  57. +3 −0 script/breakpointer
  58. +3 −0 script/console
  59. +59 −0 script/create_project
  60. +3 −0 script/dbconsole
  61. +3 −0 script/destroy
  62. +3 −0 script/generate
  63. +3 −0 script/performance/benchmarker
  64. +3 −0 script/performance/profiler
  65. +3 −0 script/performance/request
  66. +3 −0 script/plugin
  67. +3 −0 script/process/inspector
  68. +3 −0 script/process/reaper
  69. +3 −0 script/process/spawner
  70. +3 −0 script/runner
  71. +3 −0 script/server
  72. 0 test/factories.rb
  73. 0 test/functional/.keep
  74. 0 test/integration/.keep
  75. 0 test/mocks/development/.keep
  76. 0 test/mocks/test/.keep
  77. +87 −0 test/shoulda_macros/forms.rb
  78. +48 −0 test/shoulda_macros/pagination.rb
  79. +29 −0 test/test_helper.rb
  80. 0 test/unit/.keep
  81. +55 −0 vendor/plugins/hoptoad_notifier/INSTALL
  82. +22 −0 vendor/plugins/hoptoad_notifier/MIT-LICENSE
  83. +185 −0 vendor/plugins/hoptoad_notifier/README
  84. +30 −0 vendor/plugins/hoptoad_notifier/Rakefile
  85. +21 −0 vendor/plugins/hoptoad_notifier/ginger_scenarios.rb
  86. +21 −0 vendor/plugins/hoptoad_notifier/hoptoad_notifier.gemspec
  87. +1 −0 vendor/plugins/hoptoad_notifier/install.rb
  88. +366 −0 vendor/plugins/hoptoad_notifier/lib/hoptoad_notifier.rb
  89. +26 −0 vendor/plugins/hoptoad_notifier/lib/hoptoad_tasks.rb
  90. +21 −0 vendor/plugins/hoptoad_notifier/recipes/hoptoad.rb
  91. +28 −0 vendor/plugins/hoptoad_notifier/script/integration_test.rb
  92. +66 −0 vendor/plugins/hoptoad_notifier/tasks/hoptoad_notifier_tasks.rake
  93. +145 −0 vendor/plugins/hoptoad_notifier/test/configuration_test.rb
  94. +366 −0 vendor/plugins/hoptoad_notifier/test/controller_test.rb
  95. +66 −0 vendor/plugins/hoptoad_notifier/test/helper.rb
  96. +131 −0 vendor/plugins/hoptoad_notifier/test/hoptoad_tasks_test.rb
  97. +179 −0 vendor/plugins/hoptoad_notifier/test/notifier_test.rb
  98. +1 −0 vendor/plugins/hoptoad_notifier/vendor/ginger/.gitignore
  99. +20 −0 vendor/plugins/hoptoad_notifier/vendor/ginger/LICENCE
  100. +50 −0 vendor/plugins/hoptoad_notifier/vendor/ginger/README.textile
  101. +57 −0 vendor/plugins/hoptoad_notifier/vendor/ginger/Rakefile
  102. +42 −0 vendor/plugins/hoptoad_notifier/vendor/ginger/bin/ginger
  103. +33 −0 vendor/plugins/hoptoad_notifier/vendor/ginger/ginger.gemspec
  104. +21 −0 vendor/plugins/hoptoad_notifier/vendor/ginger/lib/ginger.rb
  105. +20 −0 vendor/plugins/hoptoad_notifier/vendor/ginger/lib/ginger/configuration.rb
  106. +56 −0 vendor/plugins/hoptoad_notifier/vendor/ginger/lib/ginger/kernel.rb
  107. +24 −0 vendor/plugins/hoptoad_notifier/vendor/ginger/lib/ginger/scenario.rb
  108. +7 −0 vendor/plugins/hoptoad_notifier/vendor/ginger/spec/ginger/configuration_spec.rb
  109. +7 −0 vendor/plugins/hoptoad_notifier/vendor/ginger/spec/ginger/kernel_spec.rb
  110. +50 −0 vendor/plugins/hoptoad_notifier/vendor/ginger/spec/ginger/scenario_spec.rb
  111. +14 −0 vendor/plugins/hoptoad_notifier/vendor/ginger/spec/ginger_spec.rb
  112. +7 −0 vendor/plugins/hoptoad_notifier/vendor/ginger/spec/spec_helper.rb
  113. +20 −0 vendor/plugins/limerick_rake/MIT-LICENSE
  114. +140 −0 vendor/plugins/limerick_rake/README.textile
  115. +2 −0 vendor/plugins/limerick_rake/Rakefile
  116. +91 −0 vendor/plugins/limerick_rake/lib/find_mass_assignment.rb
  117. +20 −0 vendor/plugins/limerick_rake/limerick_rake.gemspec
  118. +39 −0 vendor/plugins/limerick_rake/tasks/backup.rake
  119. +14 −0 vendor/plugins/limerick_rake/tasks/coverage.rake
  120. +15 −0 vendor/plugins/limerick_rake/tasks/db/bootstrap.rake
  121. +22 −0 vendor/plugins/limerick_rake/tasks/db/indexes.rake
  122. +23 −0 vendor/plugins/limerick_rake/tasks/db/shell.rake
  123. +27 −0 vendor/plugins/limerick_rake/tasks/db/validate_models.rake
  124. +5 −0 vendor/plugins/limerick_rake/tasks/find_mass_assignment_tasks.rake
  125. +109 −0 vendor/plugins/limerick_rake/tasks/git.rake
  126. +78 −0 vendor/plugins/limerick_rake/tasks/haml_sass.rake
  127. +20 −0 vendor/plugins/limerick_rake/tasks/rails_two.rake
  128. +21 −0 vendor/plugins/limerick_rake/tasks/svn.rake
4 .gems
@@ -0,0 +1,4 @@
+thoughtbot-clearance --version '>= 0.6.8' --source gems.github.com
+RedCloth --version '= 3.0.4'
+mislav-will_paginate --version '~> 2.3.11' --source gems.github.com
+
@@ -0,0 +1,10 @@
+log/*
+tmp/**/*
+db/schema.rb
+db/*.sqlite3
+public/system
+*.DS_Store
+coverage/*
+*.swp
+
+!.keep
@@ -0,0 +1,3 @@
+load 'deploy' if respond_to?(:namespace) # cap2 differentiator
+Dir['vendor/plugins/*/recipes/*.rb'].each { |plugin| load(plugin) }
+load 'config/deploy'
@@ -0,0 +1,10 @@
+# Add your own tasks in files placed in lib/tasks ending in .rake,
+# for example lib/tasks/capistrano.rake, and they will automatically be available to Rake.
+
+require(File.join(File.dirname(__FILE__), 'config', 'boot'))
+
+require 'rake'
+require 'rake/testtask'
+require 'rake/rdoctask'
+
+require 'tasks/rails'
@@ -0,0 +1,9 @@
+class ApplicationController < ActionController::Base
+
+ helper :all
+
+ protect_from_forgery
+
+ include HoptoadNotifier::Catcher
+
+end
@@ -0,0 +1,5 @@
+module ApplicationHelper
+ def body_class
+ "#{controller.controller_name} #{controller.controller_name}-#{controller.action_name}"
+ end
+end
No changes.
@@ -0,0 +1,5 @@
+<div id="flash">
+ <% flash.each do |key, value| -%>
+ <div id="flash_<%= key %>"><%=h value %></div>
+ <% end -%>
+</div>
@@ -0,0 +1,2 @@
+<%= javascript_include_tag :defaults, :cache => true %>
+<%= yield :javascript %>
@@ -0,0 +1,14 @@
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
+ <head>
+ <meta http-equiv="Content-type" content="text/html; charset=utf-8" />
+ <title>CHANGEME</title>
+ <%= stylesheet_link_tag 'screen', :media => 'all', :cache => true %>
+ </head>
+ <body class="<%= body_class %>">
+ <%= render :partial => 'layouts/flashes' -%>
+ <%= yield %>
+ <%= render :partial => 'layouts/javascript' %>
+ </body>
+</html>
@@ -0,0 +1,110 @@
+# Don't change this file!
+# Configure your app in config/environment.rb and config/environments/*.rb
+
+RAILS_ROOT = "#{File.dirname(__FILE__)}/.." unless defined?(RAILS_ROOT)
+
+module Rails
+ class << self
+ def boot!
+ unless booted?
+ preinitialize
+ pick_boot.run
+ end
+ end
+
+ def booted?
+ defined? Rails::Initializer
+ end
+
+ def pick_boot
+ (vendor_rails? ? VendorBoot : GemBoot).new
+ end
+
+ def vendor_rails?
+ File.exist?("#{RAILS_ROOT}/vendor/rails")
+ end
+
+ def preinitialize
+ load(preinitializer_path) if File.exist?(preinitializer_path)
+ end
+
+ def preinitializer_path
+ "#{RAILS_ROOT}/config/preinitializer.rb"
+ end
+ end
+
+ class Boot
+ def run
+ load_initializer
+ Rails::Initializer.run(:set_load_path)
+ end
+ end
+
+ class VendorBoot < Boot
+ def load_initializer
+ require "#{RAILS_ROOT}/vendor/rails/railties/lib/initializer"
+ Rails::Initializer.run(:install_gem_spec_stubs)
+ Rails::GemDependency.add_frozen_gem_path
+ end
+ end
+
+ class GemBoot < Boot
+ def load_initializer
+ self.class.load_rubygems
+ load_rails_gem
+ require 'initializer'
+ end
+
+ def load_rails_gem
+ if version = self.class.gem_version
+ gem 'rails', version
+ else
+ gem 'rails'
+ end
+ rescue Gem::LoadError => load_error
+ $stderr.puts %(Missing the Rails #{version} gem. Please `gem install -v=#{version} rails`, update your RAILS_GEM_VERSION setting in config/environment.rb for the Rails version you do have installed, or comment out RAILS_GEM_VERSION to use the latest version installed.)
+ exit 1
+ end
+
+ class << self
+ def rubygems_version
+ Gem::RubyGemsVersion rescue nil
+ end
+
+ def gem_version
+ if defined? RAILS_GEM_VERSION
+ RAILS_GEM_VERSION
+ elsif ENV.include?('RAILS_GEM_VERSION')
+ ENV['RAILS_GEM_VERSION']
+ else
+ parse_gem_version(read_environment_rb)
+ end
+ end
+
+ def load_rubygems
+ require 'rubygems'
+ min_version = '1.3.1'
+ unless rubygems_version >= min_version
+ $stderr.puts %Q(Rails requires RubyGems >= #{min_version} (you have #{rubygems_version}). Please `gem update --system` and try again.)
+ exit 1
+ end
+
+ rescue LoadError
+ $stderr.puts %Q(Rails requires RubyGems >= #{min_version}. Please install RubyGems and try again: http://rubygems.rubyforge.org)
+ exit 1
+ end
+
+ def parse_gem_version(text)
+ $1 if text =~ /^[^#]*RAILS_GEM_VERSION\s*=\s*["']([!~<>=]*\s*[\d.]+)["']/
+ end
+
+ private
+ def read_environment_rb
+ File.read("#{RAILS_ROOT}/config/environment.rb")
+ end
+ end
+ end
+end
+
+# All that for this:
+Rails.boot!
@@ -0,0 +1,23 @@
+# SQLite version 3.x
+# gem install sqlite3-ruby (not necessary on OS X Leopard)
+development:
+ adapter: sqlite3
+ database: db/development.sqlite3
+ pool: 5
+ timeout: 5000
+
+# Warning: The database defined as "test" will be erased and
+# re-generated from your development database when you run "rake".
+# Do not set this db to the same as development or production.
+test:
+ adapter: sqlite3
+ database: db/test.sqlite3
+ pool: 5
+ timeout: 5000
+
+production:
+ adapter: sqlite3
+ database: db/production.sqlite3
+ pool: 5
+ timeout: 5000
+
@@ -0,0 +1,37 @@
+# Be sure to restart your server when you modify this file
+
+# Specifies gem version of Rails to use when vendor/rails is not present
+RAILS_GEM_VERSION = '2.3.2' unless defined? RAILS_GEM_VERSION
+
+# Bootstrap the Rails environment, frameworks, and default configuration
+require File.join(File.dirname(__FILE__), 'boot')
+
+Rails::Initializer.run do |config|
+ # Settings in config/environments/* take precedence over those specified here.
+
+ # Application configuration should go into files in config/initializers
+ # -- all .rb files in that directory are automatically loaded.
+ # See Rails::Configuration for more options.
+
+ # Skip frameworks you're not going to use. To use Rails without a database
+ # you must remove the Active Record framework.
+ # config.frameworks -= [ :active_record, :active_resource, :action_mailer ]
+
+ # Force all environments to use the same logger level
+ # (by default production uses :info, the others :debug)
+ # config.log_level = :debug
+
+ # Make Time.zone default to the specified zone, and make Active Record store time values
+ # in the database in UTC, and return them converted to the specified local zone.
+ # Run "rake -D time" for a list of tasks for finding time zone names. Uncomment to use default local time.
+ config.time_zone = 'UTC'
+
+ # Use SQL instead of Active Record's schema dumper when creating the test database.
+ # This is necessary if your schema can't be completely dumped by the schema dumper,
+ # like if you have constraints or database-specific column types
+ # config.active_record.schema_format = :sql
+
+ # Activate observers that should always be running
+ # config.active_record.observers = :cacher, :garbage_collector
+end
+
@@ -0,0 +1,19 @@
+# Settings specified here will take precedence over those in config/environment.rb
+
+# In the development environment your application's code is reloaded on
+# every request. This slows down response time but is perfect for development
+# since you don't have to restart the webserver when you make code changes.
+config.cache_classes = false
+
+# Log error messages when you accidentally call methods on nil.
+config.whiny_nils = true
+
+# Show full error reports and disable caching
+config.action_controller.consider_all_requests_local = true
+config.action_controller.perform_caching = false
+config.action_view.debug_rjs = true
+
+# Don't care if the mailer can't send
+config.action_mailer.raise_delivery_errors = false
+
+HOST = 'localhost'
@@ -0,0 +1,18 @@
+# Settings specified here will take precedence over those in config/environment.rb
+
+# The production environment is meant for finished, "live" apps.
+# Code is not reloaded between requests
+config.cache_classes = true
+
+# Use a different logger for distributed setups
+# config.logger = SyslogLogger.new
+
+# Full error reports are disabled and caching is turned on
+config.action_controller.consider_all_requests_local = false
+config.action_controller.perform_caching = true
+
+# Enable serving of images, stylesheets, and javascripts from an asset server
+# config.action_controller.asset_host = "http://assets.example.com"
+
+# Disable delivery errors, bad email addresses will be ignored
+config.action_mailer.raise_delivery_errors = false
@@ -0,0 +1,12 @@
+# Settings specified here will take precedence over those in config/environment.rb
+
+# We'd like to stay as close to prod as possible
+# Code is not reloaded between requests
+config.cache_classes = true
+
+# Full error reports are disabled and caching is turned on
+config.action_controller.consider_all_requests_local = false
+config.action_controller.perform_caching = true
+
+# Disable delivery errors if you bad email addresses should just be ignored
+config.action_mailer.raise_delivery_errors = false
@@ -0,0 +1,30 @@
+# Settings specified here will take precedence over those in config/environment.rb
+
+# The test environment is used exclusively to run your application's
+# test suite. You never need to work with it otherwise. Remember that
+# your test database is "scratch space" for the test suite and is wiped
+# and recreated between test runs. Don't rely on the data there!
+config.cache_classes = true
+
+# Log error messages when you accidentally call methods on nil.
+config.whiny_nils = true
+
+# Show full error reports and disable caching
+config.action_controller.consider_all_requests_local = true
+config.action_controller.perform_caching = false
+
+# Disable request forgery protection in test environment
+config.action_controller.allow_forgery_protection = false
+
+# Tell ActionMailer not to deliver emails to the real world.
+# The :test delivery method accumulates sent emails in the
+# ActionMailer::Base.deliveries array.
+config.action_mailer.delivery_method = :test
+
+HOST = 'localhost'
+
+require 'shoulda'
+require 'factory_girl'
+require 'mocha'
+
+begin require 'redgreen'; rescue LoadError; end
@@ -0,0 +1,6 @@
+ActionMailer::Base.smtp_settings = {
+ :address => "smtp.thoughtbot.com",
+ :port => 25,
+ :domain => "thoughtbot.com"
+}
+
@@ -0,0 +1,11 @@
+SHOULDA_NOISE = %w( shoulda )
+FACTORY_GIRL_NOISE = %w( factory_girl )
+THOUGHTBOT_NOISE = SHOULDA_NOISE + FACTORY_GIRL_NOISE
+
+Rails.backtrace_cleaner.add_silencer do |line|
+ THOUGHTBOT_NOISE.any? { |dir| line.include?(dir) }
+end
+
+# When debugging, uncomment the next line.
+# Rails.backtrace_cleaner.remove_silencers!
+
@@ -0,0 +1,30 @@
+# Copyright (c) 2009 Michael Koziarski <michael@koziarski.com>
+#
+# Permission to use, copy, modify, and/or distribute this software for any
+# purpose with or without fee is hereby granted, provided that the above
+# copyright notice and this permission notice appear in all copies.
+#
+# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+
+require 'bigdecimal'
+
+alias BigDecimalUnsafe BigDecimal
+
+
+# This fixes CVE-2009-1904 however it removes legitimate functionality that your
+# application may depend on. You are *strongly* advised to upgrade your ruby
+# rather than relying on this fix for an extended period of time.
+
+def BigDecimal(initial, digits=0)
+ if initial.size > 255 || initial =~ /e/i
+ raise "Invalid big Decimal Value"
+ end
+ BigDecimalUnsafe(initial, digits)
+end
+
Oops, something went wrong.

0 comments on commit fe3e01f

Please sign in to comment.