Skip to content
This repository

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Browse code

Intial commit

  • Loading branch information...
commit 8c39068e82aee85c0f3e7de10ac301922c653b29 0 parents
Some Guy authored January 17, 2012

Showing 45 changed files with 10,314 additions and 0 deletions. Show diff stats Hide diff stats

  1. 11  .gitignore
  2. 1  .rspec
  3. 19  Gemfile
  4. 99  Gemfile.lock
  5. 256  README
  6. 7  Rakefile
  7. 3  app/controllers/application_controller.rb
  8. 2  app/helpers/application_helper.rb
  9. 14  app/views/layouts/application.html.erb
  10. 2  autotest/discover.rb
  11. 4  config.ru
  12. 42  config/application.rb
  13. 13  config/boot.rb
  14. 22  config/database.yml
  15. 5  config/environment.rb
  16. 26  config/environments/development.rb
  17. 49  config/environments/production.rb
  18. 35  config/environments/test.rb
  19. 7  config/initializers/backtrace_silencers.rb
  20. 10  config/initializers/inflections.rb
  21. 5  config/initializers/mime_types.rb
  22. 7  config/initializers/secret_token.rb
  23. 8  config/initializers/session_store.rb
  24. 5  config/locales/en.yml
  25. 58  config/routes.rb
  26. 7  db/seeds.rb
  27. 2  doc/README_FOR_APP
  28. 26  public/404.html
  29. 26  public/422.html
  30. 26  public/500.html
  31. 0  public/favicon.ico
  32. BIN  public/images/rails.png
  33. 239  public/index.html
  34. 2  public/javascripts/application.js
  35. 965  public/javascripts/controls.js
  36. 974  public/javascripts/dragdrop.js
  37. 1,123  public/javascripts/effects.js
  38. 6,001  public/javascripts/prototype.js
  39. 175  public/javascripts/rails.js
  40. 5  public/robots.txt
  41. 0  public/stylesheets/.gitkeep
  42. 6  script/rails
  43. 27  spec/spec_helper.rb
  44. 0  tasks/.gitkeep b/lib/tasks/.gitkeep
  45. 0  vendor/plugins/.gitkeep
11  .gitignore
... ...
@@ -0,0 +1,11 @@
  1
+.bundle
  2
+db/*.sqlite3
  3
+log/*.log
  4
+*.log
  5
+tmp/**/*
  6
+tmp/*
  7
+doc/api
  8
+doc/app
  9
+*.swp
  10
+*~
  11
+.DS_Store
1  .rspec
... ...
@@ -0,0 +1 @@
  1
+--colour
19  Gemfile
... ...
@@ -0,0 +1,19 @@
  1
+source :rubygems
  2
+source "http://rubygems.org"
  3
+source :rubyforge
  4
+source "http://gems.rubyforge.org"
  5
+source :gemcutter
  6
+source "http://gemcutter.org"
  7
+
  8
+gem 'rails', '3.0.0'
  9
+
  10
+gem 'sqlite3-ruby', '1.2.5', :require => 'sqlite3'
  11
+
  12
+
  13
+group :development do
  14
+ gem "rspec-rails", "2.0.0.beta.18"
  15
+end
  16
+
  17
+group :test do
  18
+  gem "rspec"
  19
+end
99  Gemfile.lock
... ...
@@ -0,0 +1,99 @@
  1
+GEM
  2
+  remote: http://rubygems.org/
  3
+  remote: http://rubygems.org/
  4
+  remote: http://rubygems.org/
  5
+  remote: http://gems.rubyforge.org/
  6
+  remote: http://rubygems.org/
  7
+  remote: http://gemcutter.org/
  8
+  specs:
  9
+    abstract (1.0.0)
  10
+    actionmailer (3.0.0)
  11
+      actionpack (= 3.0.0)
  12
+      mail (~> 2.2.5)
  13
+    actionpack (3.0.0)
  14
+      activemodel (= 3.0.0)
  15
+      activesupport (= 3.0.0)
  16
+      builder (~> 2.1.2)
  17
+      erubis (~> 2.6.6)
  18
+      i18n (~> 0.4.1)
  19
+      rack (~> 1.2.1)
  20
+      rack-mount (~> 0.6.12)
  21
+      rack-test (~> 0.5.4)
  22
+      tzinfo (~> 0.3.23)
  23
+    activemodel (3.0.0)
  24
+      activesupport (= 3.0.0)
  25
+      builder (~> 2.1.2)
  26
+      i18n (~> 0.4.1)
  27
+    activerecord (3.0.0)
  28
+      activemodel (= 3.0.0)
  29
+      activesupport (= 3.0.0)
  30
+      arel (~> 1.0.0)
  31
+      tzinfo (~> 0.3.23)
  32
+    activeresource (3.0.0)
  33
+      activemodel (= 3.0.0)
  34
+      activesupport (= 3.0.0)
  35
+    activesupport (3.0.0)
  36
+    arel (1.0.1)
  37
+      activesupport (~> 3.0.0)
  38
+    builder (2.1.2)
  39
+    diff-lcs (1.1.3)
  40
+    erubis (2.6.6)
  41
+      abstract (>= 1.0.0)
  42
+    i18n (0.4.2)
  43
+    mail (2.2.19)
  44
+      activesupport (>= 2.3.6)
  45
+      i18n (>= 0.4.0)
  46
+      mime-types (~> 1.16)
  47
+      treetop (~> 1.4.8)
  48
+    mime-types (1.17.2)
  49
+    nokogiri (1.5.0)
  50
+    polyglot (0.3.3)
  51
+    rack (1.2.5)
  52
+    rack-mount (0.6.14)
  53
+      rack (>= 1.0.0)
  54
+    rack-test (0.5.7)
  55
+      rack (>= 1.0)
  56
+    rails (3.0.0)
  57
+      actionmailer (= 3.0.0)
  58
+      actionpack (= 3.0.0)
  59
+      activerecord (= 3.0.0)
  60
+      activeresource (= 3.0.0)
  61
+      activesupport (= 3.0.0)
  62
+      bundler (~> 1.0.0)
  63
+      railties (= 3.0.0)
  64
+    railties (3.0.0)
  65
+      actionpack (= 3.0.0)
  66
+      activesupport (= 3.0.0)
  67
+      rake (>= 0.8.4)
  68
+      thor (~> 0.14.0)
  69
+    rake (0.9.2.2)
  70
+    rspec (2.8.0)
  71
+      rspec-core (~> 2.8.0)
  72
+      rspec-expectations (~> 2.8.0)
  73
+      rspec-mocks (~> 2.8.0)
  74
+    rspec-core (2.8.0)
  75
+    rspec-expectations (2.8.0)
  76
+      diff-lcs (~> 1.1.2)
  77
+    rspec-mocks (2.8.0)
  78
+    rspec-rails (2.0.0.beta.18)
  79
+      rspec (>= 2.0.0.beta.14)
  80
+      webrat (>= 0.7.0)
  81
+    sqlite3-ruby (1.2.5)
  82
+    thor (0.14.6)
  83
+    treetop (1.4.10)
  84
+      polyglot
  85
+      polyglot (>= 0.3.1)
  86
+    tzinfo (0.3.31)
  87
+    webrat (0.7.3)
  88
+      nokogiri (>= 1.2.0)
  89
+      rack (>= 1.0)
  90
+      rack-test (>= 0.5.3)
  91
+
  92
+PLATFORMS
  93
+  ruby
  94
+
  95
+DEPENDENCIES
  96
+  rails (= 3.0.0)
  97
+  rspec
  98
+  rspec-rails (= 2.0.0.beta.18)
  99
+  sqlite3-ruby (= 1.2.5)
256  README
... ...
@@ -0,0 +1,256 @@
  1
+== Welcome to Rails
  2
+
  3
+Rails is a web-application framework that includes everything needed to create
  4
+database-backed web applications according to the Model-View-Control pattern.
  5
+
  6
+This pattern splits the view (also called the presentation) into "dumb"
  7
+templates that are primarily responsible for inserting pre-built data in between
  8
+HTML tags. The model contains the "smart" domain objects (such as Account,
  9
+Product, Person, Post) that holds all the business logic and knows how to
  10
+persist themselves to a database. The controller handles the incoming requests
  11
+(such as Save New Account, Update Product, Show Post) by manipulating the model
  12
+and directing data to the view.
  13
+
  14
+In Rails, the model is handled by what's called an object-relational mapping
  15
+layer entitled Active Record. This layer allows you to present the data from
  16
+database rows as objects and embellish these data objects with business logic
  17
+methods. You can read more about Active Record in
  18
+link:files/vendor/rails/activerecord/README.html.
  19
+
  20
+The controller and view are handled by the Action Pack, which handles both
  21
+layers by its two parts: Action View and Action Controller. These two layers
  22
+are bundled in a single package due to their heavy interdependence. This is
  23
+unlike the relationship between the Active Record and Action Pack that is much
  24
+more separate. Each of these packages can be used independently outside of
  25
+Rails. You can read more about Action Pack in
  26
+link:files/vendor/rails/actionpack/README.html.
  27
+
  28
+
  29
+== Getting Started
  30
+
  31
+1. At the command prompt, create a new Rails application:
  32
+       <tt>rails new myapp</tt> (where <tt>myapp</tt> is the application name)
  33
+
  34
+2. Change directory to <tt>myapp</tt> and start the web server:
  35
+       <tt>cd myapp; rails server</tt> (run with --help for options)
  36
+
  37
+3. Go to http://localhost:3000/ and you'll see:
  38
+       "Welcome aboard: You're riding Ruby on Rails!"
  39
+
  40
+4. Follow the guidelines to start developing your application. You can find
  41
+the following resources handy:
  42
+
  43
+* The Getting Started Guide: http://guides.rubyonrails.org/getting_started.html
  44
+* Ruby on Rails Tutorial Book: http://www.railstutorial.org/
  45
+
  46
+
  47
+== Debugging Rails
  48
+
  49
+Sometimes your application goes wrong. Fortunately there are a lot of tools that
  50
+will help you debug it and get it back on the rails.
  51
+
  52
+First area to check is the application log files. Have "tail -f" commands
  53
+running on the server.log and development.log. Rails will automatically display
  54
+debugging and runtime information to these files. Debugging info will also be
  55
+shown in the browser on requests from 127.0.0.1.
  56
+
  57
+You can also log your own messages directly into the log file from your code
  58
+using the Ruby logger class from inside your controllers. Example:
  59
+
  60
+  class WeblogController < ActionController::Base
  61
+    def destroy
  62
+      @weblog = Weblog.find(params[:id])
  63
+      @weblog.destroy
  64
+      logger.info("#{Time.now} Destroyed Weblog ID ##{@weblog.id}!")
  65
+    end
  66
+  end
  67
+
  68
+The result will be a message in your log file along the lines of:
  69
+
  70
+  Mon Oct 08 14:22:29 +1000 2007 Destroyed Weblog ID #1!
  71
+
  72
+More information on how to use the logger is at http://www.ruby-doc.org/core/
  73
+
  74
+Also, Ruby documentation can be found at http://www.ruby-lang.org/. There are
  75
+several books available online as well:
  76
+
  77
+* Programming Ruby: http://www.ruby-doc.org/docs/ProgrammingRuby/ (Pickaxe)
  78
+* Learn to Program: http://pine.fm/LearnToProgram/ (a beginners guide)
  79
+
  80
+These two books will bring you up to speed on the Ruby language and also on
  81
+programming in general.
  82
+
  83
+
  84
+== Debugger
  85
+
  86
+Debugger support is available through the debugger command when you start your
  87
+Mongrel or WEBrick server with --debugger. This means that you can break out of
  88
+execution at any point in the code, investigate and change the model, and then,
  89
+resume execution! You need to install ruby-debug to run the server in debugging
  90
+mode. With gems, use <tt>sudo gem install ruby-debug</tt>. Example:
  91
+
  92
+  class WeblogController < ActionController::Base
  93
+    def index
  94
+      @posts = Post.find(:all)
  95
+      debugger
  96
+    end
  97
+  end
  98
+
  99
+So the controller will accept the action, run the first line, then present you
  100
+with a IRB prompt in the server window. Here you can do things like:
  101
+
  102
+  >> @posts.inspect
  103
+  => "[#<Post:0x14a6be8
  104
+          @attributes={"title"=>nil, "body"=>nil, "id"=>"1"}>,
  105
+       #<Post:0x14a6620
  106
+          @attributes={"title"=>"Rails", "body"=>"Only ten..", "id"=>"2"}>]"
  107
+  >> @posts.first.title = "hello from a debugger"
  108
+  => "hello from a debugger"
  109
+
  110
+...and even better, you can examine how your runtime objects actually work:
  111
+
  112
+  >> f = @posts.first
  113
+  => #<Post:0x13630c4 @attributes={"title"=>nil, "body"=>nil, "id"=>"1"}>
  114
+  >> f.
  115
+  Display all 152 possibilities? (y or n)
  116
+
  117
+Finally, when you're ready to resume execution, you can enter "cont".
  118
+
  119
+
  120
+== Console
  121
+
  122
+The console is a Ruby shell, which allows you to interact with your
  123
+application's domain model. Here you'll have all parts of the application
  124
+configured, just like it is when the application is running. You can inspect
  125
+domain models, change values, and save to the database. Starting the script
  126
+without arguments will launch it in the development environment.
  127
+
  128
+To start the console, run <tt>rails console</tt> from the application
  129
+directory.
  130
+
  131
+Options:
  132
+
  133
+* Passing the <tt>-s, --sandbox</tt> argument will rollback any modifications
  134
+  made to the database.
  135
+* Passing an environment name as an argument will load the corresponding
  136
+  environment. Example: <tt>rails console production</tt>.
  137
+
  138
+To reload your controllers and models after launching the console run
  139
+<tt>reload!</tt>
  140
+
  141
+More information about irb can be found at:
  142
+link:http://www.rubycentral.com/pickaxe/irb.html
  143
+
  144
+
  145
+== dbconsole
  146
+
  147
+You can go to the command line of your database directly through <tt>rails
  148
+dbconsole</tt>. You would be connected to the database with the credentials
  149
+defined in database.yml. Starting the script without arguments will connect you
  150
+to the development database. Passing an argument will connect you to a different
  151
+database, like <tt>rails dbconsole production</tt>. Currently works for MySQL,
  152
+PostgreSQL and SQLite 3.
  153
+
  154
+== Description of Contents
  155
+
  156
+The default directory structure of a generated Ruby on Rails application:
  157
+
  158
+  |-- app
  159
+  |   |-- controllers
  160
+  |   |-- helpers
  161
+  |   |-- models
  162
+  |   `-- views
  163
+  |       `-- layouts
  164
+  |-- config
  165
+  |   |-- environments
  166
+  |   |-- initializers
  167
+  |   `-- locales
  168
+  |-- db
  169
+  |-- doc
  170
+  |-- lib
  171
+  |   `-- tasks
  172
+  |-- log
  173
+  |-- public
  174
+  |   |-- images
  175
+  |   |-- javascripts
  176
+  |   `-- stylesheets
  177
+  |-- script
  178
+  |   `-- performance
  179
+  |-- test
  180
+  |   |-- fixtures
  181
+  |   |-- functional
  182
+  |   |-- integration
  183
+  |   |-- performance
  184
+  |   `-- unit
  185
+  |-- tmp
  186
+  |   |-- cache
  187
+  |   |-- pids
  188
+  |   |-- sessions
  189
+  |   `-- sockets
  190
+  `-- vendor
  191
+      `-- plugins
  192
+
  193
+app
  194
+  Holds all the code that's specific to this particular application.
  195
+
  196
+app/controllers
  197
+  Holds controllers that should be named like weblogs_controller.rb for
  198
+  automated URL mapping. All controllers should descend from
  199
+  ApplicationController which itself descends from ActionController::Base.
  200
+
  201
+app/models
  202
+  Holds models that should be named like post.rb. Models descend from
  203
+  ActiveRecord::Base by default.
  204
+
  205
+app/views
  206
+  Holds the template files for the view that should be named like
  207
+  weblogs/index.html.erb for the WeblogsController#index action. All views use
  208
+  eRuby syntax by default.
  209
+
  210
+app/views/layouts
  211
+  Holds the template files for layouts to be used with views. This models the
  212
+  common header/footer method of wrapping views. In your views, define a layout
  213
+  using the <tt>layout :default</tt> and create a file named default.html.erb.
  214
+  Inside default.html.erb, call <% yield %> to render the view using this
  215
+  layout.
  216
+
  217
+app/helpers
  218
+  Holds view helpers that should be named like weblogs_helper.rb. These are
  219
+  generated for you automatically when using generators for controllers.
  220
+  Helpers can be used to wrap functionality for your views into methods.
  221
+
  222
+config
  223
+  Configuration files for the Rails environment, the routing map, the database,
  224
+  and other dependencies.
  225
+
  226
+db
  227
+  Contains the database schema in schema.rb. db/migrate contains all the
  228
+  sequence of Migrations for your schema.
  229
+
  230
+doc
  231
+  This directory is where your application documentation will be stored when
  232
+  generated using <tt>rake doc:app</tt>
  233
+
  234
+lib
  235
+  Application specific libraries. Basically, any kind of custom code that
  236
+  doesn't belong under controllers, models, or helpers. This directory is in
  237
+  the load path.
  238
+
  239
+public
  240
+  The directory available for the web server. Contains subdirectories for
  241
+  images, stylesheets, and javascripts. Also contains the dispatchers and the
  242
+  default HTML files. This should be set as the DOCUMENT_ROOT of your web
  243
+  server.
  244
+
  245
+script
  246
+  Helper scripts for automation and generation.
  247
+
  248
+test
  249
+  Unit and functional tests along with fixtures. When using the rails generate
  250
+  command, template test files will be generated for you and placed in this
  251
+  directory.
  252
+
  253
+vendor
  254
+  External libraries that the application depends on. Also includes the plugins
  255
+  subdirectory. If the app has frozen rails, those gems also go here, under
  256
+  vendor/rails/. This directory is in the load path.
7  Rakefile
... ...
@@ -0,0 +1,7 @@
  1
+# Add your own tasks in files placed in lib/tasks ending in .rake,
  2
+# for example lib/tasks/capistrano.rake, and they will automatically be available to Rake.
  3
+
  4
+require File.expand_path('../config/application', __FILE__)
  5
+require 'rake'
  6
+
  7
+SampleApp::Application.load_tasks
3  app/controllers/application_controller.rb
... ...
@@ -0,0 +1,3 @@
  1
+class ApplicationController < ActionController::Base
  2
+  protect_from_forgery
  3
+end
2  app/helpers/application_helper.rb
... ...
@@ -0,0 +1,2 @@
  1
+module ApplicationHelper
  2
+end
14  app/views/layouts/application.html.erb
... ...
@@ -0,0 +1,14 @@
  1
+<!DOCTYPE html>
  2
+<html>
  3
+<head>
  4
+  <title>SampleApp</title>
  5
+  <%= stylesheet_link_tag :all %>
  6
+  <%= javascript_include_tag :defaults %>
  7
+  <%= csrf_meta_tag %>
  8
+</head>
  9
+<body>
  10
+
  11
+<%= yield %>
  12
+
  13
+</body>
  14
+</html>
2  autotest/discover.rb
... ...
@@ -0,0 +1,2 @@
  1
+Autotest.add_discovery { "rails" }
  2
+Autotest.add_discovery { "rspec2" }
4  config.ru
... ...
@@ -0,0 +1,4 @@
  1
+# This file is used by Rack-based servers to start the application.
  2
+
  3
+require ::File.expand_path('../config/environment',  __FILE__)
  4
+run SampleApp::Application
42  config/application.rb
... ...
@@ -0,0 +1,42 @@
  1
+require File.expand_path('../boot', __FILE__)
  2
+
  3
+require 'rails/all'
  4
+
  5
+# If you have a Gemfile, require the gems listed there, including any gems
  6
+# you've limited to :test, :development, or :production.
  7
+Bundler.require(:default, Rails.env) if defined?(Bundler)
  8
+
  9
+module SampleApp
  10
+  class Application < Rails::Application
  11
+    # Settings in config/environments/* take precedence over those specified here.
  12
+    # Application configuration should go into files in config/initializers
  13
+    # -- all .rb files in that directory are automatically loaded.
  14
+
  15
+    # Custom directories with classes and modules you want to be autoloadable.
  16
+    # config.autoload_paths += %W(#{config.root}/extras)
  17
+
  18
+    # Only load the plugins named here, in the order given (default is alphabetical).
  19
+    # :all can be used as a placeholder for all plugins not explicitly named.
  20
+    # config.plugins = [ :exception_notification, :ssl_requirement, :all ]
  21
+
  22
+    # Activate observers that should always be running.
  23
+    # config.active_record.observers = :cacher, :garbage_collector, :forum_observer
  24
+
  25
+    # Set Time.zone default to the specified zone and make Active Record auto-convert to this zone.
  26
+    # Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC.
  27
+    # config.time_zone = 'Central Time (US & Canada)'
  28
+
  29
+    # The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
  30
+    # config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
  31
+    # config.i18n.default_locale = :de
  32
+
  33
+    # JavaScript files you want as :defaults (application.js is always included).
  34
+    # config.action_view.javascript_expansions[:defaults] = %w(jquery rails)
  35
+
  36
+    # Configure the default encoding used in templates for Ruby 1.9.
  37
+    config.encoding = "utf-8"
  38
+
  39
+    # Configure sensitive parameters which will be filtered from the log file.
  40
+    config.filter_parameters += [:password]
  41
+  end
  42
+end
13  config/boot.rb
... ...
@@ -0,0 +1,13 @@
  1
+require 'rubygems'
  2
+
  3
+# Set up gems listed in the Gemfile.
  4
+gemfile = File.expand_path('../../Gemfile', __FILE__)
  5
+begin
  6
+  ENV['BUNDLE_GEMFILE'] = gemfile
  7
+  require 'bundler'
  8
+  Bundler.setup
  9
+rescue Bundler::GemNotFound => e
  10
+  STDERR.puts e.message
  11
+  STDERR.puts "Try running `bundle install`."
  12
+  exit!
  13
+end if File.exist?(gemfile)
22  config/database.yml
... ...
@@ -0,0 +1,22 @@
  1
+# SQLite version 3.x
  2
+#   gem install sqlite3-ruby (not necessary on OS X Leopard)
  3
+development:
  4
+  adapter: sqlite3
  5
+  database: db/development.sqlite3
  6
+  pool: 5
  7
+  timeout: 5000
  8
+
  9
+# Warning: The database defined as "test" will be erased and
  10
+# re-generated from your development database when you run "rake".
  11
+# Do not set this db to the same as development or production.
  12
+test:
  13
+  adapter: sqlite3
  14
+  database: db/test.sqlite3
  15
+  pool: 5
  16
+  timeout: 5000
  17
+
  18
+production:
  19
+  adapter: sqlite3
  20
+  database: db/production.sqlite3
  21
+  pool: 5
  22
+  timeout: 5000
5  config/environment.rb
... ...
@@ -0,0 +1,5 @@
  1
+# Load the rails application
  2
+require File.expand_path('../application', __FILE__)
  3
+
  4
+# Initialize the rails application
  5
+SampleApp::Application.initialize!
26  config/environments/development.rb
... ...
@@ -0,0 +1,26 @@
  1
+SampleApp::Application.configure do
  2
+  # Settings specified here will take precedence over those in config/environment.rb
  3
+
  4
+  # In the development environment your application's code is reloaded on
  5
+  # every request.  This slows down response time but is perfect for development
  6
+  # since you don't have to restart the webserver when you make code changes.
  7
+  config.cache_classes = false
  8
+
  9
+  # Log error messages when you accidentally call methods on nil.
  10
+  config.whiny_nils = true
  11
+
  12
+  # Show full error reports and disable caching
  13
+  config.consider_all_requests_local       = true
  14
+  config.action_view.debug_rjs             = true
  15
+  config.action_controller.perform_caching = false
  16
+
  17
+  # Don't care if the mailer can't send
  18
+  config.action_mailer.raise_delivery_errors = false
  19
+
  20
+  # Print deprecation notices to the Rails logger
  21
+  config.active_support.deprecation = :log
  22
+
  23
+  # Only use best-standards-support built into browsers
  24
+  config.action_dispatch.best_standards_support = :builtin
  25
+end
  26
+
49  config/environments/production.rb
... ...
@@ -0,0 +1,49 @@
  1
+SampleApp::Application.configure do
  2
+  # Settings specified here will take precedence over those in config/environment.rb
  3
+
  4
+  # The production environment is meant for finished, "live" apps.
  5
+  # Code is not reloaded between requests
  6
+  config.cache_classes = true
  7
+
  8
+  # Full error reports are disabled and caching is turned on
  9
+  config.consider_all_requests_local       = false
  10
+  config.action_controller.perform_caching = true
  11
+
  12
+  # Specifies the header that your server uses for sending files
  13
+  config.action_dispatch.x_sendfile_header = "X-Sendfile"
  14
+
  15
+  # For nginx:
  16
+  # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect'
  17
+
  18
+  # If you have no front-end server that supports something like X-Sendfile,
  19
+  # just comment this out and Rails will serve the files
  20
+
  21
+  # See everything in the log (default is :info)
  22
+  # config.log_level = :debug
  23
+
  24
+  # Use a different logger for distributed setups
  25
+  # config.logger = SyslogLogger.new
  26
+
  27
+  # Use a different cache store in production
  28
+  # config.cache_store = :mem_cache_store
  29
+
  30
+  # Disable Rails's static asset server
  31
+  # In production, Apache or nginx will already do this
  32
+  config.serve_static_assets = false
  33
+
  34
+  # Enable serving of images, stylesheets, and javascripts from an asset server
  35
+  # config.action_controller.asset_host = "http://assets.example.com"
  36
+
  37
+  # Disable delivery errors, bad email addresses will be ignored
  38
+  # config.action_mailer.raise_delivery_errors = false
  39
+
  40
+  # Enable threaded mode
  41
+  # config.threadsafe!
  42
+
  43
+  # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
  44
+  # the I18n.default_locale when a translation can not be found)
  45
+  config.i18n.fallbacks = true
  46
+
  47
+  # Send deprecation notices to registered listeners
  48
+  config.active_support.deprecation = :notify
  49
+end
35  config/environments/test.rb
... ...
@@ -0,0 +1,35 @@
  1
+SampleApp::Application.configure do
  2
+  # Settings specified here will take precedence over those in config/environment.rb
  3
+
  4
+  # The test environment is used exclusively to run your application's
  5
+  # test suite.  You never need to work with it otherwise.  Remember that
  6
+  # your test database is "scratch space" for the test suite and is wiped
  7
+  # and recreated between test runs.  Don't rely on the data there!
  8
+  config.cache_classes = true
  9
+
  10
+  # Log error messages when you accidentally call methods on nil.
  11
+  config.whiny_nils = true
  12
+
  13
+  # Show full error reports and disable caching
  14
+  config.consider_all_requests_local       = true
  15
+  config.action_controller.perform_caching = false
  16
+
  17
+  # Raise exceptions instead of rendering exception templates
  18
+  config.action_dispatch.show_exceptions = false
  19
+
  20
+  # Disable request forgery protection in test environment
  21
+  config.action_controller.allow_forgery_protection    = false
  22
+
  23
+  # Tell Action Mailer not to deliver emails to the real world.
  24
+  # The :test delivery method accumulates sent emails in the
  25
+  # ActionMailer::Base.deliveries array.
  26
+  config.action_mailer.delivery_method = :test
  27
+
  28
+  # Use SQL instead of Active Record's schema dumper when creating the test database.
  29
+  # This is necessary if your schema can't be completely dumped by the schema dumper,
  30
+  # like if you have constraints or database-specific column types
  31
+  # config.active_record.schema_format = :sql
  32
+
  33
+  # Print deprecation notices to the stderr
  34
+  config.active_support.deprecation = :stderr
  35
+end
7  config/initializers/backtrace_silencers.rb
... ...
@@ -0,0 +1,7 @@
  1
+# Be sure to restart your server when you modify this file.
  2
+
  3
+# You can add backtrace silencers for libraries that you're using but don't wish to see in your backtraces.
  4
+# Rails.backtrace_cleaner.add_silencer { |line| line =~ /my_noisy_library/ }
  5
+
  6
+# You can also remove all the silencers if you're trying to debug a problem that might stem from framework code.
  7
+# Rails.backtrace_cleaner.remove_silencers!
10  config/initializers/inflections.rb
... ...
@@ -0,0 +1,10 @@
  1
+# Be sure to restart your server when you modify this file.
  2
+
  3
+# Add new inflection rules using the following format
  4
+# (all these examples are active by default):
  5
+# ActiveSupport::Inflector.inflections do |inflect|
  6
+#   inflect.plural /^(ox)$/i, '\1en'
  7
+#   inflect.singular /^(ox)en/i, '\1'
  8
+#   inflect.irregular 'person', 'people'
  9
+#   inflect.uncountable %w( fish sheep )
  10
+# end
5  config/initializers/mime_types.rb
... ...
@@ -0,0 +1,5 @@
  1
+# Be sure to restart your server when you modify this file.
  2
+
  3
+# Add new mime types for use in respond_to blocks:
  4
+# Mime::Type.register "text/richtext", :rtf
  5
+# Mime::Type.register_alias "text/html", :iphone
7  config/initializers/secret_token.rb
... ...
@@ -0,0 +1,7 @@
  1
+# Be sure to restart your server when you modify this file.
  2
+
  3
+# Your secret key for verifying the integrity of signed cookies.
  4
+# If you change this key, all old signed cookies will become invalid!
  5
+# Make sure the secret is at least 30 characters and all random,
  6
+# no regular words or you'll be exposed to dictionary attacks.
  7
+SampleApp::Application.config.secret_token = '26a3cb703f774946a298d618cddd4ff92f9f70f5ef1c9862f15ba37bb47a84b4a589ca38797d1c4b42ee9310545dd9bd3757b5935ed2fce807101b1c4279e5af'
8  config/initializers/session_store.rb
... ...
@@ -0,0 +1,8 @@
  1
+# Be sure to restart your server when you modify this file.
  2
+
  3
+SampleApp::Application.config.session_store :cookie_store, :key => '_sample_app_session'
  4
+
  5
+# Use the database for sessions instead of the cookie-based default,
  6
+# which shouldn't be used to store highly confidential information
  7
+# (create the session table with "rake db:sessions:create")
  8
+# SampleApp::Application.config.session_store :active_record_store
5  config/locales/en.yml
... ...
@@ -0,0 +1,5 @@
  1
+# Sample localization file for English. Add more files in this directory for other locales.
  2
+# See http://github.com/svenfuchs/rails-i18n/tree/master/rails%2Flocale for starting points.
  3
+
  4
+en:
  5
+  hello: "Hello world"
58  config/routes.rb
... ...
@@ -0,0 +1,58 @@
  1
+SampleApp::Application.routes.draw do
  2
+  # The priority is based upon order of creation:
  3
+  # first created -> highest priority.
  4
+
  5
+  # Sample of regular route:
  6
+  #   match 'products/:id' => 'catalog#view'
  7
+  # Keep in mind you can assign values other than :controller and :action
  8
+
  9
+  # Sample of named route:
  10
+  #   match 'products/:id/purchase' => 'catalog#purchase', :as => :purchase
  11
+  # This route can be invoked with purchase_url(:id => product.id)
  12
+
  13
+  # Sample resource route (maps HTTP verbs to controller actions automatically):
  14
+  #   resources :products
  15
+
  16
+  # Sample resource route with options:
  17
+  #   resources :products do
  18
+  #     member do
  19
+  #       get 'short'
  20
+  #       post 'toggle'
  21
+  #     end
  22
+  #
  23
+  #     collection do
  24
+  #       get 'sold'
  25
+  #     end
  26
+  #   end
  27
+
  28
+  # Sample resource route with sub-resources:
  29
+  #   resources :products do
  30
+  #     resources :comments, :sales
  31
+  #     resource :seller
  32
+  #   end
  33
+
  34
+  # Sample resource route with more complex sub-resources
  35
+  #   resources :products do
  36
+  #     resources :comments
  37
+  #     resources :sales do
  38
+  #       get 'recent', :on => :collection
  39
+  #     end
  40
+  #   end
  41
+
  42
+  # Sample resource route within a namespace:
  43
+  #   namespace :admin do
  44
+  #     # Directs /admin/products/* to Admin::ProductsController
  45
+  #     # (app/controllers/admin/products_controller.rb)
  46
+  #     resources :products
  47
+  #   end
  48
+
  49
+  # You can have the root of your site routed with "root"
  50
+  # just remember to delete public/index.html.
  51
+  # root :to => "welcome#index"
  52
+
  53
+  # See how all your routes lay out with "rake routes"
  54
+
  55
+  # This is a legacy wild controller route that's not recommended for RESTful applications.
  56
+  # Note: This route will make all actions in every controller accessible via GET requests.
  57
+  # match ':controller(/:action(/:id(.:format)))'
  58
+end
7  db/seeds.rb
... ...
@@ -0,0 +1,7 @@
  1
+# This file should contain all the record creation needed to seed the database with its default values.
  2
+# The data can then be loaded with the rake db:seed (or created alongside the db with db:setup).
  3
+#
  4
+# Examples:
  5
+#
  6
+#   cities = City.create([{ :name => 'Chicago' }, { :name => 'Copenhagen' }])
  7
+#   Mayor.create(:name => 'Daley', :city => cities.first)
2  doc/README_FOR_APP
... ...
@@ -0,0 +1,2 @@
  1
+Use this README file to introduce your application and point to useful places in the API for learning more.
  2
+Run "rake doc:app" to generate API documentation for your models, controllers, helpers, and libraries.
26  public/404.html
... ...
@@ -0,0 +1,26 @@
  1
+<!DOCTYPE html>
  2
+<html>
  3
+<head>
  4
+  <title>The page you were looking for doesn't exist (404)</title>
  5
+  <style type="text/css">
  6
+    body { background-color: #fff; color: #666; text-align: center; font-family: arial, sans-serif; }
  7
+    div.dialog {
  8
+      width: 25em;
  9
+      padding: 0 4em;
  10
+      margin: 4em auto 0 auto;
  11
+      border: 1px solid #ccc;
  12
+      border-right-color: #999;
  13
+      border-bottom-color: #999;
  14
+    }
  15
+    h1 { font-size: 100%; color: #f00; line-height: 1.5em; }
  16
+  </style>
  17
+</head>
  18
+
  19
+<body>
  20
+  <!-- This file lives in public/404.html -->
  21
+  <div class="dialog">
  22
+    <h1>The page you were looking for doesn't exist.</h1>
  23
+    <p>You may have mistyped the address or the page may have moved.</p>
  24
+  </div>
  25
+</body>
  26
+</html>
26  public/422.html
... ...
@@ -0,0 +1,26 @@
  1
+<!DOCTYPE html>
  2
+<html>
  3
+<head>
  4
+  <title>The change you wanted was rejected (422)</title>
  5
+  <style type="text/css">
  6
+    body { background-color: #fff; color: #666; text-align: center; font-family: arial, sans-serif; }
  7
+    div.dialog {
  8
+      width: 25em;
  9
+      padding: 0 4em;
  10
+      margin: 4em auto 0 auto;
  11
+      border: 1px solid #ccc;
  12
+      border-right-color: #999;
  13
+      border-bottom-color: #999;
  14
+    }
  15
+    h1 { font-size: 100%; color: #f00; line-height: 1.5em; }
  16
+  </style>
  17
+</head>
  18
+
  19
+<body>
  20
+  <!-- This file lives in public/422.html -->
  21
+  <div class="dialog">
  22
+    <h1>The change you wanted was rejected.</h1>
  23
+    <p>Maybe you tried to change something you didn't have access to.</p>
  24
+  </div>
  25
+</body>
  26
+</html>
26  public/500.html
... ...
@@ -0,0 +1,26 @@
  1
+<!DOCTYPE html>
  2
+<html>
  3
+<head>
  4
+  <title>We're sorry, but something went wrong (500)</title>
  5
+  <style type="text/css">
  6
+    body { background-color: #fff; color: #666; text-align: center; font-family: arial, sans-serif; }
  7
+    div.dialog {
  8
+      width: 25em;
  9
+      padding: 0 4em;
  10
+      margin: 4em auto 0 auto;
  11
+      border: 1px solid #ccc;
  12
+      border-right-color: #999;
  13
+      border-bottom-color: #999;
  14
+    }
  15
+    h1 { font-size: 100%; color: #f00; line-height: 1.5em; }
  16
+  </style>
  17
+</head>
  18
+
  19
+<body>
  20
+  <!-- This file lives in public/500.html -->
  21
+  <div class="dialog">
  22
+    <h1>We're sorry, but something went wrong.</h1>
  23
+    <p>We've been notified about this issue and we'll take a look at it shortly.</p>
  24
+  </div>
  25
+</body>
  26
+</html>
0  public/favicon.ico
No changes.
BIN  public/images/rails.png
239  public/index.html
... ...
@@ -0,0 +1,239 @@
  1
+<!DOCTYPE html>
  2
+<html>
  3
+  <head>
  4
+    <title>Ruby on Rails: Welcome aboard</title>
  5
+    <style type="text/css" media="screen">
  6
+      body {
  7
+        margin: 0;
  8
+        margin-bottom: 25px;
  9
+        padding: 0;
  10
+        background-color: #f0f0f0;
  11
+        font-family: "Lucida Grande", "Bitstream Vera Sans", "Verdana";
  12
+        font-size: 13px;
  13
+        color: #333;
  14
+      }
  15
+
  16
+      h1 {
  17
+        font-size: 28px;
  18
+        color: #000;
  19
+      }
  20
+
  21
+      a  {color: #03c}
  22
+      a:hover {
  23
+        background-color: #03c;
  24
+        color: white;
  25
+        text-decoration: none;
  26
+      }
  27
+
  28
+
  29
+      #page {
  30
+        background-color: #f0f0f0;
  31
+        width: 750px;
  32
+        margin: 0;
  33
+        margin-left: auto;
  34
+        margin-right: auto;
  35
+      }
  36
+
  37
+      #content {
  38
+        float: left;
  39
+        background-color: white;
  40
+        border: 3px solid #aaa;
  41
+        border-top: none;
  42
+        padding: 25px;
  43
+        width: 500px;
  44
+      }
  45
+
  46
+      #sidebar {
  47
+        float: right;
  48
+        width: 175px;
  49
+      }
  50
+
  51
+      #footer {
  52
+        clear: both;
  53
+      }
  54
+
  55
+
  56
+      #header, #about, #getting-started {
  57
+        padding-left: 75px;
  58
+        padding-right: 30px;
  59
+      }
  60
+
  61
+
  62
+      #header {
  63
+        background-image: url("images/rails.png");
  64
+        background-repeat: no-repeat;
  65
+        background-position: top left;
  66
+        height: 64px;
  67
+      }
  68
+      #header h1, #header h2 {margin: 0}
  69
+      #header h2 {
  70
+        color: #888;
  71
+        font-weight: normal;
  72
+        font-size: 16px;
  73
+      }
  74
+
  75
+
  76
+      #about h3 {
  77
+        margin: 0;
  78
+        margin-bottom: 10px;
  79
+        font-size: 14px;
  80
+      }
  81
+
  82
+      #about-content {
  83
+        background-color: #ffd;
  84
+        border: 1px solid #fc0;
  85
+        margin-left: -55px;
  86
+        margin-right: -10px;
  87
+      }
  88
+      #about-content table {
  89
+        margin-top: 10px;
  90
+        margin-bottom: 10px;
  91
+        font-size: 11px;
  92
+        border-collapse: collapse;
  93
+      }
  94
+      #about-content td {
  95
+        padding: 10px;
  96
+        padding-top: 3px;
  97
+        padding-bottom: 3px;
  98
+      }
  99
+      #about-content td.name  {color: #555}
  100
+      #about-content td.value {color: #000}
  101
+
  102
+      #about-content ul {
  103
+        padding: 0;
  104
+        list-style-type: none;
  105
+      }
  106
+
  107
+      #about-content.failure {
  108
+        background-color: #fcc;
  109
+        border: 1px solid #f00;
  110
+      }
  111
+      #about-content.failure p {
  112
+        margin: 0;
  113
+        padding: 10px;
  114
+      }
  115
+
  116
+
  117
+      #getting-started {
  118
+        border-top: 1px solid #ccc;
  119
+        margin-top: 25px;
  120
+        padding-top: 15px;
  121
+      }
  122
+      #getting-started h1 {
  123
+        margin: 0;
  124
+        font-size: 20px;
  125
+      }
  126
+      #getting-started h2 {
  127
+        margin: 0;
  128
+        font-size: 14px;
  129
+        font-weight: normal;
  130
+        color: #333;
  131
+        margin-bottom: 25px;
  132
+      }
  133
+      #getting-started ol {
  134
+        margin-left: 0;
  135
+        padding-left: 0;
  136
+      }
  137
+      #getting-started li {
  138
+        font-size: 18px;
  139
+        color: #888;
  140
+        margin-bottom: 25px;
  141
+      }
  142
+      #getting-started li h2 {
  143
+        margin: 0;
  144
+        font-weight: normal;
  145
+        font-size: 18px;
  146
+        color: #333;
  147
+      }
  148
+      #getting-started li p {
  149
+        color: #555;
  150
+        font-size: 13px;
  151
+      }
  152
+
  153
+
  154
+      #sidebar ul {
  155
+        margin-left: 0;
  156
+        padding-left: 0;
  157
+      }
  158
+      #sidebar ul h3 {
  159
+        margin-top: 25px;
  160
+        font-size: 16px;
  161
+        padding-bottom: 10px;
  162
+        border-bottom: 1px solid #ccc;
  163
+      }
  164
+      #sidebar li {
  165
+        list-style-type: none;
  166
+      }
  167
+      #sidebar ul.links li {
  168
+        margin-bottom: 5px;
  169
+      }
  170
+
  171
+    </style>
  172
+    <script type="text/javascript">
  173
+      function about() {
  174
+        info = document.getElementById('about-content');
  175
+        if (window.XMLHttpRequest)
  176
+          { xhr = new XMLHttpRequest(); }
  177
+        else
  178
+          { xhr = new ActiveXObject("Microsoft.XMLHTTP"); }
  179
+        xhr.open("GET","rails/info/properties",false);
  180
+        xhr.send("");
  181
+        info.innerHTML = xhr.responseText;
  182
+        info.style.display = 'block'
  183
+      }
  184
+    </script>
  185
+  </head>
  186
+  <body>
  187
+    <div id="page">
  188
+      <div id="sidebar">
  189
+        <ul id="sidebar-items">
  190
+          <li>
  191
+            <h3>Browse the documentation</h3>
  192
+            <ul class="links">
  193
+              <li><a href="http://api.rubyonrails.org/">Rails API</a></li>
  194
+              <li><a href="http://stdlib.rubyonrails.org/">Ruby standard library</a></li>
  195
+              <li><a href="http://corelib.rubyonrails.org/">Ruby core</a></li>
  196
+              <li><a href="http://guides.rubyonrails.org/">Rails Guides</a></li>
  197
+            </ul>
  198
+          </li>
  199
+        </ul>
  200
+      </div>
  201
+
  202
+      <div id="content">
  203
+        <div id="header">
  204
+          <h1>Welcome aboard</h1>
  205
+          <h2>You&rsquo;re riding Ruby on Rails!</h2>
  206
+        </div>
  207
+
  208
+        <div id="about">
  209
+          <h3><a href="rails/info/properties" onclick="about(); return false">About your application&rsquo;s environment</a></h3>
  210
+          <div id="about-content" style="display: none"></div>
  211
+        </div>
  212
+
  213
+        <div id="getting-started">
  214
+          <h1>Getting started</h1>
  215
+          <h2>Here&rsquo;s how to get rolling:</h2>
  216
+
  217
+          <ol>
  218
+            <li>
  219
+              <h2>Use <code>rails generate</code> to create your models and controllers</h2>
  220
+              <p>To see all available options, run it without parameters.</p>
  221
+            </li>
  222
+
  223
+            <li>
  224
+              <h2>Set up a default route and remove or rename this file</h2>
  225
+              <p>Routes are set up in config/routes.rb.</p>
  226
+            </li>
  227
+
  228
+            <li>
  229
+              <h2>Create your database</h2>
  230
+              <p>Run <code>rake db:migrate</code> to create your database. If you're not using SQLite (the default), edit <code>config/database.yml</code> with your username and password.</p>
  231
+            </li>
  232
+          </ol>
  233
+        </div>
  234
+      </div>
  235
+
  236
+      <div id="footer">&nbsp;</div>
  237
+    </div>
  238
+  </body>
  239
+</html>
2  public/javascripts/application.js
... ...
@@ -0,0 +1,2 @@
  1
+// Place your application-specific JavaScript functions and classes here
  2
+// This file is automatically included by javascript_include_tag :defaults
965  public/javascripts/controls.js
... ...
@@ -0,0 +1,965 @@
  1
+// script.aculo.us controls.js v1.8.3, Thu Oct 08 11:23:33 +0200 2009
  2
+
  3
+// Copyright (c) 2005-2009 Thomas Fuchs (http://script.aculo.us, http://mir.aculo.us)
  4
+//           (c) 2005-2009 Ivan Krstic (http://blogs.law.harvard.edu/ivan)
  5
+//           (c) 2005-2009 Jon Tirsen (http://www.tirsen.com)
  6
+// Contributors:
  7
+//  Richard Livsey
  8
+//  Rahul Bhargava
  9
+//  Rob Wills
  10
+//
  11
+// script.aculo.us is freely distributable under the terms of an MIT-style license.
  12
+// For details, see the script.aculo.us web site: http://script.aculo.us/
  13
+
  14
+// Autocompleter.Base handles all the autocompletion functionality
  15
+// that's independent of the data source for autocompletion. This
  16
+// includes drawing the autocompletion menu, observing keyboard
  17
+// and mouse events, and similar.
  18
+//
  19
+// Specific autocompleters need to provide, at the very least,
  20
+// a getUpdatedChoices function that will be invoked every time
  21
+// the text inside the monitored textbox changes. This method
  22
+// should get the text for which to provide autocompletion by
  23
+// invoking this.getToken(), NOT by directly accessing
  24
+// this.element.value. This is to allow incremental tokenized
  25
+// autocompletion. Specific auto-completion logic (AJAX, etc)
  26
+// belongs in getUpdatedChoices.
  27
+//
  28
+// Tokenized incremental autocompletion is enabled automatically
  29
+// when an autocompleter is instantiated with the 'tokens' option
  30
+// in the options parameter, e.g.:
  31
+// new Ajax.Autocompleter('id','upd', '/url/', { tokens: ',' });
  32
+// will incrementally autocomplete with a comma as the token.
  33
+// Additionally, ',' in the above example can be replaced with
  34
+// a token array, e.g. { tokens: [',', '\n'] } which
  35
+// enables autocompletion on multiple tokens. This is most
  36
+// useful when one of the tokens is \n (a newline), as it
  37
+// allows smart autocompletion after linebreaks.
  38
+
  39
+if(typeof Effect == 'undefined')
  40
+  throw("controls.js requires including script.aculo.us' effects.js library");
  41
+
  42
+var Autocompleter = { };
  43
+Autocompleter.Base = Class.create({
  44
+  baseInitialize: function(element, update, options) {
  45
+    element          = $(element);
  46
+    this.element     = element;
  47
+    this.update      = $(update);
  48
+    this.hasFocus    = false;
  49
+    this.changed     = false;
  50
+    this.active      = false;
  51
+    this.index       = 0;
  52
+    this.entryCount  = 0;
  53
+    this.oldElementValue = this.element.value;
  54
+
  55
+    if(this.setOptions)
  56
+      this.setOptions(options);
  57
+    else
  58
+      this.options = options || { };
  59
+
  60
+    this.options.paramName    = this.options.paramName || this.element.name;
  61
+    this.options.tokens       = this.options.tokens || [];
  62
+    this.options.frequency    = this.options.frequency || 0.4;
  63
+    this.options.minChars     = this.options.minChars || 1;
  64
+    this.options.onShow       = this.options.onShow ||
  65
+      function(element, update){
  66
+        if(!update.style.position || update.style.position=='absolute') {
  67
+          update.style.position = 'absolute';
  68
+          Position.clone(element, update, {
  69
+            setHeight: false,
  70
+            offsetTop: element.offsetHeight
  71
+          });
  72
+        }
  73
+        Effect.Appear(update,{duration:0.15});
  74
+      };