3mix-castronaut 0.5.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/MIT-LICENSE +20 -0
- data/README.textile +75 -0
- data/Rakefile +105 -0
- data/app/config.rb +15 -0
- data/app/config.ru +24 -0
- data/app/controllers/application.rb +47 -0
- data/app/public/javascripts/application.js +3 -0
- data/app/public/javascripts/jquery.js +32 -0
- data/app/public/stylesheets/screen.css +122 -0
- data/app/views/layout.erb +27 -0
- data/app/views/login.erb +31 -0
- data/app/views/logout.erb +13 -0
- data/app/views/proxy_validate.erb +25 -0
- data/app/views/service_validate.erb +18 -0
- data/bin/castronaut +48 -0
- data/castronaut.rb +7 -0
- data/config/castronaut.example.yml +47 -0
- data/config/nginx_vhost.conf +24 -0
- data/config/thin_config.yml +13 -0
- data/lib/castronaut/adapters/active_record_adapter.rb +20 -0
- data/lib/castronaut/adapters/development/adapter.rb +13 -0
- data/lib/castronaut/adapters/development/user.rb +25 -0
- data/lib/castronaut/adapters/ldap/adapter.rb +15 -0
- data/lib/castronaut/adapters/ldap/user.rb +40 -0
- data/lib/castronaut/adapters/restful_authentication/adapter.rb +21 -0
- data/lib/castronaut/adapters/restful_authentication/user.rb +50 -0
- data/lib/castronaut/adapters.rb +17 -0
- data/lib/castronaut/authentication_result.rb +27 -0
- data/lib/castronaut/configuration.rb +95 -0
- data/lib/castronaut/db/001_create_cas_database.rb +47 -0
- data/lib/castronaut/db/002_change_username_to_identifier.rb +11 -0
- data/lib/castronaut/db/003_add_extra_info.rb +11 -0
- data/lib/castronaut/models/consumeable.rb +18 -0
- data/lib/castronaut/models/dispenser.rb +14 -0
- data/lib/castronaut/models/login_ticket.rb +53 -0
- data/lib/castronaut/models/proxy_granting_ticket.rb +69 -0
- data/lib/castronaut/models/proxy_ticket.rb +43 -0
- data/lib/castronaut/models/service_ticket.rb +100 -0
- data/lib/castronaut/models/ticket_granting_ticket.rb +70 -0
- data/lib/castronaut/presenters/base.rb +32 -0
- data/lib/castronaut/presenters/login.rb +60 -0
- data/lib/castronaut/presenters/logout.rb +40 -0
- data/lib/castronaut/presenters/process_login.rb +127 -0
- data/lib/castronaut/presenters/proxy_validate.rb +49 -0
- data/lib/castronaut/presenters/service_validate.rb +43 -0
- data/lib/castronaut/ticket_result.rb +27 -0
- data/lib/castronaut/utilities/random_string.rb +24 -0
- data/lib/castronaut.rb +34 -0
- data/lib/version.rb +5 -0
- data/spec/app/controllers/application_spec.rb +89 -0
- data/spec/castronaut/adapters/development/adapter_spec.rb +14 -0
- data/spec/castronaut/adapters/development/user_spec.rb +55 -0
- data/spec/castronaut/adapters/ldap/adapter_spec.rb +14 -0
- data/spec/castronaut/adapters/ldap/user_spec.rb +25 -0
- data/spec/castronaut/adapters/restful_authentication/adapter_spec.rb +14 -0
- data/spec/castronaut/adapters/restful_authentication/user_spec.rb +108 -0
- data/spec/castronaut/adapters_spec.rb +13 -0
- data/spec/castronaut/authentication_result_spec.rb +20 -0
- data/spec/castronaut/configuration_spec.rb +172 -0
- data/spec/castronaut/models/consumeable_spec.rb +39 -0
- data/spec/castronaut/models/dispenser_spec.rb +30 -0
- data/spec/castronaut/models/login_ticket_spec.rb +107 -0
- data/spec/castronaut/models/proxy_granting_ticket_spec.rb +302 -0
- data/spec/castronaut/models/proxy_ticket_spec.rb +109 -0
- data/spec/castronaut/models/service_ticket_spec.rb +269 -0
- data/spec/castronaut/models/ticket_granting_ticket_spec.rb +89 -0
- data/spec/castronaut/presenters/login_spec.rb +152 -0
- data/spec/castronaut/presenters/logout_spec.rb +85 -0
- data/spec/castronaut/presenters/process_login_spec.rb +300 -0
- data/spec/castronaut/presenters/proxy_validate_spec.rb +103 -0
- data/spec/castronaut/presenters/service_validate_spec.rb +86 -0
- data/spec/castronaut/ticket_result_spec.rb +42 -0
- data/spec/castronaut/utilities/random_string_spec.rb +14 -0
- data/spec/castronaut_spec.rb +26 -0
- data/spec/spec.opts +2 -0
- data/spec/spec_controller_helper.rb +17 -0
- data/spec/spec_helper.rb +49 -0
- data/spec/spec_rails_mocks.rb +132 -0
- data/vendor/activerecord/CHANGELOG +5753 -0
- data/vendor/activerecord/README +351 -0
- data/vendor/activerecord/RUNNING_UNIT_TESTS +36 -0
- data/vendor/activerecord/Rakefile +248 -0
- data/vendor/activerecord/examples/associations.png +0 -0
- data/vendor/activerecord/install.rb +30 -0
- data/vendor/activerecord/lib/active_record/aggregations.rb +189 -0
- data/vendor/activerecord/lib/active_record/association_preload.rb +282 -0
- data/vendor/activerecord/lib/active_record/associations/association_collection.rb +368 -0
- data/vendor/activerecord/lib/active_record/associations/association_proxy.rb +220 -0
- data/vendor/activerecord/lib/active_record/associations/belongs_to_association.rb +58 -0
- data/vendor/activerecord/lib/active_record/associations/belongs_to_polymorphic_association.rb +49 -0
- data/vendor/activerecord/lib/active_record/associations/has_and_belongs_to_many_association.rb +111 -0
- data/vendor/activerecord/lib/active_record/associations/has_many_association.rb +121 -0
- data/vendor/activerecord/lib/active_record/associations/has_many_through_association.rb +254 -0
- data/vendor/activerecord/lib/active_record/associations/has_one_association.rb +98 -0
- data/vendor/activerecord/lib/active_record/associations/has_one_through_association.rb +32 -0
- data/vendor/activerecord/lib/active_record/associations.rb +2012 -0
- data/vendor/activerecord/lib/active_record/attribute_methods.rb +379 -0
- data/vendor/activerecord/lib/active_record/base.rb +2744 -0
- data/vendor/activerecord/lib/active_record/calculations.rb +288 -0
- data/vendor/activerecord/lib/active_record/callbacks.rb +312 -0
- data/vendor/activerecord/lib/active_record/connection_adapters/abstract/connection_specification.rb +309 -0
- data/vendor/activerecord/lib/active_record/connection_adapters/abstract/database_statements.rb +176 -0
- data/vendor/activerecord/lib/active_record/connection_adapters/abstract/query_cache.rb +93 -0
- data/vendor/activerecord/lib/active_record/connection_adapters/abstract/quoting.rb +69 -0
- data/vendor/activerecord/lib/active_record/connection_adapters/abstract/schema_definitions.rb +664 -0
- data/vendor/activerecord/lib/active_record/connection_adapters/abstract/schema_statements.rb +428 -0
- data/vendor/activerecord/lib/active_record/connection_adapters/abstract_adapter.rb +169 -0
- data/vendor/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb +559 -0
- data/vendor/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb +994 -0
- data/vendor/activerecord/lib/active_record/connection_adapters/sqlite3_adapter.rb +34 -0
- data/vendor/activerecord/lib/active_record/connection_adapters/sqlite_adapter.rb +418 -0
- data/vendor/activerecord/lib/active_record/dirty.rb +165 -0
- data/vendor/activerecord/lib/active_record/fixtures.rb +997 -0
- data/vendor/activerecord/lib/active_record/locking/optimistic.rb +148 -0
- data/vendor/activerecord/lib/active_record/locking/pessimistic.rb +77 -0
- data/vendor/activerecord/lib/active_record/migration.rb +523 -0
- data/vendor/activerecord/lib/active_record/named_scope.rb +168 -0
- data/vendor/activerecord/lib/active_record/observer.rb +197 -0
- data/vendor/activerecord/lib/active_record/query_cache.rb +21 -0
- data/vendor/activerecord/lib/active_record/reflection.rb +239 -0
- data/vendor/activerecord/lib/active_record/schema.rb +51 -0
- data/vendor/activerecord/lib/active_record/schema_dumper.rb +171 -0
- data/vendor/activerecord/lib/active_record/serialization.rb +98 -0
- data/vendor/activerecord/lib/active_record/serializers/json_serializer.rb +80 -0
- data/vendor/activerecord/lib/active_record/serializers/xml_serializer.rb +338 -0
- data/vendor/activerecord/lib/active_record/test_case.rb +47 -0
- data/vendor/activerecord/lib/active_record/timestamp.rb +41 -0
- data/vendor/activerecord/lib/active_record/transactions.rb +130 -0
- data/vendor/activerecord/lib/active_record/validations.rb +971 -0
- data/vendor/activerecord/lib/active_record/vendor/mysql.rb +1214 -0
- data/vendor/activerecord/lib/active_record/version.rb +9 -0
- data/vendor/activerecord/lib/active_record.rb +80 -0
- data/vendor/activerecord/lib/activerecord.rb +1 -0
- data/vendor/activerecord/test/assets/example.log +1 -0
- data/vendor/activerecord/test/assets/flowers.jpg +0 -0
- data/vendor/activerecord/test/cases/aaa_create_tables_test.rb +24 -0
- data/vendor/activerecord/test/cases/active_schema_test_mysql.rb +95 -0
- data/vendor/activerecord/test/cases/active_schema_test_postgresql.rb +24 -0
- data/vendor/activerecord/test/cases/adapter_test.rb +127 -0
- data/vendor/activerecord/test/cases/adapter_test_sqlserver.rb +95 -0
- data/vendor/activerecord/test/cases/aggregations_test.rb +128 -0
- data/vendor/activerecord/test/cases/ar_schema_test.rb +33 -0
- data/vendor/activerecord/test/cases/associations/belongs_to_associations_test.rb +431 -0
- data/vendor/activerecord/test/cases/associations/callbacks_test.rb +161 -0
- data/vendor/activerecord/test/cases/associations/cascaded_eager_loading_test.rb +123 -0
- data/vendor/activerecord/test/cases/associations/eager_load_includes_full_sti_class_test.rb +36 -0
- data/vendor/activerecord/test/cases/associations/eager_load_nested_include_test.rb +83 -0
- data/vendor/activerecord/test/cases/associations/eager_singularization_test.rb +145 -0
- data/vendor/activerecord/test/cases/associations/eager_test.rb +636 -0
- data/vendor/activerecord/test/cases/associations/extension_test.rb +47 -0
- data/vendor/activerecord/test/cases/associations/has_and_belongs_to_many_associations_test.rb +706 -0
- data/vendor/activerecord/test/cases/associations/has_many_associations_test.rb +1034 -0
- data/vendor/activerecord/test/cases/associations/has_many_through_associations_test.rb +200 -0
- data/vendor/activerecord/test/cases/associations/has_one_associations_test.rb +345 -0
- data/vendor/activerecord/test/cases/associations/has_one_through_associations_test.rb +113 -0
- data/vendor/activerecord/test/cases/associations/inner_join_association_test.rb +88 -0
- data/vendor/activerecord/test/cases/associations/join_model_test.rb +714 -0
- data/vendor/activerecord/test/cases/associations_test.rb +262 -0
- data/vendor/activerecord/test/cases/attribute_methods_test.rb +238 -0
- data/vendor/activerecord/test/cases/base_test.rb +1997 -0
- data/vendor/activerecord/test/cases/binary_test.rb +34 -0
- data/vendor/activerecord/test/cases/calculations_test.rb +323 -0
- data/vendor/activerecord/test/cases/callbacks_test.rb +400 -0
- data/vendor/activerecord/test/cases/class_inheritable_attributes_test.rb +32 -0
- data/vendor/activerecord/test/cases/column_alias_test.rb +17 -0
- data/vendor/activerecord/test/cases/column_definition_test.rb +36 -0
- data/vendor/activerecord/test/cases/connection_test_firebird.rb +8 -0
- data/vendor/activerecord/test/cases/connection_test_mysql.rb +30 -0
- data/vendor/activerecord/test/cases/copy_table_test_sqlite.rb +69 -0
- data/vendor/activerecord/test/cases/database_statements_test.rb +12 -0
- data/vendor/activerecord/test/cases/datatype_test_postgresql.rb +203 -0
- data/vendor/activerecord/test/cases/date_time_test.rb +37 -0
- data/vendor/activerecord/test/cases/default_test_firebird.rb +16 -0
- data/vendor/activerecord/test/cases/defaults_test.rb +69 -0
- data/vendor/activerecord/test/cases/deprecated_finder_test.rb +30 -0
- data/vendor/activerecord/test/cases/dirty_test.rb +257 -0
- data/vendor/activerecord/test/cases/finder_respond_to_test.rb +76 -0
- data/vendor/activerecord/test/cases/finder_test.rb +890 -0
- data/vendor/activerecord/test/cases/fixtures_test.rb +626 -0
- data/vendor/activerecord/test/cases/helper.rb +47 -0
- data/vendor/activerecord/test/cases/inheritance_test.rb +262 -0
- data/vendor/activerecord/test/cases/invalid_date_test.rb +24 -0
- data/vendor/activerecord/test/cases/json_serialization_test.rb +205 -0
- data/vendor/activerecord/test/cases/lifecycle_test.rb +193 -0
- data/vendor/activerecord/test/cases/locking_test.rb +309 -0
- data/vendor/activerecord/test/cases/method_scoping_test.rb +462 -0
- data/vendor/activerecord/test/cases/migration_test.rb +1444 -0
- data/vendor/activerecord/test/cases/migration_test_firebird.rb +124 -0
- data/vendor/activerecord/test/cases/mixin_test.rb +96 -0
- data/vendor/activerecord/test/cases/modules_test.rb +39 -0
- data/vendor/activerecord/test/cases/multiple_db_test.rb +60 -0
- data/vendor/activerecord/test/cases/named_scope_test.rb +206 -0
- data/vendor/activerecord/test/cases/pk_test.rb +101 -0
- data/vendor/activerecord/test/cases/query_cache_test.rb +127 -0
- data/vendor/activerecord/test/cases/readonly_test.rb +107 -0
- data/vendor/activerecord/test/cases/reflection_test.rb +176 -0
- data/vendor/activerecord/test/cases/reserved_word_test_mysql.rb +176 -0
- data/vendor/activerecord/test/cases/schema_authorization_test_postgresql.rb +75 -0
- data/vendor/activerecord/test/cases/schema_dumper_test.rb +184 -0
- data/vendor/activerecord/test/cases/schema_test_postgresql.rb +102 -0
- data/vendor/activerecord/test/cases/serialization_test.rb +47 -0
- data/vendor/activerecord/test/cases/synonym_test_oracle.rb +17 -0
- data/vendor/activerecord/test/cases/table_name_test_sqlserver.rb +23 -0
- data/vendor/activerecord/test/cases/threaded_connections_test.rb +48 -0
- data/vendor/activerecord/test/cases/transactions_test.rb +307 -0
- data/vendor/activerecord/test/cases/unconnected_test.rb +32 -0
- data/vendor/activerecord/test/cases/validations_test.rb +1534 -0
- data/vendor/activerecord/test/cases/xml_serialization_test.rb +202 -0
- data/vendor/activerecord/test/config.rb +5 -0
- data/vendor/activerecord/test/connections/native_db2/connection.rb +25 -0
- data/vendor/activerecord/test/connections/native_firebird/connection.rb +26 -0
- data/vendor/activerecord/test/connections/native_frontbase/connection.rb +27 -0
- data/vendor/activerecord/test/connections/native_mysql/connection.rb +27 -0
- data/vendor/activerecord/test/connections/native_openbase/connection.rb +21 -0
- data/vendor/activerecord/test/connections/native_oracle/connection.rb +27 -0
- data/vendor/activerecord/test/connections/native_postgresql/connection.rb +21 -0
- data/vendor/activerecord/test/connections/native_sqlite/connection.rb +25 -0
- data/vendor/activerecord/test/connections/native_sqlite3/connection.rb +25 -0
- data/vendor/activerecord/test/connections/native_sqlite3/in_memory_connection.rb +18 -0
- data/vendor/activerecord/test/connections/native_sybase/connection.rb +23 -0
- data/vendor/activerecord/test/debug.log +358 -0
- data/vendor/activerecord/test/fixtures/accounts.yml +28 -0
- data/vendor/activerecord/test/fixtures/all/developers.yml +0 -0
- data/vendor/activerecord/test/fixtures/all/people.csv +0 -0
- data/vendor/activerecord/test/fixtures/all/tasks.yml +0 -0
- data/vendor/activerecord/test/fixtures/author_addresses.yml +5 -0
- data/vendor/activerecord/test/fixtures/author_favorites.yml +4 -0
- data/vendor/activerecord/test/fixtures/authors.yml +9 -0
- data/vendor/activerecord/test/fixtures/binaries.yml +132 -0
- data/vendor/activerecord/test/fixtures/books.yml +7 -0
- data/vendor/activerecord/test/fixtures/categories/special_categories.yml +9 -0
- data/vendor/activerecord/test/fixtures/categories/subsubdir/arbitrary_filename.yml +4 -0
- data/vendor/activerecord/test/fixtures/categories.yml +14 -0
- data/vendor/activerecord/test/fixtures/categories_ordered.yml +7 -0
- data/vendor/activerecord/test/fixtures/categories_posts.yml +23 -0
- data/vendor/activerecord/test/fixtures/categorizations.yml +17 -0
- data/vendor/activerecord/test/fixtures/clubs.yml +6 -0
- data/vendor/activerecord/test/fixtures/comments.yml +59 -0
- data/vendor/activerecord/test/fixtures/companies.yml +55 -0
- data/vendor/activerecord/test/fixtures/computers.yml +4 -0
- data/vendor/activerecord/test/fixtures/courses.yml +7 -0
- data/vendor/activerecord/test/fixtures/customers.yml +17 -0
- data/vendor/activerecord/test/fixtures/developers.yml +21 -0
- data/vendor/activerecord/test/fixtures/developers_projects.yml +17 -0
- data/vendor/activerecord/test/fixtures/edges.yml +6 -0
- data/vendor/activerecord/test/fixtures/entrants.yml +14 -0
- data/vendor/activerecord/test/fixtures/fixture_database.sqlite3 +0 -0
- data/vendor/activerecord/test/fixtures/fixture_database_2.sqlite3 +0 -0
- data/vendor/activerecord/test/fixtures/fk_test_has_fk.yml +3 -0
- data/vendor/activerecord/test/fixtures/fk_test_has_pk.yml +2 -0
- data/vendor/activerecord/test/fixtures/funny_jokes.yml +10 -0
- data/vendor/activerecord/test/fixtures/items.yml +4 -0
- data/vendor/activerecord/test/fixtures/jobs.yml +7 -0
- data/vendor/activerecord/test/fixtures/legacy_things.yml +3 -0
- data/vendor/activerecord/test/fixtures/mateys.yml +4 -0
- data/vendor/activerecord/test/fixtures/members.yml +4 -0
- data/vendor/activerecord/test/fixtures/memberships.yml +20 -0
- data/vendor/activerecord/test/fixtures/minimalistics.yml +2 -0
- data/vendor/activerecord/test/fixtures/mixed_case_monkeys.yml +6 -0
- data/vendor/activerecord/test/fixtures/mixins.yml +29 -0
- data/vendor/activerecord/test/fixtures/movies.yml +7 -0
- data/vendor/activerecord/test/fixtures/naked/csv/accounts.csv +1 -0
- data/vendor/activerecord/test/fixtures/naked/yml/accounts.yml +1 -0
- data/vendor/activerecord/test/fixtures/naked/yml/companies.yml +1 -0
- data/vendor/activerecord/test/fixtures/naked/yml/courses.yml +1 -0
- data/vendor/activerecord/test/fixtures/owners.yml +7 -0
- data/vendor/activerecord/test/fixtures/parrots.yml +27 -0
- data/vendor/activerecord/test/fixtures/parrots_pirates.yml +7 -0
- data/vendor/activerecord/test/fixtures/people.yml +6 -0
- data/vendor/activerecord/test/fixtures/pets.yml +14 -0
- data/vendor/activerecord/test/fixtures/pirates.yml +9 -0
- data/vendor/activerecord/test/fixtures/posts.yml +49 -0
- data/vendor/activerecord/test/fixtures/price_estimates.yml +7 -0
- data/vendor/activerecord/test/fixtures/projects.yml +7 -0
- data/vendor/activerecord/test/fixtures/readers.yml +9 -0
- data/vendor/activerecord/test/fixtures/references.yml +17 -0
- data/vendor/activerecord/test/fixtures/reserved_words/distinct.yml +5 -0
- data/vendor/activerecord/test/fixtures/reserved_words/distincts_selects.yml +11 -0
- data/vendor/activerecord/test/fixtures/reserved_words/group.yml +14 -0
- data/vendor/activerecord/test/fixtures/reserved_words/select.yml +8 -0
- data/vendor/activerecord/test/fixtures/reserved_words/values.yml +7 -0
- data/vendor/activerecord/test/fixtures/ships.yml +5 -0
- data/vendor/activerecord/test/fixtures/sponsors.yml +9 -0
- data/vendor/activerecord/test/fixtures/subscribers.yml +7 -0
- data/vendor/activerecord/test/fixtures/subscriptions.yml +12 -0
- data/vendor/activerecord/test/fixtures/taggings.yml +28 -0
- data/vendor/activerecord/test/fixtures/tags.yml +7 -0
- data/vendor/activerecord/test/fixtures/tasks.yml +7 -0
- data/vendor/activerecord/test/fixtures/topics.yml +42 -0
- data/vendor/activerecord/test/fixtures/treasures.yml +10 -0
- data/vendor/activerecord/test/fixtures/vertices.yml +4 -0
- data/vendor/activerecord/test/fixtures/warehouse-things.yml +3 -0
- data/vendor/activerecord/test/migrations/decimal/1_give_me_big_numbers.rb +15 -0
- data/vendor/activerecord/test/migrations/duplicate/1_people_have_last_names.rb +9 -0
- data/vendor/activerecord/test/migrations/duplicate/2_we_need_reminders.rb +12 -0
- data/vendor/activerecord/test/migrations/duplicate/3_foo.rb +7 -0
- data/vendor/activerecord/test/migrations/duplicate/3_innocent_jointable.rb +12 -0
- data/vendor/activerecord/test/migrations/duplicate_names/20080507052938_chunky.rb +7 -0
- data/vendor/activerecord/test/migrations/duplicate_names/20080507053028_chunky.rb +7 -0
- data/vendor/activerecord/test/migrations/interleaved/pass_1/3_innocent_jointable.rb +12 -0
- data/vendor/activerecord/test/migrations/interleaved/pass_2/1_people_have_last_names.rb +9 -0
- data/vendor/activerecord/test/migrations/interleaved/pass_2/3_innocent_jointable.rb +12 -0
- data/vendor/activerecord/test/migrations/interleaved/pass_3/1_people_have_last_names.rb +9 -0
- data/vendor/activerecord/test/migrations/interleaved/pass_3/2_i_raise_on_down.rb +8 -0
- data/vendor/activerecord/test/migrations/interleaved/pass_3/3_innocent_jointable.rb +12 -0
- data/vendor/activerecord/test/migrations/missing/1000_people_have_middle_names.rb +9 -0
- data/vendor/activerecord/test/migrations/missing/1_people_have_last_names.rb +9 -0
- data/vendor/activerecord/test/migrations/missing/3_we_need_reminders.rb +12 -0
- data/vendor/activerecord/test/migrations/missing/4_innocent_jointable.rb +12 -0
- data/vendor/activerecord/test/migrations/valid/1_people_have_last_names.rb +9 -0
- data/vendor/activerecord/test/migrations/valid/2_we_need_reminders.rb +12 -0
- data/vendor/activerecord/test/migrations/valid/3_innocent_jointable.rb +12 -0
- data/vendor/activerecord/test/models/author.rb +137 -0
- data/vendor/activerecord/test/models/auto_id.rb +4 -0
- data/vendor/activerecord/test/models/binary.rb +2 -0
- data/vendor/activerecord/test/models/book.rb +4 -0
- data/vendor/activerecord/test/models/categorization.rb +5 -0
- data/vendor/activerecord/test/models/category.rb +30 -0
- data/vendor/activerecord/test/models/citation.rb +6 -0
- data/vendor/activerecord/test/models/club.rb +7 -0
- data/vendor/activerecord/test/models/column_name.rb +3 -0
- data/vendor/activerecord/test/models/comment.rb +25 -0
- data/vendor/activerecord/test/models/company.rb +132 -0
- data/vendor/activerecord/test/models/company_in_module.rb +61 -0
- data/vendor/activerecord/test/models/computer.rb +3 -0
- data/vendor/activerecord/test/models/contact.rb +16 -0
- data/vendor/activerecord/test/models/course.rb +3 -0
- data/vendor/activerecord/test/models/customer.rb +55 -0
- data/vendor/activerecord/test/models/default.rb +2 -0
- data/vendor/activerecord/test/models/developer.rb +79 -0
- data/vendor/activerecord/test/models/edge.rb +5 -0
- data/vendor/activerecord/test/models/entrant.rb +3 -0
- data/vendor/activerecord/test/models/guid.rb +2 -0
- data/vendor/activerecord/test/models/item.rb +7 -0
- data/vendor/activerecord/test/models/job.rb +5 -0
- data/vendor/activerecord/test/models/joke.rb +3 -0
- data/vendor/activerecord/test/models/keyboard.rb +3 -0
- data/vendor/activerecord/test/models/legacy_thing.rb +3 -0
- data/vendor/activerecord/test/models/matey.rb +4 -0
- data/vendor/activerecord/test/models/member.rb +9 -0
- data/vendor/activerecord/test/models/membership.rb +9 -0
- data/vendor/activerecord/test/models/minimalistic.rb +2 -0
- data/vendor/activerecord/test/models/mixed_case_monkey.rb +3 -0
- data/vendor/activerecord/test/models/movie.rb +5 -0
- data/vendor/activerecord/test/models/order.rb +4 -0
- data/vendor/activerecord/test/models/owner.rb +4 -0
- data/vendor/activerecord/test/models/parrot.rb +13 -0
- data/vendor/activerecord/test/models/person.rb +10 -0
- data/vendor/activerecord/test/models/pet.rb +4 -0
- data/vendor/activerecord/test/models/pirate.rb +9 -0
- data/vendor/activerecord/test/models/post.rb +85 -0
- data/vendor/activerecord/test/models/price_estimate.rb +3 -0
- data/vendor/activerecord/test/models/project.rb +29 -0
- data/vendor/activerecord/test/models/reader.rb +4 -0
- data/vendor/activerecord/test/models/reference.rb +4 -0
- data/vendor/activerecord/test/models/reply.rb +39 -0
- data/vendor/activerecord/test/models/ship.rb +3 -0
- data/vendor/activerecord/test/models/sponsor.rb +4 -0
- data/vendor/activerecord/test/models/subject.rb +4 -0
- data/vendor/activerecord/test/models/subscriber.rb +8 -0
- data/vendor/activerecord/test/models/subscription.rb +4 -0
- data/vendor/activerecord/test/models/tag.rb +7 -0
- data/vendor/activerecord/test/models/tagging.rb +10 -0
- data/vendor/activerecord/test/models/task.rb +3 -0
- data/vendor/activerecord/test/models/topic.rb +66 -0
- data/vendor/activerecord/test/models/treasure.rb +6 -0
- data/vendor/activerecord/test/models/vertex.rb +9 -0
- data/vendor/activerecord/test/models/warehouse_thing.rb +5 -0
- data/vendor/activerecord/test/schema/mysql_specific_schema.rb +12 -0
- data/vendor/activerecord/test/schema/postgresql_specific_schema.rb +103 -0
- data/vendor/activerecord/test/schema/schema.rb +429 -0
- data/vendor/activerecord/test/schema/schema2.rb +6 -0
- data/vendor/activerecord/test/schema/sqlite_specific_schema.rb +25 -0
- data/vendor/activerecord/test/schema/sqlserver_specific_schema.rb +5 -0
- data/vendor/activesupport/CHANGELOG +1193 -0
- data/vendor/activesupport/README +43 -0
- data/vendor/activesupport/lib/active_support/base64.rb +22 -0
- data/vendor/activesupport/lib/active_support/basic_object.rb +24 -0
- data/vendor/activesupport/lib/active_support/buffered_logger.rb +121 -0
- data/vendor/activesupport/lib/active_support/cache/compressed_mem_cache_store.rb +15 -0
- data/vendor/activesupport/lib/active_support/cache/drb_store.rb +15 -0
- data/vendor/activesupport/lib/active_support/cache/file_store.rb +70 -0
- data/vendor/activesupport/lib/active_support/cache/mem_cache_store.rb +100 -0
- data/vendor/activesupport/lib/active_support/cache/memory_store.rb +38 -0
- data/vendor/activesupport/lib/active_support/cache.rb +147 -0
- data/vendor/activesupport/lib/active_support/callbacks.rb +275 -0
- data/vendor/activesupport/lib/active_support/clean_logger.rb +127 -0
- data/vendor/activesupport/lib/active_support/core_ext/array/access.rb +26 -0
- data/vendor/activesupport/lib/active_support/core_ext/array/conversions.rb +178 -0
- data/vendor/activesupport/lib/active_support/core_ext/array/extract_options.rb +20 -0
- data/vendor/activesupport/lib/active_support/core_ext/array/grouping.rb +63 -0
- data/vendor/activesupport/lib/active_support/core_ext/array/random_access.rb +12 -0
- data/vendor/activesupport/lib/active_support/core_ext/array.rb +13 -0
- data/vendor/activesupport/lib/active_support/core_ext/base64/encoding.rb +13 -0
- data/vendor/activesupport/lib/active_support/core_ext/base64.rb +4 -0
- data/vendor/activesupport/lib/active_support/core_ext/benchmark.rb +12 -0
- data/vendor/activesupport/lib/active_support/core_ext/bigdecimal/conversions.rb +41 -0
- data/vendor/activesupport/lib/active_support/core_ext/bigdecimal.rb +6 -0
- data/vendor/activesupport/lib/active_support/core_ext/blank.rb +53 -0
- data/vendor/activesupport/lib/active_support/core_ext/cgi/escape_skipping_slashes.rb +14 -0
- data/vendor/activesupport/lib/active_support/core_ext/cgi.rb +5 -0
- data/vendor/activesupport/lib/active_support/core_ext/class/attribute_accessors.rb +54 -0
- data/vendor/activesupport/lib/active_support/core_ext/class/delegating_attributes.rb +46 -0
- data/vendor/activesupport/lib/active_support/core_ext/class/inheritable_attributes.rb +140 -0
- data/vendor/activesupport/lib/active_support/core_ext/class/removal.rb +50 -0
- data/vendor/activesupport/lib/active_support/core_ext/class.rb +4 -0
- data/vendor/activesupport/lib/active_support/core_ext/date/behavior.rb +39 -0
- data/vendor/activesupport/lib/active_support/core_ext/date/calculations.rb +215 -0
- data/vendor/activesupport/lib/active_support/core_ext/date/conversions.rb +107 -0
- data/vendor/activesupport/lib/active_support/core_ext/date.rb +10 -0
- data/vendor/activesupport/lib/active_support/core_ext/date_time/calculations.rb +112 -0
- data/vendor/activesupport/lib/active_support/core_ext/date_time/conversions.rb +96 -0
- data/vendor/activesupport/lib/active_support/core_ext/date_time.rb +12 -0
- data/vendor/activesupport/lib/active_support/core_ext/duplicable.rb +37 -0
- data/vendor/activesupport/lib/active_support/core_ext/enumerable.rb +69 -0
- data/vendor/activesupport/lib/active_support/core_ext/exception.rb +41 -0
- data/vendor/activesupport/lib/active_support/core_ext/file.rb +21 -0
- data/vendor/activesupport/lib/active_support/core_ext/float/rounding.rb +24 -0
- data/vendor/activesupport/lib/active_support/core_ext/float.rb +5 -0
- data/vendor/activesupport/lib/active_support/core_ext/hash/conversions.rb +259 -0
- data/vendor/activesupport/lib/active_support/core_ext/hash/diff.rb +19 -0
- data/vendor/activesupport/lib/active_support/core_ext/hash/except.rb +25 -0
- data/vendor/activesupport/lib/active_support/core_ext/hash/indifferent_access.rb +137 -0
- data/vendor/activesupport/lib/active_support/core_ext/hash/keys.rb +52 -0
- data/vendor/activesupport/lib/active_support/core_ext/hash/reverse_merge.rb +28 -0
- data/vendor/activesupport/lib/active_support/core_ext/hash/slice.rb +30 -0
- data/vendor/activesupport/lib/active_support/core_ext/hash.rb +13 -0
- data/vendor/activesupport/lib/active_support/core_ext/integer/even_odd.rb +29 -0
- data/vendor/activesupport/lib/active_support/core_ext/integer/inflections.rb +20 -0
- data/vendor/activesupport/lib/active_support/core_ext/integer.rb +7 -0
- data/vendor/activesupport/lib/active_support/core_ext/kernel/agnostics.rb +11 -0
- data/vendor/activesupport/lib/active_support/core_ext/kernel/daemonizing.rb +7 -0
- data/vendor/activesupport/lib/active_support/core_ext/kernel/debugger.rb +13 -0
- data/vendor/activesupport/lib/active_support/core_ext/kernel/reporting.rb +59 -0
- data/vendor/activesupport/lib/active_support/core_ext/kernel/requires.rb +24 -0
- data/vendor/activesupport/lib/active_support/core_ext/kernel.rb +5 -0
- data/vendor/activesupport/lib/active_support/core_ext/load_error.rb +38 -0
- data/vendor/activesupport/lib/active_support/core_ext/logger.rb +16 -0
- data/vendor/activesupport/lib/active_support/core_ext/module/aliasing.rb +70 -0
- data/vendor/activesupport/lib/active_support/core_ext/module/attr_accessor_with_default.rb +31 -0
- data/vendor/activesupport/lib/active_support/core_ext/module/attr_internal.rb +32 -0
- data/vendor/activesupport/lib/active_support/core_ext/module/attribute_accessors.rb +58 -0
- data/vendor/activesupport/lib/active_support/core_ext/module/delegation.rb +64 -0
- data/vendor/activesupport/lib/active_support/core_ext/module/inclusion.rb +30 -0
- data/vendor/activesupport/lib/active_support/core_ext/module/introspection.rb +75 -0
- data/vendor/activesupport/lib/active_support/core_ext/module/loading.rb +23 -0
- data/vendor/activesupport/lib/active_support/core_ext/module/model_naming.rb +22 -0
- data/vendor/activesupport/lib/active_support/core_ext/module.rb +13 -0
- data/vendor/activesupport/lib/active_support/core_ext/name_error.rb +17 -0
- data/vendor/activesupport/lib/active_support/core_ext/numeric/bytes.rb +44 -0
- data/vendor/activesupport/lib/active_support/core_ext/numeric/conversions.rb +19 -0
- data/vendor/activesupport/lib/active_support/core_ext/numeric/time.rb +91 -0
- data/vendor/activesupport/lib/active_support/core_ext/numeric.rb +9 -0
- data/vendor/activesupport/lib/active_support/core_ext/object/conversions.rb +14 -0
- data/vendor/activesupport/lib/active_support/core_ext/object/extending.rb +59 -0
- data/vendor/activesupport/lib/active_support/core_ext/object/instance_variables.rb +74 -0
- data/vendor/activesupport/lib/active_support/core_ext/object/misc.rb +59 -0
- data/vendor/activesupport/lib/active_support/core_ext/object.rb +4 -0
- data/vendor/activesupport/lib/active_support/core_ext/pathname/clean_within.rb +14 -0
- data/vendor/activesupport/lib/active_support/core_ext/pathname.rb +7 -0
- data/vendor/activesupport/lib/active_support/core_ext/proc.rb +12 -0
- data/vendor/activesupport/lib/active_support/core_ext/process/daemon.rb +25 -0
- data/vendor/activesupport/lib/active_support/core_ext/process.rb +1 -0
- data/vendor/activesupport/lib/active_support/core_ext/range/blockless_step.rb +32 -0
- data/vendor/activesupport/lib/active_support/core_ext/range/conversions.rb +27 -0
- data/vendor/activesupport/lib/active_support/core_ext/range/include_range.rb +30 -0
- data/vendor/activesupport/lib/active_support/core_ext/range/overlaps.rb +15 -0
- data/vendor/activesupport/lib/active_support/core_ext/range.rb +11 -0
- data/vendor/activesupport/lib/active_support/core_ext/rexml.rb +35 -0
- data/vendor/activesupport/lib/active_support/core_ext/string/access.rb +82 -0
- data/vendor/activesupport/lib/active_support/core_ext/string/conversions.rb +28 -0
- data/vendor/activesupport/lib/active_support/core_ext/string/filters.rb +26 -0
- data/vendor/activesupport/lib/active_support/core_ext/string/inflections.rb +148 -0
- data/vendor/activesupport/lib/active_support/core_ext/string/iterators.rb +21 -0
- data/vendor/activesupport/lib/active_support/core_ext/string/starts_ends_with.rb +35 -0
- data/vendor/activesupport/lib/active_support/core_ext/string/unicode.rb +66 -0
- data/vendor/activesupport/lib/active_support/core_ext/string/xchar.rb +11 -0
- data/vendor/activesupport/lib/active_support/core_ext/string.rb +18 -0
- data/vendor/activesupport/lib/active_support/core_ext/symbol.rb +14 -0
- data/vendor/activesupport/lib/active_support/core_ext/test/unit/assertions.rb +64 -0
- data/vendor/activesupport/lib/active_support/core_ext/test.rb +1 -0
- data/vendor/activesupport/lib/active_support/core_ext/time/behavior.rb +13 -0
- data/vendor/activesupport/lib/active_support/core_ext/time/calculations.rb +276 -0
- data/vendor/activesupport/lib/active_support/core_ext/time/conversions.rb +89 -0
- data/vendor/activesupport/lib/active_support/core_ext/time/zones.rb +86 -0
- data/vendor/activesupport/lib/active_support/core_ext/time.rb +42 -0
- data/vendor/activesupport/lib/active_support/core_ext.rb +4 -0
- data/vendor/activesupport/lib/active_support/dependencies.rb +553 -0
- data/vendor/activesupport/lib/active_support/deprecation.rb +223 -0
- data/vendor/activesupport/lib/active_support/duration.rb +96 -0
- data/vendor/activesupport/lib/active_support/gzip.rb +25 -0
- data/vendor/activesupport/lib/active_support/inflections.rb +55 -0
- data/vendor/activesupport/lib/active_support/inflector.rb +313 -0
- data/vendor/activesupport/lib/active_support/json/decoding.rb +63 -0
- data/vendor/activesupport/lib/active_support/json/encoders/date.rb +14 -0
- data/vendor/activesupport/lib/active_support/json/encoders/date_time.rb +14 -0
- data/vendor/activesupport/lib/active_support/json/encoders/enumerable.rb +12 -0
- data/vendor/activesupport/lib/active_support/json/encoders/false_class.rb +5 -0
- data/vendor/activesupport/lib/active_support/json/encoders/hash.rb +47 -0
- data/vendor/activesupport/lib/active_support/json/encoders/nil_class.rb +5 -0
- data/vendor/activesupport/lib/active_support/json/encoders/numeric.rb +5 -0
- data/vendor/activesupport/lib/active_support/json/encoders/object.rb +6 -0
- data/vendor/activesupport/lib/active_support/json/encoders/regexp.rb +5 -0
- data/vendor/activesupport/lib/active_support/json/encoders/string.rb +36 -0
- data/vendor/activesupport/lib/active_support/json/encoders/symbol.rb +5 -0
- data/vendor/activesupport/lib/active_support/json/encoders/time.rb +14 -0
- data/vendor/activesupport/lib/active_support/json/encoders/true_class.rb +5 -0
- data/vendor/activesupport/lib/active_support/json/encoding.rb +37 -0
- data/vendor/activesupport/lib/active_support/json/variable.rb +10 -0
- data/vendor/activesupport/lib/active_support/json.rb +23 -0
- data/vendor/activesupport/lib/active_support/multibyte/chars.rb +137 -0
- data/vendor/activesupport/lib/active_support/multibyte/generators/generate_tables.rb +149 -0
- data/vendor/activesupport/lib/active_support/multibyte/handlers/passthru_handler.rb +9 -0
- data/vendor/activesupport/lib/active_support/multibyte/handlers/utf8_handler.rb +564 -0
- data/vendor/activesupport/lib/active_support/multibyte/handlers/utf8_handler_proc.rb +43 -0
- data/vendor/activesupport/lib/active_support/multibyte.rb +9 -0
- data/vendor/activesupport/lib/active_support/option_merger.rb +25 -0
- data/vendor/activesupport/lib/active_support/ordered_hash.rb +43 -0
- data/vendor/activesupport/lib/active_support/ordered_options.rb +19 -0
- data/vendor/activesupport/lib/active_support/string_inquirer.rb +11 -0
- data/vendor/activesupport/lib/active_support/test_case.rb +13 -0
- data/vendor/activesupport/lib/active_support/testing/default.rb +9 -0
- data/vendor/activesupport/lib/active_support/testing/setup_and_teardown.rb +93 -0
- data/vendor/activesupport/lib/active_support/time_with_zone.rb +304 -0
- data/vendor/activesupport/lib/active_support/values/time_zone.rb +396 -0
- data/vendor/activesupport/lib/active_support/values/unicode_tables.dat +0 -0
- data/vendor/activesupport/lib/active_support/vendor/builder-2.1.2/blankslate.rb +113 -0
- data/vendor/activesupport/lib/active_support/vendor/builder-2.1.2/builder/blankslate.rb +20 -0
- data/vendor/activesupport/lib/active_support/vendor/builder-2.1.2/builder/css.rb +250 -0
- data/vendor/activesupport/lib/active_support/vendor/builder-2.1.2/builder/xchar.rb +115 -0
- data/vendor/activesupport/lib/active_support/vendor/builder-2.1.2/builder/xmlbase.rb +139 -0
- data/vendor/activesupport/lib/active_support/vendor/builder-2.1.2/builder/xmlevents.rb +63 -0
- data/vendor/activesupport/lib/active_support/vendor/builder-2.1.2/builder/xmlmarkup.rb +328 -0
- data/vendor/activesupport/lib/active_support/vendor/builder-2.1.2/builder.rb +13 -0
- data/vendor/activesupport/lib/active_support/vendor/memcache-client-1.5.0/memcache.rb +849 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/data_timezone.rb +47 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/data_timezone_info.rb +228 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Africa/Algiers.rb +55 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Africa/Cairo.rb +219 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Africa/Casablanca.rb +40 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Africa/Harare.rb +18 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Africa/Johannesburg.rb +25 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Africa/Monrovia.rb +22 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Africa/Nairobi.rb +23 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Argentina/Buenos_Aires.rb +166 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Argentina/San_Juan.rb +170 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Bogota.rb +23 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Caracas.rb +23 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Chicago.rb +283 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Chihuahua.rb +136 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Denver.rb +204 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Godthab.rb +161 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Guatemala.rb +27 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Halifax.rb +274 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Indiana/Indianapolis.rb +149 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Juneau.rb +194 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/La_Paz.rb +22 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Lima.rb +35 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Los_Angeles.rb +232 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Mazatlan.rb +139 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Mexico_City.rb +144 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Monterrey.rb +131 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/New_York.rb +282 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Phoenix.rb +30 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Regina.rb +74 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Santiago.rb +205 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/St_Johns.rb +288 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/America/Tijuana.rb +196 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Almaty.rb +67 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Baghdad.rb +73 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Baku.rb +161 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Bangkok.rb +20 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Chongqing.rb +33 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Dhaka.rb +27 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Hong_Kong.rb +87 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Irkutsk.rb +165 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Jakarta.rb +30 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Jerusalem.rb +163 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Kabul.rb +20 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Kamchatka.rb +163 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Karachi.rb +30 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Katmandu.rb +20 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Kolkata.rb +25 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Krasnoyarsk.rb +163 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Kuala_Lumpur.rb +31 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Kuwait.rb +18 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Magadan.rb +163 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Muscat.rb +18 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Novosibirsk.rb +164 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Rangoon.rb +24 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Riyadh.rb +18 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Seoul.rb +34 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Shanghai.rb +35 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Singapore.rb +33 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Taipei.rb +59 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Tashkent.rb +47 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Tbilisi.rb +78 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Tehran.rb +121 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Tokyo.rb +30 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Ulaanbaatar.rb +65 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Urumqi.rb +33 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Vladivostok.rb +164 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Yakutsk.rb +163 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Yekaterinburg.rb +165 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Asia/Yerevan.rb +165 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Atlantic/Azores.rb +270 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Atlantic/Cape_Verde.rb +23 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Atlantic/South_Georgia.rb +18 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Australia/Adelaide.rb +187 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Australia/Brisbane.rb +35 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Australia/Darwin.rb +29 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Australia/Hobart.rb +193 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Australia/Melbourne.rb +185 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Australia/Perth.rb +37 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Australia/Sydney.rb +185 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Etc/UTC.rb +16 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Amsterdam.rb +228 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Athens.rb +185 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Belgrade.rb +163 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Berlin.rb +188 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Bratislava.rb +13 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Brussels.rb +232 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Bucharest.rb +181 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Budapest.rb +197 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Copenhagen.rb +179 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Dublin.rb +276 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Helsinki.rb +163 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Istanbul.rb +218 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Kiev.rb +168 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Lisbon.rb +268 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Ljubljana.rb +13 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/London.rb +288 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Madrid.rb +211 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Minsk.rb +170 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Moscow.rb +181 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Paris.rb +232 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Prague.rb +187 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Riga.rb +176 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Rome.rb +215 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Sarajevo.rb +13 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Skopje.rb +13 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Sofia.rb +173 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Stockholm.rb +165 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Tallinn.rb +172 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Vienna.rb +183 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Vilnius.rb +170 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Warsaw.rb +212 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Europe/Zagreb.rb +13 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Pacific/Auckland.rb +202 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Pacific/Fiji.rb +23 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Pacific/Guam.rb +22 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Pacific/Honolulu.rb +28 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Pacific/Majuro.rb +20 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Pacific/Midway.rb +25 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Pacific/Noumea.rb +25 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Pacific/Pago_Pago.rb +26 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Pacific/Port_Moresby.rb +20 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/definitions/Pacific/Tongatapu.rb +27 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/info_timezone.rb +52 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/linked_timezone.rb +51 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/linked_timezone_info.rb +44 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/offset_rationals.rb +95 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/time_or_datetime.rb +292 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/timezone.rb +508 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/timezone_definition.rb +56 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/timezone_info.rb +40 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/timezone_offset_info.rb +94 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/timezone_period.rb +198 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo/timezone_transition_info.rb +138 -0
- data/vendor/activesupport/lib/active_support/vendor/tzinfo-0.3.9/tzinfo.rb +33 -0
- data/vendor/activesupport/lib/active_support/vendor/xml-simple-1.0.11/xmlsimple.rb +1021 -0
- data/vendor/activesupport/lib/active_support/vendor.rb +26 -0
- data/vendor/activesupport/lib/active_support/version.rb +9 -0
- data/vendor/activesupport/lib/active_support/whiny_nil.rb +58 -0
- data/vendor/activesupport/lib/active_support.rb +61 -0
- data/vendor/activesupport/lib/activesupport.rb +1 -0
- data/vendor/isaac/LICENSE +26 -0
- data/vendor/isaac/README +78 -0
- data/vendor/isaac/TODO +3 -0
- data/vendor/isaac/VERSIONS +3 -0
- data/vendor/isaac/crypt/ISAAC.rb +171 -0
- data/vendor/isaac/isaac.gemspec +39 -0
- data/vendor/isaac/setup.rb +596 -0
- data/vendor/isaac/test/TC_ISAAC.rb +76 -0
- data/vendor/json/CHANGES +93 -0
- data/vendor/json/GPL +340 -0
- data/vendor/json/README +78 -0
- data/vendor/json/RUBY +58 -0
- data/vendor/json/Rakefile +309 -0
- data/vendor/json/TODO +1 -0
- data/vendor/json/VERSION +1 -0
- data/vendor/json/benchmarks/benchmark.txt +133 -0
- data/vendor/json/benchmarks/benchmark_generator.rb +48 -0
- data/vendor/json/benchmarks/benchmark_parser.rb +26 -0
- data/vendor/json/benchmarks/benchmark_rails.rb +26 -0
- data/vendor/json/bin/edit_json.rb +10 -0
- data/vendor/json/bin/prettify_json.rb +76 -0
- data/vendor/json/data/example.json +1 -0
- data/vendor/json/data/index.html +38 -0
- data/vendor/json/data/prototype.js +4184 -0
- data/vendor/json/ext/json/ext/generator/extconf.rb +9 -0
- data/vendor/json/ext/json/ext/generator/generator.c +875 -0
- data/vendor/json/ext/json/ext/generator/unicode.c +182 -0
- data/vendor/json/ext/json/ext/generator/unicode.h +53 -0
- data/vendor/json/ext/json/ext/parser/extconf.rb +9 -0
- data/vendor/json/ext/json/ext/parser/parser.c +1758 -0
- data/vendor/json/ext/json/ext/parser/parser.rl +638 -0
- data/vendor/json/ext/json/ext/parser/unicode.c +154 -0
- data/vendor/json/ext/json/ext/parser/unicode.h +58 -0
- data/vendor/json/install.rb +26 -0
- data/vendor/json/lib/json/Array.xpm +21 -0
- data/vendor/json/lib/json/FalseClass.xpm +21 -0
- data/vendor/json/lib/json/Hash.xpm +21 -0
- data/vendor/json/lib/json/Key.xpm +73 -0
- data/vendor/json/lib/json/NilClass.xpm +21 -0
- data/vendor/json/lib/json/Numeric.xpm +28 -0
- data/vendor/json/lib/json/String.xpm +96 -0
- data/vendor/json/lib/json/TrueClass.xpm +21 -0
- data/vendor/json/lib/json/add/core.rb +135 -0
- data/vendor/json/lib/json/add/rails.rb +58 -0
- data/vendor/json/lib/json/common.rb +354 -0
- data/vendor/json/lib/json/editor.rb +1362 -0
- data/vendor/json/lib/json/ext.rb +13 -0
- data/vendor/json/lib/json/json.xpm +1499 -0
- data/vendor/json/lib/json/pure/generator.rb +394 -0
- data/vendor/json/lib/json/pure/parser.rb +259 -0
- data/vendor/json/lib/json/pure.rb +75 -0
- data/vendor/json/lib/json/version.rb +9 -0
- data/vendor/json/lib/json.rb +235 -0
- data/vendor/json/tests/fixtures/fail1.json +1 -0
- data/vendor/json/tests/fixtures/fail10.json +1 -0
- data/vendor/json/tests/fixtures/fail11.json +1 -0
- data/vendor/json/tests/fixtures/fail12.json +1 -0
- data/vendor/json/tests/fixtures/fail13.json +1 -0
- data/vendor/json/tests/fixtures/fail14.json +1 -0
- data/vendor/json/tests/fixtures/fail18.json +1 -0
- data/vendor/json/tests/fixtures/fail19.json +1 -0
- data/vendor/json/tests/fixtures/fail2.json +1 -0
- data/vendor/json/tests/fixtures/fail20.json +1 -0
- data/vendor/json/tests/fixtures/fail21.json +1 -0
- data/vendor/json/tests/fixtures/fail22.json +1 -0
- data/vendor/json/tests/fixtures/fail23.json +1 -0
- data/vendor/json/tests/fixtures/fail24.json +1 -0
- data/vendor/json/tests/fixtures/fail25.json +1 -0
- data/vendor/json/tests/fixtures/fail27.json +2 -0
- data/vendor/json/tests/fixtures/fail28.json +2 -0
- data/vendor/json/tests/fixtures/fail3.json +1 -0
- data/vendor/json/tests/fixtures/fail4.json +1 -0
- data/vendor/json/tests/fixtures/fail5.json +1 -0
- data/vendor/json/tests/fixtures/fail6.json +1 -0
- data/vendor/json/tests/fixtures/fail7.json +1 -0
- data/vendor/json/tests/fixtures/fail8.json +1 -0
- data/vendor/json/tests/fixtures/fail9.json +1 -0
- data/vendor/json/tests/fixtures/pass1.json +56 -0
- data/vendor/json/tests/fixtures/pass15.json +1 -0
- data/vendor/json/tests/fixtures/pass16.json +1 -0
- data/vendor/json/tests/fixtures/pass17.json +1 -0
- data/vendor/json/tests/fixtures/pass2.json +1 -0
- data/vendor/json/tests/fixtures/pass26.json +1 -0
- data/vendor/json/tests/fixtures/pass3.json +6 -0
- data/vendor/json/tests/runner.rb +25 -0
- data/vendor/json/tests/test_json.rb +293 -0
- data/vendor/json/tests/test_json_addition.rb +161 -0
- data/vendor/json/tests/test_json_fixtures.rb +30 -0
- data/vendor/json/tests/test_json_generate.rb +100 -0
- data/vendor/json/tests/test_json_rails.rb +118 -0
- data/vendor/json/tests/test_json_unicode.rb +61 -0
- data/vendor/json/tools/fuzz.rb +140 -0
- data/vendor/json/tools/server.rb +62 -0
- data/vendor/rack/AUTHORS +8 -0
- data/vendor/rack/COPYING +18 -0
- data/vendor/rack/KNOWN-ISSUES +18 -0
- data/vendor/rack/RDOX +265 -0
- data/vendor/rack/README +287 -0
- data/vendor/rack/Rakefile +179 -0
- data/vendor/rack/SPEC +126 -0
- data/vendor/rack/bin/rackup +172 -0
- data/vendor/rack/contrib/rack_logo.svg +111 -0
- data/vendor/rack/example/lobster.ru +4 -0
- data/vendor/rack/example/protectedlobster.rb +14 -0
- data/vendor/rack/example/protectedlobster.ru +8 -0
- data/vendor/rack/lib/rack/adapter/camping.rb +22 -0
- data/vendor/rack/lib/rack/auth/abstract/handler.rb +28 -0
- data/vendor/rack/lib/rack/auth/abstract/request.rb +37 -0
- data/vendor/rack/lib/rack/auth/basic.rb +58 -0
- data/vendor/rack/lib/rack/auth/digest/md5.rb +124 -0
- data/vendor/rack/lib/rack/auth/digest/nonce.rb +51 -0
- data/vendor/rack/lib/rack/auth/digest/params.rb +55 -0
- data/vendor/rack/lib/rack/auth/digest/request.rb +40 -0
- data/vendor/rack/lib/rack/auth/openid.rb +437 -0
- data/vendor/rack/lib/rack/builder.rb +56 -0
- data/vendor/rack/lib/rack/cascade.rb +36 -0
- data/vendor/rack/lib/rack/commonlogger.rb +61 -0
- data/vendor/rack/lib/rack/deflater.rb +63 -0
- data/vendor/rack/lib/rack/directory.rb +158 -0
- data/vendor/rack/lib/rack/file.rb +116 -0
- data/vendor/rack/lib/rack/handler/cgi.rb +57 -0
- data/vendor/rack/lib/rack/handler/evented_mongrel.rb +8 -0
- data/vendor/rack/lib/rack/handler/fastcgi.rb +84 -0
- data/vendor/rack/lib/rack/handler/lsws.rb +52 -0
- data/vendor/rack/lib/rack/handler/mongrel.rb +78 -0
- data/vendor/rack/lib/rack/handler/scgi.rb +57 -0
- data/vendor/rack/lib/rack/handler/webrick.rb +57 -0
- data/vendor/rack/lib/rack/handler.rb +44 -0
- data/vendor/rack/lib/rack/lint.rb +401 -0
- data/vendor/rack/lib/rack/lobster.rb +65 -0
- data/vendor/rack/lib/rack/mock.rb +160 -0
- data/vendor/rack/lib/rack/recursive.rb +57 -0
- data/vendor/rack/lib/rack/reloader.rb +64 -0
- data/vendor/rack/lib/rack/request.rb +209 -0
- data/vendor/rack/lib/rack/response.rb +166 -0
- data/vendor/rack/lib/rack/session/abstract/id.rb +140 -0
- data/vendor/rack/lib/rack/session/cookie.rb +71 -0
- data/vendor/rack/lib/rack/session/memcache.rb +97 -0
- data/vendor/rack/lib/rack/session/pool.rb +73 -0
- data/vendor/rack/lib/rack/showexceptions.rb +344 -0
- data/vendor/rack/lib/rack/showstatus.rb +105 -0
- data/vendor/rack/lib/rack/static.rb +38 -0
- data/vendor/rack/lib/rack/urlmap.rb +48 -0
- data/vendor/rack/lib/rack/utils.rb +318 -0
- data/vendor/rack/lib/rack.rb +81 -0
- data/vendor/rack/test/cgi/lighttpd.conf +20 -0
- data/vendor/rack/test/cgi/test +9 -0
- data/vendor/rack/test/cgi/test.fcgi +8 -0
- data/vendor/rack/test/cgi/test.ru +7 -0
- data/vendor/rack/test/spec_rack_auth_basic.rb +69 -0
- data/vendor/rack/test/spec_rack_auth_digest.rb +169 -0
- data/vendor/rack/test/spec_rack_auth_openid.rb +137 -0
- data/vendor/rack/test/spec_rack_builder.rb +50 -0
- data/vendor/rack/test/spec_rack_camping.rb +51 -0
- data/vendor/rack/test/spec_rack_cascade.rb +50 -0
- data/vendor/rack/test/spec_rack_cgi.rb +89 -0
- data/vendor/rack/test/spec_rack_commonlogger.rb +32 -0
- data/vendor/rack/test/spec_rack_deflater.rb +70 -0
- data/vendor/rack/test/spec_rack_directory.rb +56 -0
- data/vendor/rack/test/spec_rack_fastcgi.rb +89 -0
- data/vendor/rack/test/spec_rack_file.rb +50 -0
- data/vendor/rack/test/spec_rack_handler.rb +24 -0
- data/vendor/rack/test/spec_rack_lint.rb +303 -0
- data/vendor/rack/test/spec_rack_lobster.rb +45 -0
- data/vendor/rack/test/spec_rack_mock.rb +152 -0
- data/vendor/rack/test/spec_rack_mongrel.rb +170 -0
- data/vendor/rack/test/spec_rack_recursive.rb +77 -0
- data/vendor/rack/test/spec_rack_request.rb +401 -0
- data/vendor/rack/test/spec_rack_response.rb +167 -0
- data/vendor/rack/test/spec_rack_session_cookie.rb +49 -0
- data/vendor/rack/test/spec_rack_session_memcache.rb +132 -0
- data/vendor/rack/test/spec_rack_session_pool.rb +84 -0
- data/vendor/rack/test/spec_rack_showexceptions.rb +21 -0
- data/vendor/rack/test/spec_rack_showstatus.rb +72 -0
- data/vendor/rack/test/spec_rack_static.rb +37 -0
- data/vendor/rack/test/spec_rack_urlmap.rb +175 -0
- data/vendor/rack/test/spec_rack_utils.rb +174 -0
- data/vendor/rack/test/spec_rack_webrick.rb +106 -0
- data/vendor/rack/test/testrequest.rb +45 -0
- data/vendor/sinatra/CHANGELOG +64 -0
- data/vendor/sinatra/LICENSE +22 -0
- data/vendor/sinatra/README.rdoc +533 -0
- data/vendor/sinatra/Rakefile +111 -0
- data/vendor/sinatra/images/404.png +0 -0
- data/vendor/sinatra/images/500.png +0 -0
- data/vendor/sinatra/lib/sinatra/rack/handler/mongrel.rb +85 -0
- data/vendor/sinatra/lib/sinatra/test/methods.rb +76 -0
- data/vendor/sinatra/lib/sinatra/test/rspec.rb +10 -0
- data/vendor/sinatra/lib/sinatra/test/spec.rb +10 -0
- data/vendor/sinatra/lib/sinatra/test/unit.rb +13 -0
- data/vendor/sinatra/lib/sinatra.rb +1477 -0
- data/vendor/sinatra/sinatra.gemspec +78 -0
- data/vendor/sinatra/test/app_test.rb +299 -0
- data/vendor/sinatra/test/application_test.rb +318 -0
- data/vendor/sinatra/test/builder_test.rb +101 -0
- data/vendor/sinatra/test/custom_error_test.rb +62 -0
- data/vendor/sinatra/test/erb_test.rb +136 -0
- data/vendor/sinatra/test/event_context_test.rb +15 -0
- data/vendor/sinatra/test/events_test.rb +47 -0
- data/vendor/sinatra/test/filter_test.rb +30 -0
- data/vendor/sinatra/test/haml_test.rb +233 -0
- data/vendor/sinatra/test/helper.rb +7 -0
- data/vendor/sinatra/test/mapped_error_test.rb +72 -0
- data/vendor/sinatra/test/pipeline_test.rb +66 -0
- data/vendor/sinatra/test/public/foo.xml +1 -0
- data/vendor/sinatra/test/sass_test.rb +57 -0
- data/vendor/sinatra/test/sessions_test.rb +39 -0
- data/vendor/sinatra/test/streaming_test.rb +118 -0
- data/vendor/sinatra/test/sym_params_test.rb +19 -0
- data/vendor/sinatra/test/template_test.rb +30 -0
- data/vendor/sinatra/test/use_in_file_templates_test.rb +47 -0
- data/vendor/sinatra/test/views/foo.builder +1 -0
- data/vendor/sinatra/test/views/foo.erb +1 -0
- data/vendor/sinatra/test/views/foo.haml +1 -0
- data/vendor/sinatra/test/views/foo.sass +2 -0
- data/vendor/sinatra/test/views/foo_layout.erb +2 -0
- data/vendor/sinatra/test/views/foo_layout.haml +2 -0
- data/vendor/sinatra/test/views/layout_test/foo.builder +1 -0
- data/vendor/sinatra/test/views/layout_test/foo.erb +1 -0
- data/vendor/sinatra/test/views/layout_test/foo.haml +1 -0
- data/vendor/sinatra/test/views/layout_test/foo.sass +2 -0
- data/vendor/sinatra/test/views/layout_test/layout.builder +3 -0
- data/vendor/sinatra/test/views/layout_test/layout.erb +1 -0
- data/vendor/sinatra/test/views/layout_test/layout.haml +1 -0
- data/vendor/sinatra/test/views/layout_test/layout.sass +2 -0
- data/vendor/sinatra/test/views/no_layout/no_layout.builder +1 -0
- data/vendor/sinatra/test/views/no_layout/no_layout.haml +1 -0
- metadata +1121 -0
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
require 'singleton'
|
|
2
|
+
require 'set'
|
|
3
|
+
|
|
4
|
+
module ActiveRecord
|
|
5
|
+
module Observing # :nodoc:
|
|
6
|
+
def self.included(base)
|
|
7
|
+
base.extend ClassMethods
|
|
8
|
+
end
|
|
9
|
+
|
|
10
|
+
module ClassMethods
|
|
11
|
+
# Activates the observers assigned. Examples:
|
|
12
|
+
#
|
|
13
|
+
# # Calls PersonObserver.instance
|
|
14
|
+
# ActiveRecord::Base.observers = :person_observer
|
|
15
|
+
#
|
|
16
|
+
# # Calls Cacher.instance and GarbageCollector.instance
|
|
17
|
+
# ActiveRecord::Base.observers = :cacher, :garbage_collector
|
|
18
|
+
#
|
|
19
|
+
# # Same as above, just using explicit class references
|
|
20
|
+
# ActiveRecord::Base.observers = Cacher, GarbageCollector
|
|
21
|
+
#
|
|
22
|
+
# Note: Setting this does not instantiate the observers yet. +instantiate_observers+ is
|
|
23
|
+
# called during startup, and before each development request.
|
|
24
|
+
def observers=(*observers)
|
|
25
|
+
@observers = observers.flatten
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
# Gets the current observers.
|
|
29
|
+
def observers
|
|
30
|
+
@observers ||= []
|
|
31
|
+
end
|
|
32
|
+
|
|
33
|
+
# Instantiate the global Active Record observers.
|
|
34
|
+
def instantiate_observers
|
|
35
|
+
return if @observers.blank?
|
|
36
|
+
@observers.each do |observer|
|
|
37
|
+
if observer.respond_to?(:to_sym) # Symbol or String
|
|
38
|
+
observer.to_s.camelize.constantize.instance
|
|
39
|
+
elsif observer.respond_to?(:instance)
|
|
40
|
+
observer.instance
|
|
41
|
+
else
|
|
42
|
+
raise ArgumentError, "#{observer} must be a lowercase, underscored class name (or an instance of the class itself) responding to the instance method. Example: Person.observers = :big_brother # calls BigBrother.instance"
|
|
43
|
+
end
|
|
44
|
+
end
|
|
45
|
+
end
|
|
46
|
+
|
|
47
|
+
protected
|
|
48
|
+
# Notify observers when the observed class is subclassed.
|
|
49
|
+
def inherited(subclass)
|
|
50
|
+
super
|
|
51
|
+
changed
|
|
52
|
+
notify_observers :observed_class_inherited, subclass
|
|
53
|
+
end
|
|
54
|
+
end
|
|
55
|
+
end
|
|
56
|
+
|
|
57
|
+
# Observer classes respond to lifecycle callbacks to implement trigger-like
|
|
58
|
+
# behavior outside the original class. This is a great way to reduce the
|
|
59
|
+
# clutter that normally comes when the model class is burdened with
|
|
60
|
+
# functionality that doesn't pertain to the core responsibility of the
|
|
61
|
+
# class. Example:
|
|
62
|
+
#
|
|
63
|
+
# class CommentObserver < ActiveRecord::Observer
|
|
64
|
+
# def after_save(comment)
|
|
65
|
+
# Notifications.deliver_comment("admin@do.com", "New comment was posted", comment)
|
|
66
|
+
# end
|
|
67
|
+
# end
|
|
68
|
+
#
|
|
69
|
+
# This Observer sends an email when a Comment#save is finished.
|
|
70
|
+
#
|
|
71
|
+
# class ContactObserver < ActiveRecord::Observer
|
|
72
|
+
# def after_create(contact)
|
|
73
|
+
# contact.logger.info('New contact added!')
|
|
74
|
+
# end
|
|
75
|
+
#
|
|
76
|
+
# def after_destroy(contact)
|
|
77
|
+
# contact.logger.warn("Contact with an id of #{contact.id} was destroyed!")
|
|
78
|
+
# end
|
|
79
|
+
# end
|
|
80
|
+
#
|
|
81
|
+
# This Observer uses logger to log when specific callbacks are triggered.
|
|
82
|
+
#
|
|
83
|
+
# == Observing a class that can't be inferred
|
|
84
|
+
#
|
|
85
|
+
# Observers will by default be mapped to the class with which they share a name. So CommentObserver will
|
|
86
|
+
# be tied to observing Comment, ProductManagerObserver to ProductManager, and so on. If you want to name your observer
|
|
87
|
+
# differently than the class you're interested in observing, you can use the Observer.observe class method which takes
|
|
88
|
+
# either the concrete class (Product) or a symbol for that class (:product):
|
|
89
|
+
#
|
|
90
|
+
# class AuditObserver < ActiveRecord::Observer
|
|
91
|
+
# observe :account
|
|
92
|
+
#
|
|
93
|
+
# def after_update(account)
|
|
94
|
+
# AuditTrail.new(account, "UPDATED")
|
|
95
|
+
# end
|
|
96
|
+
# end
|
|
97
|
+
#
|
|
98
|
+
# If the audit observer needs to watch more than one kind of object, this can be specified with multiple arguments:
|
|
99
|
+
#
|
|
100
|
+
# class AuditObserver < ActiveRecord::Observer
|
|
101
|
+
# observe :account, :balance
|
|
102
|
+
#
|
|
103
|
+
# def after_update(record)
|
|
104
|
+
# AuditTrail.new(record, "UPDATED")
|
|
105
|
+
# end
|
|
106
|
+
# end
|
|
107
|
+
#
|
|
108
|
+
# The AuditObserver will now act on both updates to Account and Balance by treating them both as records.
|
|
109
|
+
#
|
|
110
|
+
# == Available callback methods
|
|
111
|
+
#
|
|
112
|
+
# The observer can implement callback methods for each of the methods described in the Callbacks module.
|
|
113
|
+
#
|
|
114
|
+
# == Storing Observers in Rails
|
|
115
|
+
#
|
|
116
|
+
# If you're using Active Record within Rails, observer classes are usually stored in app/models with the
|
|
117
|
+
# naming convention of app/models/audit_observer.rb.
|
|
118
|
+
#
|
|
119
|
+
# == Configuration
|
|
120
|
+
#
|
|
121
|
+
# In order to activate an observer, list it in the <tt>config.active_record.observers</tt> configuration setting in your
|
|
122
|
+
# <tt>config/environment.rb</tt> file.
|
|
123
|
+
#
|
|
124
|
+
# config.active_record.observers = :comment_observer, :signup_observer
|
|
125
|
+
#
|
|
126
|
+
# Observers will not be invoked unless you define these in your application configuration.
|
|
127
|
+
#
|
|
128
|
+
# == Loading
|
|
129
|
+
#
|
|
130
|
+
# Observers register themselves in the model class they observe, since it is the class that
|
|
131
|
+
# notifies them of events when they occur. As a side-effect, when an observer is loaded its
|
|
132
|
+
# corresponding model class is loaded.
|
|
133
|
+
#
|
|
134
|
+
# Up to (and including) Rails 2.0.2 observers were instantiated between plugins and
|
|
135
|
+
# application initializers. Now observers are loaded after application initializers,
|
|
136
|
+
# so observed models can make use of extensions.
|
|
137
|
+
#
|
|
138
|
+
# If by any chance you are using observed models in the initialization you can still
|
|
139
|
+
# load their observers by calling <tt>ModelObserver.instance</tt> before. Observers are
|
|
140
|
+
# singletons and that call instantiates and registers them.
|
|
141
|
+
#
|
|
142
|
+
class Observer
|
|
143
|
+
include Singleton
|
|
144
|
+
|
|
145
|
+
class << self
|
|
146
|
+
# Attaches the observer to the supplied model classes.
|
|
147
|
+
def observe(*models)
|
|
148
|
+
models.flatten!
|
|
149
|
+
models.collect! { |model| model.is_a?(Symbol) ? model.to_s.camelize.constantize : model }
|
|
150
|
+
define_method(:observed_classes) { Set.new(models) }
|
|
151
|
+
end
|
|
152
|
+
|
|
153
|
+
# The class observed by default is inferred from the observer's class name:
|
|
154
|
+
# assert_equal Person, PersonObserver.observed_class
|
|
155
|
+
def observed_class
|
|
156
|
+
if observed_class_name = name[/(.*)Observer/, 1]
|
|
157
|
+
observed_class_name.constantize
|
|
158
|
+
else
|
|
159
|
+
nil
|
|
160
|
+
end
|
|
161
|
+
end
|
|
162
|
+
end
|
|
163
|
+
|
|
164
|
+
# Start observing the declared classes and their subclasses.
|
|
165
|
+
def initialize
|
|
166
|
+
Set.new(observed_classes + observed_subclasses).each { |klass| add_observer! klass }
|
|
167
|
+
end
|
|
168
|
+
|
|
169
|
+
# Send observed_method(object) if the method exists.
|
|
170
|
+
def update(observed_method, object) #:nodoc:
|
|
171
|
+
send(observed_method, object) if respond_to?(observed_method)
|
|
172
|
+
end
|
|
173
|
+
|
|
174
|
+
# Special method sent by the observed class when it is inherited.
|
|
175
|
+
# Passes the new subclass.
|
|
176
|
+
def observed_class_inherited(subclass) #:nodoc:
|
|
177
|
+
self.class.observe(observed_classes + [subclass])
|
|
178
|
+
add_observer!(subclass)
|
|
179
|
+
end
|
|
180
|
+
|
|
181
|
+
protected
|
|
182
|
+
def observed_classes
|
|
183
|
+
Set.new([self.class.observed_class].compact.flatten)
|
|
184
|
+
end
|
|
185
|
+
|
|
186
|
+
def observed_subclasses
|
|
187
|
+
observed_classes.sum([]) { |klass| klass.send(:subclasses) }
|
|
188
|
+
end
|
|
189
|
+
|
|
190
|
+
def add_observer!(klass)
|
|
191
|
+
klass.add_observer(self)
|
|
192
|
+
if respond_to?(:after_find) && !klass.method_defined?(:after_find)
|
|
193
|
+
klass.class_eval 'def after_find() end'
|
|
194
|
+
end
|
|
195
|
+
end
|
|
196
|
+
end
|
|
197
|
+
end
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
module ActiveRecord
|
|
2
|
+
module QueryCache
|
|
3
|
+
# Enable the query cache within the block if Active Record is configured.
|
|
4
|
+
def cache(&block)
|
|
5
|
+
if ActiveRecord::Base.configurations.blank?
|
|
6
|
+
yield
|
|
7
|
+
else
|
|
8
|
+
connection.cache(&block)
|
|
9
|
+
end
|
|
10
|
+
end
|
|
11
|
+
|
|
12
|
+
# Disable the query cache within the block if Active Record is configured.
|
|
13
|
+
def uncached(&block)
|
|
14
|
+
if ActiveRecord::Base.configurations.blank?
|
|
15
|
+
yield
|
|
16
|
+
else
|
|
17
|
+
connection.uncached(&block)
|
|
18
|
+
end
|
|
19
|
+
end
|
|
20
|
+
end
|
|
21
|
+
end
|
|
@@ -0,0 +1,239 @@
|
|
|
1
|
+
module ActiveRecord
|
|
2
|
+
module Reflection # :nodoc:
|
|
3
|
+
def self.included(base)
|
|
4
|
+
base.extend(ClassMethods)
|
|
5
|
+
end
|
|
6
|
+
|
|
7
|
+
# Reflection allows you to interrogate Active Record classes and objects about their associations and aggregations.
|
|
8
|
+
# This information can, for example, be used in a form builder that took an Active Record object and created input
|
|
9
|
+
# fields for all of the attributes depending on their type and displayed the associations to other objects.
|
|
10
|
+
#
|
|
11
|
+
# You can find the interface for the AggregateReflection and AssociationReflection classes in the abstract MacroReflection class.
|
|
12
|
+
module ClassMethods
|
|
13
|
+
def create_reflection(macro, name, options, active_record)
|
|
14
|
+
case macro
|
|
15
|
+
when :has_many, :belongs_to, :has_one, :has_and_belongs_to_many
|
|
16
|
+
reflection = AssociationReflection.new(macro, name, options, active_record)
|
|
17
|
+
when :composed_of
|
|
18
|
+
reflection = AggregateReflection.new(macro, name, options, active_record)
|
|
19
|
+
end
|
|
20
|
+
write_inheritable_hash :reflections, name => reflection
|
|
21
|
+
reflection
|
|
22
|
+
end
|
|
23
|
+
|
|
24
|
+
# Returns a hash containing all AssociationReflection objects for the current class
|
|
25
|
+
# Example:
|
|
26
|
+
#
|
|
27
|
+
# Invoice.reflections
|
|
28
|
+
# Account.reflections
|
|
29
|
+
#
|
|
30
|
+
def reflections
|
|
31
|
+
read_inheritable_attribute(:reflections) || write_inheritable_attribute(:reflections, {})
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
# Returns an array of AggregateReflection objects for all the aggregations in the class.
|
|
35
|
+
def reflect_on_all_aggregations
|
|
36
|
+
reflections.values.select { |reflection| reflection.is_a?(AggregateReflection) }
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
# Returns the AggregateReflection object for the named +aggregation+ (use the symbol). Example:
|
|
40
|
+
#
|
|
41
|
+
# Account.reflect_on_aggregation(:balance) # returns the balance AggregateReflection
|
|
42
|
+
#
|
|
43
|
+
def reflect_on_aggregation(aggregation)
|
|
44
|
+
reflections[aggregation].is_a?(AggregateReflection) ? reflections[aggregation] : nil
|
|
45
|
+
end
|
|
46
|
+
|
|
47
|
+
# Returns an array of AssociationReflection objects for all the associations in the class. If you only want to reflect on a
|
|
48
|
+
# certain association type, pass in the symbol (<tt>:has_many</tt>, <tt>:has_one</tt>, <tt>:belongs_to</tt>) for that as the first parameter.
|
|
49
|
+
# Example:
|
|
50
|
+
#
|
|
51
|
+
# Account.reflect_on_all_associations # returns an array of all associations
|
|
52
|
+
# Account.reflect_on_all_associations(:has_many) # returns an array of all has_many associations
|
|
53
|
+
#
|
|
54
|
+
def reflect_on_all_associations(macro = nil)
|
|
55
|
+
association_reflections = reflections.values.select { |reflection| reflection.is_a?(AssociationReflection) }
|
|
56
|
+
macro ? association_reflections.select { |reflection| reflection.macro == macro } : association_reflections
|
|
57
|
+
end
|
|
58
|
+
|
|
59
|
+
# Returns the AssociationReflection object for the named +association+ (use the symbol). Example:
|
|
60
|
+
#
|
|
61
|
+
# Account.reflect_on_association(:owner) # returns the owner AssociationReflection
|
|
62
|
+
# Invoice.reflect_on_association(:line_items).macro # returns :has_many
|
|
63
|
+
#
|
|
64
|
+
def reflect_on_association(association)
|
|
65
|
+
reflections[association].is_a?(AssociationReflection) ? reflections[association] : nil
|
|
66
|
+
end
|
|
67
|
+
end
|
|
68
|
+
|
|
69
|
+
|
|
70
|
+
# Abstract base class for AggregateReflection and AssociationReflection that describes the interface available for both of
|
|
71
|
+
# those classes. Objects of AggregateReflection and AssociationReflection are returned by the Reflection::ClassMethods.
|
|
72
|
+
class MacroReflection
|
|
73
|
+
attr_reader :active_record
|
|
74
|
+
|
|
75
|
+
def initialize(macro, name, options, active_record)
|
|
76
|
+
@macro, @name, @options, @active_record = macro, name, options, active_record
|
|
77
|
+
end
|
|
78
|
+
|
|
79
|
+
# Returns the name of the macro. For example, <tt>composed_of :balance, :class_name => 'Money'</tt> will return
|
|
80
|
+
# <tt>:balance</tt> or for <tt>has_many :clients</tt> it will return <tt>:clients</tt>.
|
|
81
|
+
def name
|
|
82
|
+
@name
|
|
83
|
+
end
|
|
84
|
+
|
|
85
|
+
# Returns the macro type. For example, <tt>composed_of :balance, :class_name => 'Money'</tt> will return <tt>:composed_of</tt>
|
|
86
|
+
# or for <tt>has_many :clients</tt> will return <tt>:has_many</tt>.
|
|
87
|
+
def macro
|
|
88
|
+
@macro
|
|
89
|
+
end
|
|
90
|
+
|
|
91
|
+
# Returns the hash of options used for the macro. For example, it would return <tt>{ :class_name => "Money" }</tt> for
|
|
92
|
+
# <tt>composed_of :balance, :class_name => 'Money'</tt> or +{}+ for <tt>has_many :clients</tt>.
|
|
93
|
+
def options
|
|
94
|
+
@options
|
|
95
|
+
end
|
|
96
|
+
|
|
97
|
+
# Returns the class for the macro. For example, <tt>composed_of :balance, :class_name => 'Money'</tt> returns the Money
|
|
98
|
+
# class and <tt>has_many :clients</tt> returns the Client class.
|
|
99
|
+
def klass
|
|
100
|
+
@klass ||= class_name.constantize
|
|
101
|
+
end
|
|
102
|
+
|
|
103
|
+
# Returns the class name for the macro. For example, <tt>composed_of :balance, :class_name => 'Money'</tt> returns <tt>'Money'</tt>
|
|
104
|
+
# and <tt>has_many :clients</tt> returns <tt>'Client'</tt>.
|
|
105
|
+
def class_name
|
|
106
|
+
@class_name ||= options[:class_name] || derive_class_name
|
|
107
|
+
end
|
|
108
|
+
|
|
109
|
+
# Returns +true+ if +self+ and +other_aggregation+ have the same +name+ attribute, +active_record+ attribute,
|
|
110
|
+
# and +other_aggregation+ has an options hash assigned to it.
|
|
111
|
+
def ==(other_aggregation)
|
|
112
|
+
name == other_aggregation.name && other_aggregation.options && active_record == other_aggregation.active_record
|
|
113
|
+
end
|
|
114
|
+
|
|
115
|
+
private
|
|
116
|
+
def derive_class_name
|
|
117
|
+
name.to_s.camelize
|
|
118
|
+
end
|
|
119
|
+
end
|
|
120
|
+
|
|
121
|
+
|
|
122
|
+
# Holds all the meta-data about an aggregation as it was specified in the Active Record class.
|
|
123
|
+
class AggregateReflection < MacroReflection #:nodoc:
|
|
124
|
+
end
|
|
125
|
+
|
|
126
|
+
# Holds all the meta-data about an association as it was specified in the Active Record class.
|
|
127
|
+
class AssociationReflection < MacroReflection #:nodoc:
|
|
128
|
+
def klass
|
|
129
|
+
@klass ||= active_record.send(:compute_type, class_name)
|
|
130
|
+
end
|
|
131
|
+
|
|
132
|
+
def table_name
|
|
133
|
+
@table_name ||= klass.table_name
|
|
134
|
+
end
|
|
135
|
+
|
|
136
|
+
def quoted_table_name
|
|
137
|
+
@quoted_table_name ||= klass.quoted_table_name
|
|
138
|
+
end
|
|
139
|
+
|
|
140
|
+
def primary_key_name
|
|
141
|
+
@primary_key_name ||= options[:foreign_key] || derive_primary_key_name
|
|
142
|
+
end
|
|
143
|
+
|
|
144
|
+
def association_foreign_key
|
|
145
|
+
@association_foreign_key ||= @options[:association_foreign_key] || class_name.foreign_key
|
|
146
|
+
end
|
|
147
|
+
|
|
148
|
+
def counter_cache_column
|
|
149
|
+
if options[:counter_cache] == true
|
|
150
|
+
"#{active_record.name.underscore.pluralize}_count"
|
|
151
|
+
elsif options[:counter_cache]
|
|
152
|
+
options[:counter_cache]
|
|
153
|
+
end
|
|
154
|
+
end
|
|
155
|
+
|
|
156
|
+
# Returns the AssociationReflection object specified in the <tt>:through</tt> option
|
|
157
|
+
# of a HasManyThrough or HasOneThrough association. Example:
|
|
158
|
+
#
|
|
159
|
+
# class Post < ActiveRecord::Base
|
|
160
|
+
# has_many :taggings
|
|
161
|
+
# has_many :tags, :through => :taggings
|
|
162
|
+
# end
|
|
163
|
+
#
|
|
164
|
+
# tags_reflection = Post.reflect_on_association(:tags)
|
|
165
|
+
# taggings_reflection = tags_reflection.through_reflection
|
|
166
|
+
#
|
|
167
|
+
def through_reflection
|
|
168
|
+
@through_reflection ||= options[:through] ? active_record.reflect_on_association(options[:through]) : false
|
|
169
|
+
end
|
|
170
|
+
|
|
171
|
+
# Gets an array of possible <tt>:through</tt> source reflection names:
|
|
172
|
+
#
|
|
173
|
+
# [:singularized, :pluralized]
|
|
174
|
+
#
|
|
175
|
+
def source_reflection_names
|
|
176
|
+
@source_reflection_names ||= (options[:source] ? [options[:source]] : [name.to_s.singularize, name]).collect { |n| n.to_sym }
|
|
177
|
+
end
|
|
178
|
+
|
|
179
|
+
# Gets the source of the through reflection. It checks both a singularized and pluralized form for <tt>:belongs_to</tt> or <tt>:has_many</tt>.
|
|
180
|
+
# (The <tt>:tags</tt> association on Tagging below.)
|
|
181
|
+
#
|
|
182
|
+
# class Post < ActiveRecord::Base
|
|
183
|
+
# has_many :taggings
|
|
184
|
+
# has_many :tags, :through => :taggings
|
|
185
|
+
# end
|
|
186
|
+
#
|
|
187
|
+
def source_reflection
|
|
188
|
+
return nil unless through_reflection
|
|
189
|
+
@source_reflection ||= source_reflection_names.collect { |name| through_reflection.klass.reflect_on_association(name) }.compact.first
|
|
190
|
+
end
|
|
191
|
+
|
|
192
|
+
def check_validity!
|
|
193
|
+
if options[:through]
|
|
194
|
+
if through_reflection.nil?
|
|
195
|
+
raise HasManyThroughAssociationNotFoundError.new(active_record.name, self)
|
|
196
|
+
end
|
|
197
|
+
|
|
198
|
+
if source_reflection.nil?
|
|
199
|
+
raise HasManyThroughSourceAssociationNotFoundError.new(self)
|
|
200
|
+
end
|
|
201
|
+
|
|
202
|
+
if options[:source_type] && source_reflection.options[:polymorphic].nil?
|
|
203
|
+
raise HasManyThroughAssociationPointlessSourceTypeError.new(active_record.name, self, source_reflection)
|
|
204
|
+
end
|
|
205
|
+
|
|
206
|
+
if source_reflection.options[:polymorphic] && options[:source_type].nil?
|
|
207
|
+
raise HasManyThroughAssociationPolymorphicError.new(active_record.name, self, source_reflection)
|
|
208
|
+
end
|
|
209
|
+
|
|
210
|
+
unless [:belongs_to, :has_many].include?(source_reflection.macro) && source_reflection.options[:through].nil?
|
|
211
|
+
raise HasManyThroughSourceAssociationMacroError.new(self)
|
|
212
|
+
end
|
|
213
|
+
end
|
|
214
|
+
end
|
|
215
|
+
|
|
216
|
+
private
|
|
217
|
+
def derive_class_name
|
|
218
|
+
# get the class_name of the belongs_to association of the through reflection
|
|
219
|
+
if through_reflection
|
|
220
|
+
options[:source_type] || source_reflection.class_name
|
|
221
|
+
else
|
|
222
|
+
class_name = name.to_s.camelize
|
|
223
|
+
class_name = class_name.singularize if [ :has_many, :has_and_belongs_to_many ].include?(macro)
|
|
224
|
+
class_name
|
|
225
|
+
end
|
|
226
|
+
end
|
|
227
|
+
|
|
228
|
+
def derive_primary_key_name
|
|
229
|
+
if macro == :belongs_to
|
|
230
|
+
"#{name}_id"
|
|
231
|
+
elsif options[:as]
|
|
232
|
+
"#{options[:as]}_id"
|
|
233
|
+
else
|
|
234
|
+
active_record.name.foreign_key
|
|
235
|
+
end
|
|
236
|
+
end
|
|
237
|
+
end
|
|
238
|
+
end
|
|
239
|
+
end
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
module ActiveRecord
|
|
2
|
+
# Allows programmers to programmatically define a schema in a portable
|
|
3
|
+
# DSL. This means you can define tables, indexes, etc. without using SQL
|
|
4
|
+
# directly, so your applications can more easily support multiple
|
|
5
|
+
# databases.
|
|
6
|
+
#
|
|
7
|
+
# Usage:
|
|
8
|
+
#
|
|
9
|
+
# ActiveRecord::Schema.define do
|
|
10
|
+
# create_table :authors do |t|
|
|
11
|
+
# t.string :name, :null => false
|
|
12
|
+
# end
|
|
13
|
+
#
|
|
14
|
+
# add_index :authors, :name, :unique
|
|
15
|
+
#
|
|
16
|
+
# create_table :posts do |t|
|
|
17
|
+
# t.integer :author_id, :null => false
|
|
18
|
+
# t.string :subject
|
|
19
|
+
# t.text :body
|
|
20
|
+
# t.boolean :private, :default => false
|
|
21
|
+
# end
|
|
22
|
+
#
|
|
23
|
+
# add_index :posts, :author_id
|
|
24
|
+
# end
|
|
25
|
+
#
|
|
26
|
+
# ActiveRecord::Schema is only supported by database adapters that also
|
|
27
|
+
# support migrations, the two features being very similar.
|
|
28
|
+
class Schema < Migration
|
|
29
|
+
private_class_method :new
|
|
30
|
+
|
|
31
|
+
# Eval the given block. All methods available to the current connection
|
|
32
|
+
# adapter are available within the block, so you can easily use the
|
|
33
|
+
# database definition DSL to build up your schema (+create_table+,
|
|
34
|
+
# +add_index+, etc.).
|
|
35
|
+
#
|
|
36
|
+
# The +info+ hash is optional, and if given is used to define metadata
|
|
37
|
+
# about the current schema (currently, only the schema's version):
|
|
38
|
+
#
|
|
39
|
+
# ActiveRecord::Schema.define(:version => 20380119000001) do
|
|
40
|
+
# ...
|
|
41
|
+
# end
|
|
42
|
+
def self.define(info={}, &block)
|
|
43
|
+
instance_eval(&block)
|
|
44
|
+
|
|
45
|
+
unless info[:version].blank?
|
|
46
|
+
initialize_schema_migrations_table
|
|
47
|
+
assume_migrated_upto_version info[:version]
|
|
48
|
+
end
|
|
49
|
+
end
|
|
50
|
+
end
|
|
51
|
+
end
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
require 'stringio'
|
|
2
|
+
require 'bigdecimal'
|
|
3
|
+
|
|
4
|
+
module ActiveRecord
|
|
5
|
+
# This class is used to dump the database schema for some connection to some
|
|
6
|
+
# output format (i.e., ActiveRecord::Schema).
|
|
7
|
+
class SchemaDumper #:nodoc:
|
|
8
|
+
private_class_method :new
|
|
9
|
+
|
|
10
|
+
# A list of tables which should not be dumped to the schema.
|
|
11
|
+
# Acceptable values are strings as well as regexp.
|
|
12
|
+
# This setting is only used if ActiveRecord::Base.schema_format == :ruby
|
|
13
|
+
cattr_accessor :ignore_tables
|
|
14
|
+
@@ignore_tables = []
|
|
15
|
+
|
|
16
|
+
def self.dump(connection=ActiveRecord::Base.connection, stream=STDOUT)
|
|
17
|
+
new(connection).dump(stream)
|
|
18
|
+
stream
|
|
19
|
+
end
|
|
20
|
+
|
|
21
|
+
def dump(stream)
|
|
22
|
+
header(stream)
|
|
23
|
+
tables(stream)
|
|
24
|
+
trailer(stream)
|
|
25
|
+
stream
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
private
|
|
29
|
+
|
|
30
|
+
def initialize(connection)
|
|
31
|
+
@connection = connection
|
|
32
|
+
@types = @connection.native_database_types
|
|
33
|
+
@version = Migrator::current_version rescue nil
|
|
34
|
+
end
|
|
35
|
+
|
|
36
|
+
def header(stream)
|
|
37
|
+
define_params = @version ? ":version => #{@version}" : ""
|
|
38
|
+
|
|
39
|
+
stream.puts <<HEADER
|
|
40
|
+
# This file is auto-generated from the current state of the database. Instead of editing this file,
|
|
41
|
+
# please use the migrations feature of Active Record to incrementally modify your database, and
|
|
42
|
+
# then regenerate this schema definition.
|
|
43
|
+
#
|
|
44
|
+
# Note that this schema.rb definition is the authoritative source for your database schema. If you need
|
|
45
|
+
# to create the application database on another system, you should be using db:schema:load, not running
|
|
46
|
+
# all the migrations from scratch. The latter is a flawed and unsustainable approach (the more migrations
|
|
47
|
+
# you'll amass, the slower it'll run and the greater likelihood for issues).
|
|
48
|
+
#
|
|
49
|
+
# It's strongly recommended to check this file into your version control system.
|
|
50
|
+
|
|
51
|
+
ActiveRecord::Schema.define(#{define_params}) do
|
|
52
|
+
|
|
53
|
+
HEADER
|
|
54
|
+
end
|
|
55
|
+
|
|
56
|
+
def trailer(stream)
|
|
57
|
+
stream.puts "end"
|
|
58
|
+
end
|
|
59
|
+
|
|
60
|
+
def tables(stream)
|
|
61
|
+
@connection.tables.sort.each do |tbl|
|
|
62
|
+
next if ['schema_migrations', ignore_tables].flatten.any? do |ignored|
|
|
63
|
+
case ignored
|
|
64
|
+
when String; tbl == ignored
|
|
65
|
+
when Regexp; tbl =~ ignored
|
|
66
|
+
else
|
|
67
|
+
raise StandardError, 'ActiveRecord::SchemaDumper.ignore_tables accepts an array of String and / or Regexp values.'
|
|
68
|
+
end
|
|
69
|
+
end
|
|
70
|
+
table(tbl, stream)
|
|
71
|
+
end
|
|
72
|
+
end
|
|
73
|
+
|
|
74
|
+
def table(table, stream)
|
|
75
|
+
columns = @connection.columns(table)
|
|
76
|
+
begin
|
|
77
|
+
tbl = StringIO.new
|
|
78
|
+
|
|
79
|
+
if @connection.respond_to?(:pk_and_sequence_for)
|
|
80
|
+
pk, pk_seq = @connection.pk_and_sequence_for(table)
|
|
81
|
+
end
|
|
82
|
+
pk ||= 'id'
|
|
83
|
+
|
|
84
|
+
tbl.print " create_table #{table.inspect}"
|
|
85
|
+
if columns.detect { |c| c.name == pk }
|
|
86
|
+
if pk != 'id'
|
|
87
|
+
tbl.print %Q(, :primary_key => "#{pk}")
|
|
88
|
+
end
|
|
89
|
+
else
|
|
90
|
+
tbl.print ", :id => false"
|
|
91
|
+
end
|
|
92
|
+
tbl.print ", :force => true"
|
|
93
|
+
tbl.puts " do |t|"
|
|
94
|
+
|
|
95
|
+
column_specs = columns.map do |column|
|
|
96
|
+
raise StandardError, "Unknown type '#{column.sql_type}' for column '#{column.name}'" if @types[column.type].nil?
|
|
97
|
+
next if column.name == pk
|
|
98
|
+
spec = {}
|
|
99
|
+
spec[:name] = column.name.inspect
|
|
100
|
+
spec[:type] = column.type.to_s
|
|
101
|
+
spec[:limit] = column.limit.inspect if column.limit != @types[column.type][:limit] && column.type != :decimal
|
|
102
|
+
spec[:precision] = column.precision.inspect if !column.precision.nil?
|
|
103
|
+
spec[:scale] = column.scale.inspect if !column.scale.nil?
|
|
104
|
+
spec[:null] = 'false' if !column.null
|
|
105
|
+
spec[:default] = default_string(column.default) if !column.default.nil?
|
|
106
|
+
(spec.keys - [:name, :type]).each{ |k| spec[k].insert(0, "#{k.inspect} => ")}
|
|
107
|
+
spec
|
|
108
|
+
end.compact
|
|
109
|
+
|
|
110
|
+
# find all migration keys used in this table
|
|
111
|
+
keys = [:name, :limit, :precision, :scale, :default, :null] & column_specs.map(&:keys).flatten
|
|
112
|
+
|
|
113
|
+
# figure out the lengths for each column based on above keys
|
|
114
|
+
lengths = keys.map{ |key| column_specs.map{ |spec| spec[key] ? spec[key].length + 2 : 0 }.max }
|
|
115
|
+
|
|
116
|
+
# the string we're going to sprintf our values against, with standardized column widths
|
|
117
|
+
format_string = lengths.map{ |len| "%-#{len}s" }
|
|
118
|
+
|
|
119
|
+
# find the max length for the 'type' column, which is special
|
|
120
|
+
type_length = column_specs.map{ |column| column[:type].length }.max
|
|
121
|
+
|
|
122
|
+
# add column type definition to our format string
|
|
123
|
+
format_string.unshift " t.%-#{type_length}s "
|
|
124
|
+
|
|
125
|
+
format_string *= ''
|
|
126
|
+
|
|
127
|
+
column_specs.each do |colspec|
|
|
128
|
+
values = keys.zip(lengths).map{ |key, len| colspec.key?(key) ? colspec[key] + ", " : " " * len }
|
|
129
|
+
values.unshift colspec[:type]
|
|
130
|
+
tbl.print((format_string % values).gsub(/,\s*$/, ''))
|
|
131
|
+
tbl.puts
|
|
132
|
+
end
|
|
133
|
+
|
|
134
|
+
tbl.puts " end"
|
|
135
|
+
tbl.puts
|
|
136
|
+
|
|
137
|
+
indexes(table, tbl)
|
|
138
|
+
|
|
139
|
+
tbl.rewind
|
|
140
|
+
stream.print tbl.read
|
|
141
|
+
rescue => e
|
|
142
|
+
stream.puts "# Could not dump table #{table.inspect} because of following #{e.class}"
|
|
143
|
+
stream.puts "# #{e.message}"
|
|
144
|
+
stream.puts
|
|
145
|
+
end
|
|
146
|
+
|
|
147
|
+
stream
|
|
148
|
+
end
|
|
149
|
+
|
|
150
|
+
def default_string(value)
|
|
151
|
+
case value
|
|
152
|
+
when BigDecimal
|
|
153
|
+
value.to_s
|
|
154
|
+
when Date, DateTime, Time
|
|
155
|
+
"'" + value.to_s(:db) + "'"
|
|
156
|
+
else
|
|
157
|
+
value.inspect
|
|
158
|
+
end
|
|
159
|
+
end
|
|
160
|
+
|
|
161
|
+
def indexes(table, stream)
|
|
162
|
+
indexes = @connection.indexes(table)
|
|
163
|
+
indexes.each do |index|
|
|
164
|
+
stream.print " add_index #{index.table.inspect}, #{index.columns.inspect}, :name => #{index.name.inspect}"
|
|
165
|
+
stream.print ", :unique => true" if index.unique
|
|
166
|
+
stream.puts
|
|
167
|
+
end
|
|
168
|
+
stream.puts unless indexes.empty?
|
|
169
|
+
end
|
|
170
|
+
end
|
|
171
|
+
end
|