crystal 0.0.10 → 0.0.12
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/Rakefile +25 -0
- data/lib/crystal/controller/abstract_controller/micelaneous.rb +31 -0
- data/lib/crystal/controller/abstract_controller/render.rb +133 -0
- data/lib/crystal/controller/abstract_controller/responder.rb +17 -0
- data/lib/crystal/controller/abstract_controller.rb +60 -0
- data/lib/crystal/controller/controller_context.rb +7 -0
- data/lib/crystal/controller/http_controller.rb +43 -0
- data/lib/crystal/controller/processors/controller_caller.rb +40 -0
- data/lib/crystal/controller/processors/controller_error_handling.rb +53 -0
- data/lib/crystal/controller/processors/controller_logger.rb +13 -0
- data/lib/crystal/controller.rb +28 -0
- data/lib/crystal/conveyor/conveyor.rb +74 -0
- data/lib/crystal/conveyor/conveyors.rb +20 -0
- data/lib/crystal/conveyor/params.rb +22 -0
- data/lib/crystal/conveyor/processor.rb +68 -0
- data/lib/crystal/conveyor/processors/conveyor_logger.rb +24 -0
- data/lib/crystal/conveyor/workspace.rb +36 -0
- data/lib/crystal/conveyor.rb +29 -0
- data/lib/crystal/environment/config.rb +118 -0
- data/lib/crystal/environment/dependency_resolver.rb +107 -0
- data/lib/crystal/environment/environment.rb +5 -0
- data/lib/crystal/environment/files_helper.rb +42 -0
- data/lib/crystal/environment/logger.rb +21 -0
- data/lib/crystal/environment.rb +52 -0
- data/lib/crystal/html/controller_helpers/controller_url_helper.rb +52 -0
- data/lib/crystal/html/controller_helpers/flash_helper.rb +5 -0
- data/lib/crystal/html/flash.rb +40 -0
- data/lib/crystal/html/include_into_controller.rb +24 -0
- data/lib/crystal/html/processors/prepare_flash.rb +26 -0
- data/lib/crystal/html/processors/scoped_params.rb +30 -0
- data/lib/crystal/html/view_helpers/basic_html_helper.rb +83 -0
- data/lib/crystal/html/view_helpers/form_helper.rb +104 -0
- data/lib/crystal/html/view_helpers/javascript_helper.rb +18 -0
- data/lib/crystal/html/view_helpers/model_helper.rb +119 -0
- data/lib/crystal/html/view_helpers/view_url_helper.rb +66 -0
- data/lib/crystal/html.rb +28 -0
- data/lib/crystal/http/http.rb +21 -0
- data/lib/crystal/http/http_adapter.rb +30 -0
- data/lib/crystal/http/middleware/static_files.rb +20 -0
- data/lib/crystal/http/processors/evaluate_format.rb +22 -0
- data/lib/crystal/http/processors/http_logger.rb +15 -0
- data/lib/crystal/http/processors/http_writer.rb +48 -0
- data/lib/crystal/http/processors/prepare_params.rb +24 -0
- data/lib/crystal/http/rack_config.rb +15 -0
- data/lib/crystal/http/support/rack/rack_adapter.rb +65 -0
- data/lib/crystal/http/support/rack/request.rb +12 -0
- data/lib/crystal/http/support/rack/response.rb +39 -0
- data/lib/crystal/http.rb +47 -0
- data/lib/crystal/mailer/mail.rb +7 -0
- data/lib/crystal/mailer.rb +13 -0
- data/lib/crystal/profiles/web.rb +69 -0
- data/lib/crystal/profiles/web_require.rb +5 -0
- data/lib/crystal/remote/processors/remote_caller.rb +54 -0
- data/lib/crystal/remote/processors/remote_logger.rb +13 -0
- data/lib/crystal/remote/remote.rb +15 -0
- data/lib/crystal/remote.rb +9 -0
- data/lib/crystal/router/configurator.rb +23 -0
- data/lib/crystal/router/default_format_processor.rb +12 -0
- data/lib/crystal/router/default_router.rb +23 -0
- data/lib/crystal/router/named_router.rb +63 -0
- data/lib/crystal/router/processors/router.rb +22 -0
- data/lib/crystal/router/router.rb +218 -0
- data/lib/crystal/router/routing_helper.rb +17 -0
- data/lib/crystal/router.rb +19 -0
- data/lib/crystal/spec/controller.rb +15 -0
- data/lib/crystal/spec/environment.rb +41 -0
- data/lib/crystal/spec/http.rb +67 -0
- data/lib/crystal/spec/mail.rb +20 -0
- data/lib/crystal/spec/remote.rb +9 -0
- data/lib/crystal/spec/view.rb +10 -0
- data/lib/crystal/spec/xhtml.rb +33 -0
- data/lib/crystal/spec.rb +8 -0
- data/lib/crystal/support/active_support/micelaneous.rb +2 -0
- data/lib/crystal/support/active_support.rb +37 -28
- data/lib/crystal/support/addressable.rb +45 -0
- data/lib/crystal/support/buffered_logger.rb +38 -0
- data/lib/crystal/support/callbacks.rb +155 -0
- data/lib/crystal/support/exception.rb +21 -0
- data/lib/crystal/support/filters.rb +34 -0
- data/lib/crystal/support/format.rb +9 -0
- data/lib/crystal/support/gems.rb +12 -0
- data/lib/crystal/support/micon.rb +16 -0
- data/lib/crystal/support/mime.rb +11 -0
- data/lib/crystal/support/module.rb +44 -0
- data/lib/crystal/support/rson.rb +53 -0
- data/lib/crystal/support/ruby_ext_with_active_support.rb +4 -0
- data/lib/crystal/support/safe_hash.rb +135 -0
- data/lib/crystal/support/string.rb +26 -0
- data/lib/crystal/support.rb +42 -0
- data/lib/crystal/template/support/tilt.rb +68 -0
- data/lib/crystal/template/template.rb +244 -0
- data/lib/crystal/template/template_context.rb +57 -0
- data/lib/crystal/template.rb +21 -0
- data/lib/views/crystal_default_templates/development/error.html.erb +11 -0
- data/lib/views/crystal_default_templates/development/error.js.erb +1 -0
- data/readme.md +9 -5
- data/spec/_mailer/basic_spec.rb +110 -0
- data/spec/_mailer/helper.rb +6 -0
- data/spec/controller/abstract_controller_spec/views/OperationsOrderSpec/action.erb +1 -0
- data/spec/controller/abstract_controller_spec/views/ViewVariablesSpec/action.erb +10 -0
- data/spec/controller/abstract_controller_spec.rb +138 -0
- data/spec/controller/controller_context_spec/views/ItemSpec/actions.erb +4 -0
- data/spec/controller/controller_context_spec/views/ItemSpec/show.erb +0 -0
- data/spec/controller/controller_context_spec/views/ItemSpec/update.erb +0 -0
- data/spec/controller/controller_context_spec/views/NamespaceSpec/ClassSpec/show.erb +0 -0
- data/spec/controller/controller_context_spec/views/PageSpec/actions.erb +3 -0
- data/spec/controller/controller_context_spec/views/PageSpec/show.erb +0 -0
- data/spec/controller/controller_context_spec/views/namespace_spec/class_spec/update.erb +0 -0
- data/spec/controller/controller_context_spec.rb +123 -0
- data/spec/controller/controller_helper_spec/views/HelperMethodSpec/action.erb +1 -0
- data/spec/controller/controller_helper_spec/views/HelperSpec/action.erb +1 -0
- data/spec/controller/controller_helper_spec.rb +58 -0
- data/spec/controller/controller_render_spec/views/AlreadyRenderedSpec/action.erb +1 -0
- data/spec/controller/controller_render_spec/views/AlreadyRenderedSpec/custom_template.erb +1 -0
- data/spec/controller/controller_render_spec/views/AnotherActionSpec/another_action.erb +1 -0
- data/spec/controller/controller_render_spec/views/AnotherLayout/action.erb +1 -0
- data/spec/controller/controller_render_spec/views/ExplicitRenderSpec/action.erb +1 -0
- data/spec/controller/controller_render_spec/views/ExplicitRenderSpec/another_action.erb +1 -0
- data/spec/controller/controller_render_spec/views/ForbidPartialAsActionSpec/_action.erb +1 -0
- data/spec/controller/controller_render_spec/views/FormatSpec/action.html.erb +1 -0
- data/spec/controller/controller_render_spec/views/FormatSpec/action.js.erb +1 -0
- data/spec/controller/controller_render_spec/views/LayoutFiltersSpec/action_with_layout.erb +1 -0
- data/spec/controller/controller_render_spec/views/LayoutFiltersSpec/action_without_layout.erb +1 -0
- data/spec/controller/controller_render_spec/views/LayoutSpec/action.erb +1 -0
- data/spec/controller/controller_render_spec/views/layouts/admin.erb +1 -0
- data/spec/controller/controller_render_spec/views/layouts/app.html.erb +1 -0
- data/spec/controller/controller_render_spec/views/layouts/app.js.erb +1 -0
- data/spec/controller/controller_render_spec/views/some_template.erb +1 -0
- data/spec/controller/controller_render_spec/views/standalone.html.erb +1 -0
- data/spec/controller/controller_render_spec.rb +192 -0
- data/spec/controller/error_handling_spec/views/diferrent_error_handling_spec/a.erb +1 -0
- data/spec/controller/error_handling_spec/views/diferrent_error_handling_spec/b.erb +1 -0
- data/spec/controller/error_handling_spec/views/diferrent_error_handling_spec/c.erb +1 -0
- data/spec/controller/error_handling_spec.rb +97 -0
- data/spec/controller/helper.rb +21 -0
- data/spec/controller/http_controller_spec.rb +90 -0
- data/spec/conveyor/conveyor_spec.rb +124 -0
- data/spec/conveyor/helper.rb +8 -0
- data/spec/environment/_dependency_resolver_spec.rb +50 -0
- data/spec/environment/environment_spec/app/app_plugin/config/ec_layout +1 -0
- data/spec/environment/environment_spec/app/app_plugin/ec_some_file +1 -0
- data/spec/environment/environment_spec/app/config/config.test.yml +1 -0
- data/spec/environment/environment_spec/app/config/config.yml +2 -0
- data/spec/environment/environment_spec/gem_plugin/config/ec_layout +1 -0
- data/spec/environment/environment_spec.rb +87 -0
- data/spec/environment/helper.rb +4 -0
- data/spec/environment/logger_spec.rb +20 -0
- data/spec/environment/minimal_app_spec/app.rb +3 -0
- data/spec/environment/minimal_app_spec.rb +29 -0
- data/spec/environment/standard_app_spec.rb +65 -0
- data/spec/environment/standard_app_spec_data/config/init.rb +18 -0
- data/spec/environment/standard_app_spec_data/plugin_a/plugin_a.rb +7 -0
- data/spec/html/basic_html_helper_spec.rb +30 -0
- data/spec/html/flash_spec.rb +185 -0
- data/spec/html/form_helper_spec.rb +57 -0
- data/spec/html/helper.rb +31 -0
- data/spec/html/javascript_helper_spec.rb +16 -0
- data/spec/html/model_helper_spec.rb +66 -0
- data/spec/html/scoped_params_spec.rb +18 -0
- data/spec/html/url_helper_spec.rb +152 -0
- data/spec/http/helper.rb +9 -0
- data/spec/http/http_spec.rb +57 -0
- data/spec/http/http_spec_data/config/init.rb +7 -0
- data/spec/http/http_spec_data/plugin_b/plugin_b.rb +6 -0
- data/spec/integration/basic_spec/views/smoke_test_spec/action.erb +1 -0
- data/spec/integration/basic_spec.rb +83 -0
- data/spec/integration/helper.rb +10 -0
- data/spec/remote/helper.rb +20 -0
- data/spec/remote/remote_spec.rb +76 -0
- data/spec/router/basic_spec.rb +131 -0
- data/spec/router/configurator_spec.rb +30 -0
- data/spec/router/helper.rb +23 -0
- data/spec/router/integration_spec.rb +43 -0
- data/spec/support/callbacks_spec.rb +155 -0
- data/spec/support/filters_spec.rb +61 -0
- data/spec/support/helper.rb +7 -0
- data/spec/support/safe_hash_spec.rb +84 -0
- data/spec/template/helper.rb +8 -0
- data/spec/template/template_spec/file.erb +1 -0
- data/spec/template/template_spec/views/basic/custom_context.erb +1 -0
- data/spec/template/template_spec/views/basic/extension.erb +1 -0
- data/spec/template/template_spec/views/basic/general.html.erb +5 -0
- data/spec/template/template_spec/views/basic/non_existing_format.html.erb +0 -0
- data/spec/template/template_spec/views/format/format.erb +1 -0
- data/spec/template/template_spec/views/format/format.html.erb +1 -0
- data/spec/template/template_spec/views/format/format.js.erb +1 -0
- data/spec/template/template_spec/views/layout/basic/content.erb +1 -0
- data/spec/template/template_spec/views/layout/basic/layout.erb +1 -0
- data/spec/template/template_spec/views/layout/content_for/content.erb +3 -0
- data/spec/template/template_spec/views/layout/content_for/layout.erb +3 -0
- data/spec/template/template_spec/views/layout/format/content.html.erb +1 -0
- data/spec/template/template_spec/views/layout/format/content.js.erb +1 -0
- data/spec/template/template_spec/views/layout/format/layout.html.erb +1 -0
- data/spec/template/template_spec/views/layout/format/layout.js.erb +1 -0
- data/spec/template/template_spec/views/layout/nested_yield/a.erb +1 -0
- data/spec/template/template_spec/views/layout/nested_yield/layout.erb +1 -0
- data/spec/template/template_spec/views/layout/nested_yield/layout_b.erb +1 -0
- data/spec/template/template_spec/views/layout/same_context/a.erb +1 -0
- data/spec/template/template_spec/views/layout/same_context/b.erb +1 -0
- data/spec/template/template_spec/views/layout/same_context/layout.erb +1 -0
- data/spec/template/template_spec/views/nested/format/a.erb +1 -0
- data/spec/template/template_spec/views/nested/format/b.erb +1 -0
- data/spec/template/template_spec/views/nested/relative/a.erb +1 -0
- data/spec/template/template_spec/views/nested/relative/b.erb +1 -0
- data/spec/template/template_spec/views/nested/relative/c.erb +1 -0
- data/spec/template/template_spec/views/nested/shared/c.erb +1 -0
- data/spec/template/template_spec/views/nesting_format/_dialog.html.erb +1 -0
- data/spec/template/template_spec/views/nesting_format/_form.html.erb +1 -0
- data/spec/template/template_spec/views/nesting_format/dialog.js.erb +1 -0
- data/spec/template/template_spec/views/other/template.erb +1 -0
- data/spec/template/template_spec/views/prefixes/_underscored.erb +1 -0
- data/spec/template/template_spec/views/prefixes/without_prefix.erb +1 -0
- data/spec/template/template_spec.rb +190 -0
- data/spec/template/tilt_spec/views/concat_and_capture.erb +1 -0
- data/spec/template/tilt_spec/views/concat_and_capture.haml +3 -0
- data/spec/template/tilt_spec/views/errors.erb +3 -0
- data/spec/template/tilt_spec/views/errors.haml +3 -0
- data/spec/template/tilt_spec/views/mixed_templates/broken_erb_concat_erb.erb +4 -0
- data/spec/template/tilt_spec/views/mixed_templates/broken_erb_concat_haml.haml +1 -0
- data/spec/template/tilt_spec/views/mixed_templates/broken_haml_concat_erb.erb +1 -0
- data/spec/template/tilt_spec/views/mixed_templates/broken_haml_concat_haml.haml +2 -0
- data/spec/template/tilt_spec/views/nested_capture_and_concat.haml +3 -0
- data/spec/template/tilt_spec/views/ugly.haml +3 -0
- data/spec/template/tilt_spec/views/yield.erb +1 -0
- data/spec/template/tilt_spec.rb +97 -0
- metadata +345 -205
- data/.git/COMMIT_EDITMSG +0 -1
- data/.git/FETCH_HEAD +0 -1
- data/.git/HEAD +0 -1
- data/.git/ORIG_HEAD +0 -1
- data/.git/config +0 -12
- data/.git/description +0 -1
- data/.git/hooks/applypatch-msg.sample +0 -15
- data/.git/hooks/commit-msg.sample +0 -24
- data/.git/hooks/post-commit.sample +0 -8
- data/.git/hooks/post-receive.sample +0 -15
- data/.git/hooks/post-update.sample +0 -8
- data/.git/hooks/pre-applypatch.sample +0 -14
- data/.git/hooks/pre-commit.sample +0 -46
- data/.git/hooks/pre-rebase.sample +0 -169
- data/.git/hooks/prepare-commit-msg.sample +0 -36
- data/.git/hooks/update.sample +0 -128
- data/.git/index +0 -0
- data/.git/info/exclude +0 -6
- data/.git/logs/HEAD +0 -21
- data/.git/logs/refs/heads/master +0 -21
- data/.git/logs/refs/remotes/origin/master +0 -19
- data/.git/objects/00/c26dc781c8997ed2bfa61f03b323466a3860d1 +0 -0
- data/.git/objects/04/03ee94b34a5760c46616cd13c317e69cb90d56 +0 -0
- data/.git/objects/04/6f30de5fd9fe81fd558c58091c38a57b6be727 +0 -0
- data/.git/objects/05/78d884154d5a74143844a4373121e8d9fa6abd +0 -0
- data/.git/objects/06/8c594d16214cbee3ad8e9f4eae9c78f6a9ddf1 +0 -3
- data/.git/objects/08/8b766b31125f7c4ae34a8fc50b23842cd3d329 +0 -0
- data/.git/objects/09/66c6b45bacaae9282463b9b4c0ce8488bbcee5 +0 -2
- data/.git/objects/09/a40c814899fcdadc2bd5665e892a7db26a3677 +0 -2
- data/.git/objects/0c/eac702c4548a2748f50793ea5108cfd4937568 +0 -0
- data/.git/objects/0d/03131f9fbc3e2fb1f8f9b616ac273d05f3a7f5 +0 -0
- data/.git/objects/0e/50f691a65b41ba9e7df9d6738ff9f333089b34 +0 -0
- data/.git/objects/11/72a42d5efc6cb442f877bef4427321a216990a +0 -1
- data/.git/objects/12/3a3f6e3c82bb8df88e242085deef1aa150039c +0 -0
- data/.git/objects/14/6253750089fd522535155630344c8ff2a60830 +0 -0
- data/.git/objects/15/3d7375df50713dd61152db972492405e5475e0 +0 -0
- data/.git/objects/15/f5669d470665c6bd28b5ab7b65431e199c36e9 +0 -0
- data/.git/objects/1b/d4b59edc03948d15434e9eb882c769ab779ba6 +0 -0
- data/.git/objects/1c/abe7402ff0ea8bbf7a63cee7a61dec7578dae9 +0 -0
- data/.git/objects/20/fb67fdc8a63361a3d317d3c873462fd5a338d0 +0 -0
- data/.git/objects/21/4bb3dd51d883243c744ee3d668e09a0c1cc293 +0 -0
- data/.git/objects/23/9d84cdccd97f779f60c08f88ab635f4c236e87 +0 -0
- data/.git/objects/27/510002446b0a1405c1e7f14634c28407dffa76 +0 -0
- data/.git/objects/28/4db1992e17d1d5fc9280dc4e79799958a9cbac +0 -0
- data/.git/objects/28/69649fc37831734b82493fe980f9dc65dfd935 +0 -0
- data/.git/objects/28/a3d1b3c79d0e59b8359ecd75e4ec0d62f60468 +0 -2
- data/.git/objects/29/53f684e47235f5b14b4beb0b0bb61c8e520dd8 +0 -0
- data/.git/objects/2c/b339709e1fb005a3e3006e76558d2e45333008 +0 -0
- data/.git/objects/2d/077a401db466ea0b1f062eac15293879293439 +0 -0
- data/.git/objects/2e/2f635a49a032cb37d69af4862181bb37bfa0fa +0 -0
- data/.git/objects/31/0f7c970910eced673e858c197f6ee418e97545 +0 -0
- data/.git/objects/34/7475671d8fbc0e870ce9ec1c6f275ddd90f1db +0 -0
- data/.git/objects/36/479605ef7fc62ec68841284083e171bcb3b2c2 +0 -2
- data/.git/objects/37/1221704ea1da5a27626855e82076565fb58cac +0 -0
- data/.git/objects/38/3af6cb155addf818eb9396229892743112dbc3 +0 -0
- data/.git/objects/3a/97679c02b93c246d359a6f663b513691e37991 +0 -0
- data/.git/objects/3b/101bd6fccf79321048448c8384029c8768ec01 +0 -0
- data/.git/objects/3d/4a702963039cf32ac2ca91c37669e78625f92b +0 -0
- data/.git/objects/40/55426e988e151ac26792ec17bf31d04c606377 +0 -0
- data/.git/objects/42/828defbc95389daf9bfa11c8b2341f98303ee7 +0 -0
- data/.git/objects/44/b6d8df4e1f924caeb7de56135c251ce24998fd +0 -0
- data/.git/objects/46/42a59703e31a105aa67c4511be5e41402d08af +0 -0
- data/.git/objects/49/22dc7ff543c31059ef3979c51ab36cdf74367e +0 -0
- data/.git/objects/49/3a5d4dfc291e68321e15120dd9ca15388817ff +0 -0
- data/.git/objects/4a/787ce4e048fe15df728e9b5e9170f087b0bcde +0 -4
- data/.git/objects/4b/f9324fefa911db32f9d75461842e3420254e7f +0 -0
- data/.git/objects/4d/ada0b46f7aedd3da02dbec0daef667b3903765 +0 -0
- data/.git/objects/50/dfa247b62156c4eb6371c8a68054c63aa1f075 +0 -2
- data/.git/objects/53/ae2a3872c30d9242b5ea4a609165c02da18392 +0 -0
- data/.git/objects/56/43b861a644b727a8b54ae003977151d975f360 +0 -0
- data/.git/objects/57/5fdffb0b6f624c9d2676964603788264ed7b28 +0 -0
- data/.git/objects/5a/53898e77d291396aeb2b7255d97d185b92cad2 +0 -0
- data/.git/objects/5c/bb5fbba6c1b72af9e412047c50e8629c681d72 +0 -1
- data/.git/objects/5e/11ba5e0794a914747bae95b942b2dbeb5c36c3 +0 -0
- data/.git/objects/5e/22424fba117a89e563604e2e55fca82ef7547a +0 -0
- data/.git/objects/5e/90e483ed4782b9a2a834280c6ad5e7711462fa +0 -0
- data/.git/objects/5e/f6eb87941331580ede445399654f199a9a6156 +0 -0
- data/.git/objects/5f/2b8b8c9f16877c91fda9a177e235698103c4c9 +0 -0
- data/.git/objects/61/8d3d8348db1739ba171f7db3effb3c7244bf3b +0 -2
- data/.git/objects/62/b4bbd793a5a9ad8b0f24ef657b973afbfcf3cf +0 -0
- data/.git/objects/62/fa8ffcffcedc680a953c2e01ca9312e60807b0 +0 -0
- data/.git/objects/63/82b66d637e3d04e78a6272e25d3e212de90a10 +0 -0
- data/.git/objects/65/b8ba705a4a439a8b26df539f10b97d6ca4988d +0 -1
- data/.git/objects/66/aa791f24ea2ed8717abe3d1c74da4ad544723d +0 -0
- data/.git/objects/68/02f5c496f00787242a9fa1a81eb9847071e076 +0 -0
- data/.git/objects/69/b1b39f438eb902f68ddd438119d2e74633d16f +0 -0
- data/.git/objects/6c/a1abc3f9fe344fddcedb7163848fe6111717ae +0 -0
- data/.git/objects/6d/003cf32b629086b5714d3ba0cb6b3ae296ff4e +0 -0
- data/.git/objects/6e/4e5c95547a5e088db2d6a9d3b52c446cfec1fb +0 -0
- data/.git/objects/6f/2b5882b4cb9c2ef42902433076b58ef5ce44b9 +0 -0
- data/.git/objects/71/d7d7da97da36d9899873715ccd080c2793cbe9 +0 -0
- data/.git/objects/7a/64ac4146eb137a2667085fbddfea97cc727bb7 +0 -2
- data/.git/objects/7b/47a3e0c3fb6407567185df38e031cb54179c6e +0 -0
- data/.git/objects/7c/34481a926b48e49767828aa8a3bbeeeb26643e +0 -0
- data/.git/objects/7c/4fb1fb0dfa094010b07e489dd6feaa0b15c316 +0 -0
- data/.git/objects/7d/97e0e697055b4fbf915cc3d662d4599b3b1477 +0 -0
- data/.git/objects/7f/0673a63b426d7025b0a11de29083490264b350 +0 -0
- data/.git/objects/81/031da1db90c4cd43fe27336054d76564dbe64c +0 -3
- data/.git/objects/81/1ad37e54ba756ff8d3acbbad733e43631c2de8 +0 -3
- data/.git/objects/81/f505f109391e66ba3de39165c66c41b8e5e0bb +0 -0
- data/.git/objects/82/1912a397a9029beb4d74f407a6ad4b8e36f2f2 +0 -0
- data/.git/objects/85/8d7587d219e75ac4eda5bc7b6d28e74d545146 +0 -0
- data/.git/objects/86/738c97b0d7ac8443a25cbcd0c4e147bcdb152e +0 -0
- data/.git/objects/86/edc0909929d735fe5e1cf8f8b46ad7fa2c1d60 +0 -0
- data/.git/objects/8b/722287d6667e73e07eab685f7bd7b32dbecb04 +0 -0
- data/.git/objects/8b/ef303f65e1da2f9054b8912cb952718ef99bba +0 -0
- data/.git/objects/8c/572af4f04bcafb3c226a669fbc4dc508aed651 +0 -0
- data/.git/objects/8d/a995e65577a82011df060b13a498f0a738d017 +0 -0
- data/.git/objects/8e/1980f27fbc85de9d530e3946ad9f4e78b96107 +0 -0
- data/.git/objects/8e/5b69ea615859da8ee6d7848ca754d8cca5ffc5 +0 -0
- data/.git/objects/90/cfb8df76866f20a0c9c4adfb6d5d1faebad9d3 +0 -0
- data/.git/objects/9f/e781c5e0fe8f889aefb163da0b52f9cf25ec1f +0 -2
- data/.git/objects/a4/fd740f28646783c68d1db592fa65a983d73e7b +0 -0
- data/.git/objects/a7/618ca140c7c16536cdbd864c8264d4e738d508 +0 -0
- data/.git/objects/a9/38b272a1a743d7e30caa05b5513760195ec0a8 +0 -4
- data/.git/objects/a9/4c0880d370e61595adda4af6e91209437265aa +0 -0
- data/.git/objects/aa/2420e96b6dcb848de2a8ea393c28a0314eda6e +0 -2
- data/.git/objects/aa/ddfc59430a3fb268bd5c97a088ea4bfdb2db07 +0 -0
- data/.git/objects/ac/3226f3722e8ea60a4ddcbc5b4a30d305fbdf50 +0 -0
- data/.git/objects/ad/8ddf80de972b932bc955c672c29e21f948367f +0 -0
- data/.git/objects/ad/994f9b41e5bc6fd188de9aa8adefe6b5515ed6 +0 -3
- data/.git/objects/af/606f60f63c31341fd75ec557e073435327cf82 +0 -0
- data/.git/objects/b1/244bb3652d56ebe4b465468e214d1a1fa87ebb +0 -1
- data/.git/objects/b2/1be06405e5a7e2db12e03d6a781c759b305a72 +0 -0
- data/.git/objects/b2/a45e92c20d09897c984186472f616c0af6b5d3 +0 -2
- data/.git/objects/b3/39ab5d14998e1bb098eb0b807fb9b53ecc790b +0 -0
- data/.git/objects/b3/838491c1c451ff8680fe25a7288d79e22c5ee9 +0 -1
- data/.git/objects/b4/e715329ba853104d19112487b1188571bca659 +0 -0
- data/.git/objects/b5/010cc435a10af9518f125b67851576c1e74835 +0 -0
- data/.git/objects/b5/9d6a5f9325cbd5a7ce3b351b51db1f1b6d58f9 +0 -0
- data/.git/objects/b6/e185313a1e82513d52144e80d97c4e7217a6b0 +0 -0
- data/.git/objects/b8/bd01ebc6defac18710776615168beb4e251e87 +0 -2
- data/.git/objects/b8/ca44e136c1392f27f617801a9ea908eaf45d0b +0 -0
- data/.git/objects/ba/c39f505b90f6e64cff088337293912161a4ca5 +0 -0
- data/.git/objects/bb/c21a34b3d2ddd51f3e39ddef3c6811aaa26305 +0 -0
- data/.git/objects/bf/1e07cd3085bed5be7f3ca1860ec8c14d0fdebb +0 -0
- data/.git/objects/bf/4d123f34ecf86a041a5d8df32beb6e1b24dfed +0 -0
- data/.git/objects/c0/aa97f36a0fdf80be4ca530ecf0ff7ec23fc313 +0 -0
- data/.git/objects/c2/759026a46887f199c46ee60ef9764fed87c7af +0 -0
- data/.git/objects/c3/6838a35e7acdbe40a8e762aa92e143d6be8376 +0 -0
- data/.git/objects/c5/73778609d449286e4eb5177d34e3c77b0cf520 +0 -0
- data/.git/objects/c5/945ab6909de8dd7f9e192a67fe72db2a7f5740 +0 -0
- data/.git/objects/c5/ef2f6ac4ee5779fa79f7afb54a458191352e86 +0 -0
- data/.git/objects/c6/c08bf8bd35fcf7fc9127a482badd7a9ff48ba2 +0 -0
- data/.git/objects/c6/c8485326187c9c872dedc68d71a2fe3ad15446 +0 -0
- data/.git/objects/cc/0b74e32ae045d3208839aa91d0dc94f5ea4c09 +0 -0
- data/.git/objects/cc/dd62a9a3a9e16e487495294c19ac64da9516d0 +0 -3
- data/.git/objects/cf/8ccc732db70ccfb4e185f78dc03512b04fb4f6 +0 -0
- data/.git/objects/d2/6b6bac449e70757e718bf023bd3c327b3f231c +0 -0
- data/.git/objects/d3/b4580aaa3c069e320b941dd23f56a474cd6caa +0 -3
- data/.git/objects/d4/5dffe5792c4d873de1cc233ec8992e9a9f8df5 +0 -0
- data/.git/objects/d7/ea5d3d4b7fdcc93771304fee8d5261f6469f28 +0 -0
- data/.git/objects/d8/53eba81fc4b75fbc90cf8c39f4b1344deddc9f +0 -0
- data/.git/objects/d8/de40b222d79af7bdb2b1ae59944fc3b0dd0f05 +0 -0
- data/.git/objects/df/39c68e0de1bee1b87beeb44170f52db5da2317 +0 -0
- data/.git/objects/df/e23416f16c0bb6c98ca2a0b1d02d803ff53831 +0 -0
- data/.git/objects/df/ee793cf3fd89820e5a9a4481d35000d75040d9 +0 -0
- data/.git/objects/e0/f7b971a634e34d7976676a4d575c654746a5f8 +0 -0
- data/.git/objects/e2/6ee4ee0aae4b71ab0fae46952e858050eb6380 +0 -0
- data/.git/objects/e5/134d62f67ad64eb79b139bb86ed8af711704d4 +0 -0
- data/.git/objects/e6/9de29bb2d1d6434b8b29ae775ad8c2e48c5391 +0 -0
- data/.git/objects/e8/2061e7bc928cd8df2a4ac34848bd670d7cb29c +0 -0
- data/.git/objects/e8/2e9ddde8094f4d6f4871abe19f82acce46cafe +0 -0
- data/.git/objects/e9/0b6867602c5754080219c30aee275f3aa10b49 +0 -0
- data/.git/objects/e9/8264a4555c2b9436f7c8633575eb5cea338e35 +0 -0
- data/.git/objects/eb/86cc8e7187bdb75267a4e5ba1c5d4d4b200c98 +0 -0
- data/.git/objects/ee/282c9448793de0bd2df8348e0f4fd6cb1b8f2f +0 -0
- data/.git/objects/f0/2d1b4f22ec5df7fc658d4616cac5e5250e033b +0 -0
- data/.git/objects/f3/8245046bfe9c478a502c58b1c1434f382800d3 +0 -0
- data/.git/objects/f3/e1d5f3bc635974bf9410cb87d21bb3ad29da6b +0 -0
- data/.git/objects/f6/3c2e6d83a07cf107ff63a6b92a72a0ac5e9e3f +0 -0
- data/.git/objects/f8/a51fe3b4da3e5616ee4606fc71ef1915162853 +0 -0
- data/.git/objects/fb/0a0717fd1a64bfe6de89e84ce2f320e9bca527 +0 -0
- data/.git/objects/fc/794047fc246572581a7fdce016e1be6b8ab61a +0 -0
- data/.git/objects/fe/d4da51927e4d0b97d071611a3cb0c7c484938d +0 -0
- data/.git/objects/ff/db1bde1735cee2b62d80bf8151ae98515069b4 +0 -0
- data/.git/refs/heads/master +0 -1
- data/.git/refs/remotes/origin/master +0 -1
- data/.gitignore +0 -3
- data/bin/crystal_console +0 -45
- data/bin/crystal_new +0 -3
- data/bin/crystal_server +0 -6
- data/lib/crystal/core/config.rb +0 -52
- data/lib/crystal/core/crystal.rb +0 -40
- data/lib/crystal/core/remote.rb +0 -8
- data/lib/crystal/core/router.rb +0 -39
- data/lib/crystal/core/scopes.rb +0 -4
- data/lib/crystal/rack/adapter.rb +0 -57
- data/lib/crystal/rack/middleware/static_files.rb +0 -27
- data/lib/crystal/rack/rack_app.rb +0 -96
- data/lib/crystal/rack/support.rb +0 -55
- data/lib/crystal.rb +0 -37
- data/rakefile +0 -70
data/lib/crystal/http.rb
ADDED
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
# WServer provides support for Web Servers (via Rack)
|
|
2
|
+
|
|
3
|
+
require 'rack'
|
|
4
|
+
require 'rack/builder'
|
|
5
|
+
|
|
6
|
+
require 'crystal/conveyor'
|
|
7
|
+
|
|
8
|
+
# support
|
|
9
|
+
[
|
|
10
|
+
'rack/request',
|
|
11
|
+
'rack/response',
|
|
12
|
+
'rack/rack_adapter'
|
|
13
|
+
].each{|f| require "crystal/http/support/#{f}"}
|
|
14
|
+
|
|
15
|
+
# http
|
|
16
|
+
[
|
|
17
|
+
# 'config',
|
|
18
|
+
'http',
|
|
19
|
+
'http_adapter',
|
|
20
|
+
'processors/prepare_params',
|
|
21
|
+
'processors/http_writer',
|
|
22
|
+
'processors/http_logger',
|
|
23
|
+
'processors/evaluate_format'
|
|
24
|
+
].each{|f| require "crystal/http/#{f}"}
|
|
25
|
+
|
|
26
|
+
module Crystal
|
|
27
|
+
autoload :StaticFiles, 'crystal/http/middleware/static_files'
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
Crystal.metaclass_eval do
|
|
31
|
+
delegate :build_common_app, :to => Crystal::RackAdapter
|
|
32
|
+
delegate :call, :to => Crystal::HTTPAdapter
|
|
33
|
+
delegate :ensure_public_symlink, :to => Crystal::HTTP
|
|
34
|
+
end
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
#
|
|
38
|
+
# Initialization
|
|
39
|
+
#
|
|
40
|
+
Crystal::Config::DEFAULTS.merge!({
|
|
41
|
+
:host => '0.0.0.0',
|
|
42
|
+
:port => 4000,
|
|
43
|
+
|
|
44
|
+
:static => true,
|
|
45
|
+
:url_root => '',
|
|
46
|
+
:default_format => 'html',
|
|
47
|
+
}.stringify_keys)
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
gem 'mail'
|
|
2
|
+
|
|
3
|
+
require 'crystal/template'
|
|
4
|
+
|
|
5
|
+
[
|
|
6
|
+
'mail',
|
|
7
|
+
].each{|f| require "crystal/remote/#{f}"}
|
|
8
|
+
|
|
9
|
+
crystal.register :mail, :depends_on => :environment do
|
|
10
|
+
Crystal::Mail.new #TODO2 add mail config here
|
|
11
|
+
end
|
|
12
|
+
|
|
13
|
+
Crystal.run :mail, :after => :render
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
require 'crystal/profiles/web_require'
|
|
2
|
+
|
|
3
|
+
#
|
|
4
|
+
# Routes
|
|
5
|
+
#
|
|
6
|
+
Crystal::AbstractController.include Crystal::NamedRouter::Helper
|
|
7
|
+
Crystal::ControllerContext.include Crystal::NamedRouter::Helper
|
|
8
|
+
|
|
9
|
+
crystal.after :environment do
|
|
10
|
+
crystal.register(:router, :depends_on => :environment) do
|
|
11
|
+
Crystal::Router.new(:class, [
|
|
12
|
+
[:named_router, Crystal::NamedRouter.new],
|
|
13
|
+
[:default_router, Crystal::DefaultRouter.new]
|
|
14
|
+
])
|
|
15
|
+
end
|
|
16
|
+
end
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
#
|
|
20
|
+
# Conveyors
|
|
21
|
+
#
|
|
22
|
+
module Crystal::Processors
|
|
23
|
+
crystal.after :environment do
|
|
24
|
+
crystal.conveyors.web do |web|
|
|
25
|
+
# conveyor
|
|
26
|
+
web.use ConveyorLogger
|
|
27
|
+
|
|
28
|
+
# http
|
|
29
|
+
web.use HttpWriter, :content
|
|
30
|
+
web.use PrepareParams
|
|
31
|
+
web.use EvaluateFormat
|
|
32
|
+
web.use HTTPLogger
|
|
33
|
+
|
|
34
|
+
# html
|
|
35
|
+
web.use ScopedParams
|
|
36
|
+
|
|
37
|
+
# controller
|
|
38
|
+
web.use ControllerErrorHandling, :content
|
|
39
|
+
|
|
40
|
+
# router
|
|
41
|
+
web.use Router, :class, :method_name
|
|
42
|
+
|
|
43
|
+
# controller
|
|
44
|
+
web.use ControllerLogger
|
|
45
|
+
web.use ControllerCaller, :content
|
|
46
|
+
|
|
47
|
+
web.build!
|
|
48
|
+
end
|
|
49
|
+
end
|
|
50
|
+
end
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
#
|
|
54
|
+
# Rack
|
|
55
|
+
#
|
|
56
|
+
Crystal::RackAdapter.build_common_app do |builder|
|
|
57
|
+
config = crystal.config
|
|
58
|
+
|
|
59
|
+
# CommonLogger, ShowExceptions, Lint
|
|
60
|
+
builder.use Rack::Lint if config.development?
|
|
61
|
+
builder.use Crystal::StaticFiles, "#{config.root!}/public" if config.static? and config.root? and config.development?
|
|
62
|
+
|
|
63
|
+
# use Rack::Session::Cookie, :key => 'rack.session', :domain => 'foo.com', :path => '/', :expire_after => 2592000, :secret => 'change_me'
|
|
64
|
+
builder.use Rack::Session::Cookie, config.session.to_hash if config.session?
|
|
65
|
+
|
|
66
|
+
# builder.use Rack::CommonLogger
|
|
67
|
+
builder.use Rack::MethodOverride
|
|
68
|
+
# builder.use ShowExceptions if config.show_exceptions?
|
|
69
|
+
end
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
module Crystal
|
|
2
|
+
module Processors
|
|
3
|
+
class RemoteCaller < Processor
|
|
4
|
+
# TODO2 :remote isn't registered with crystal[
|
|
5
|
+
inject :remote => :remote
|
|
6
|
+
|
|
7
|
+
def initialize next_processor, result_variable = 'content'
|
|
8
|
+
super(next_processor)
|
|
9
|
+
@result_variable = result_variable
|
|
10
|
+
end
|
|
11
|
+
|
|
12
|
+
def call
|
|
13
|
+
return next_processor.call unless workspace.class?
|
|
14
|
+
|
|
15
|
+
# prepare
|
|
16
|
+
klass = workspace.class
|
|
17
|
+
raise "The remote class #{klass} must be a Crystal::Remote!" unless klass.is? Crystal::Remote
|
|
18
|
+
workspace.remote_object = klass.new
|
|
19
|
+
method = workspace.method_name
|
|
20
|
+
|
|
21
|
+
# call
|
|
22
|
+
begin
|
|
23
|
+
result = workspace.remote_object.run_callbacks :action, :method => method do
|
|
24
|
+
workspace.remote_object.send method
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
ensure_correct_result! result
|
|
28
|
+
workspace.remote_result = result
|
|
29
|
+
|
|
30
|
+
next_processor.call
|
|
31
|
+
|
|
32
|
+
# write JSON as a result if format is JSON and no one else filled it
|
|
33
|
+
if workspace[@result_variable].blank?
|
|
34
|
+
workspace[@result_variable] = workspace.remote_result.to_json
|
|
35
|
+
end
|
|
36
|
+
rescue StandardError => e
|
|
37
|
+
raise e if !workspace.params.format.json? or config.test?
|
|
38
|
+
|
|
39
|
+
workspace[@result_variable] = {:error => e.message}.to_json
|
|
40
|
+
|
|
41
|
+
logger.error e
|
|
42
|
+
logger.info "\n"
|
|
43
|
+
end
|
|
44
|
+
end
|
|
45
|
+
|
|
46
|
+
private
|
|
47
|
+
def ensure_correct_result! result
|
|
48
|
+
unless result.rson?
|
|
49
|
+
raise "You can't use object of type '#{result.class}' as Remote's return value!"
|
|
50
|
+
end
|
|
51
|
+
end
|
|
52
|
+
end
|
|
53
|
+
end
|
|
54
|
+
end
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
module Crystal
|
|
2
|
+
module Processors
|
|
3
|
+
class RemoteLogger < Processor
|
|
4
|
+
def call
|
|
5
|
+
next_processor.call
|
|
6
|
+
|
|
7
|
+
if (klass = workspace.class) and (method = workspace.method_name)
|
|
8
|
+
logger.info "Processing #{klass.name}.#{method} with #{workspace.params.inspect}"
|
|
9
|
+
end
|
|
10
|
+
end
|
|
11
|
+
end
|
|
12
|
+
end
|
|
13
|
+
end
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
module Crystal
|
|
2
|
+
module Routes
|
|
3
|
+
class Configurator
|
|
4
|
+
def initialize router
|
|
5
|
+
@router = router
|
|
6
|
+
end
|
|
7
|
+
|
|
8
|
+
def named_route *args, &block
|
|
9
|
+
named_router = @router.routes[:named_router]
|
|
10
|
+
raise "There's no NamedRouter (use config to add it)!" unless named_router
|
|
11
|
+
named_router.add *args, &block
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
class << self
|
|
15
|
+
inject :router => :router
|
|
16
|
+
|
|
17
|
+
def routes &block
|
|
18
|
+
block.call Configurator.new(router)
|
|
19
|
+
end
|
|
20
|
+
end
|
|
21
|
+
end
|
|
22
|
+
end
|
|
23
|
+
end
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
module Crystal
|
|
2
|
+
class DefaultRouter
|
|
3
|
+
inject :logger => :logger
|
|
4
|
+
|
|
5
|
+
def encode klass, method, params
|
|
6
|
+
path = "/#{klass.name.underscore}/#{method}"
|
|
7
|
+
return path, params
|
|
8
|
+
end
|
|
9
|
+
|
|
10
|
+
def decode path, params
|
|
11
|
+
parts = path[1..-1].split '/'
|
|
12
|
+
if parts.size >= 2
|
|
13
|
+
method = parts.pop
|
|
14
|
+
|
|
15
|
+
class_path = parts.join('/')
|
|
16
|
+
class_name = class_path.camelize
|
|
17
|
+
klass = class_name.constantize
|
|
18
|
+
|
|
19
|
+
return klass, method, params
|
|
20
|
+
end
|
|
21
|
+
end
|
|
22
|
+
end
|
|
23
|
+
end
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
module Crystal
|
|
2
|
+
class NamedRouter
|
|
3
|
+
attr_accessor :names, :classes
|
|
4
|
+
|
|
5
|
+
def initialize
|
|
6
|
+
@names, @classes = {}, {}
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
def add name, klass
|
|
10
|
+
name = name.to_s
|
|
11
|
+
names[name] = klass
|
|
12
|
+
classes[klass] = name
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
def encode klass, method, params
|
|
16
|
+
if name = classes[klass]
|
|
17
|
+
path = "/#{name}/#{method}"
|
|
18
|
+
return path, params
|
|
19
|
+
else
|
|
20
|
+
nil
|
|
21
|
+
end
|
|
22
|
+
end
|
|
23
|
+
|
|
24
|
+
def decode path, params
|
|
25
|
+
parts = path[1..-1].split '/'
|
|
26
|
+
if parts.size >= 2
|
|
27
|
+
method = parts.pop
|
|
28
|
+
name = parts.join('/')
|
|
29
|
+
|
|
30
|
+
if klass = names[name]
|
|
31
|
+
return klass, method, params
|
|
32
|
+
else
|
|
33
|
+
nil
|
|
34
|
+
end
|
|
35
|
+
end
|
|
36
|
+
end
|
|
37
|
+
|
|
38
|
+
def encode_route_method method, params = {}
|
|
39
|
+
method = method.sub(/_path$/, '')
|
|
40
|
+
names.each do |name, klass|
|
|
41
|
+
if i = method.rindex(name)
|
|
42
|
+
if method.size == i + name.size and method[(i-1)..(i-1)] == '_'
|
|
43
|
+
return encode(klass, method[0..(i-2)], params)
|
|
44
|
+
end
|
|
45
|
+
end
|
|
46
|
+
end
|
|
47
|
+
raise "Unknown route #{method}!"
|
|
48
|
+
end
|
|
49
|
+
cache_method_with_params :encode_route_method
|
|
50
|
+
|
|
51
|
+
module Helper
|
|
52
|
+
protected
|
|
53
|
+
def method_missing m, *args, &block
|
|
54
|
+
m = m.to_s
|
|
55
|
+
if m =~ /_path$/
|
|
56
|
+
crystal[:router].routes[:named_router].encode_route_method m, *args
|
|
57
|
+
else
|
|
58
|
+
super m.to_sym, *args, &block
|
|
59
|
+
end
|
|
60
|
+
end
|
|
61
|
+
end
|
|
62
|
+
end
|
|
63
|
+
end
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
module Crystal
|
|
2
|
+
module Processors
|
|
3
|
+
class Router < Processor
|
|
4
|
+
inject :router => :router
|
|
5
|
+
|
|
6
|
+
def initialize next_processor, class_variable = 'class', method_variable = 'method'
|
|
7
|
+
super(next_processor)
|
|
8
|
+
@class_variable, @method_variable = class_variable, method_variable
|
|
9
|
+
end
|
|
10
|
+
|
|
11
|
+
def call
|
|
12
|
+
klass, method, params = router.decode workspace.path, workspace.params
|
|
13
|
+
|
|
14
|
+
# params.class_name, params.method_name = klass.name, method
|
|
15
|
+
|
|
16
|
+
workspace[@class_variable], workspace[@method_variable], workspace.params = klass, method, params
|
|
17
|
+
|
|
18
|
+
next_processor.call
|
|
19
|
+
end
|
|
20
|
+
end
|
|
21
|
+
end
|
|
22
|
+
end
|
|
@@ -0,0 +1,218 @@
|
|
|
1
|
+
module Crystal
|
|
2
|
+
class Router
|
|
3
|
+
|
|
4
|
+
inject(
|
|
5
|
+
:config => :config,
|
|
6
|
+
:workspace => :workspace
|
|
7
|
+
)
|
|
8
|
+
|
|
9
|
+
attr_reader :routes, :format_processor
|
|
10
|
+
|
|
11
|
+
def initialize class_variable, routes = [[:default_router, DefaultRouter.new]], format_processor = DefaultFormatProcessor.new
|
|
12
|
+
@class_variable, @format_processor = class_variable, format_processor
|
|
13
|
+
@routes = Dictionary.new
|
|
14
|
+
routes.each do |k, v|
|
|
15
|
+
k.must_be.present
|
|
16
|
+
v.must_be.present
|
|
17
|
+
v.must.respond_to(:decode)
|
|
18
|
+
v.must.respond_to(:encode)
|
|
19
|
+
|
|
20
|
+
@routes[k] = v
|
|
21
|
+
end
|
|
22
|
+
end
|
|
23
|
+
|
|
24
|
+
def url_for *args
|
|
25
|
+
if args.first.is_a?(Class)
|
|
26
|
+
args.size.must_be.in 2..3
|
|
27
|
+
klass, method, options = args
|
|
28
|
+
url_for_class(klass, method, (options || {}))
|
|
29
|
+
else
|
|
30
|
+
first = args.first.to_s
|
|
31
|
+
if first !~ /^\//
|
|
32
|
+
args.size.must_be.in 1..2
|
|
33
|
+
method, options = args
|
|
34
|
+
url_for_class(nil, method, (options || {}))
|
|
35
|
+
else
|
|
36
|
+
args.size.must_be.in 1..2
|
|
37
|
+
path, options = args
|
|
38
|
+
url_for_path(path, (options || {}))
|
|
39
|
+
end
|
|
40
|
+
end
|
|
41
|
+
end
|
|
42
|
+
|
|
43
|
+
def decode path, params
|
|
44
|
+
path.first.must == '/'
|
|
45
|
+
params = params.to_openobject
|
|
46
|
+
|
|
47
|
+
path, format = format_processor.remove_format path if format_processor
|
|
48
|
+
|
|
49
|
+
result = nil
|
|
50
|
+
routes.each do |name, route|
|
|
51
|
+
result = route.decode path, params
|
|
52
|
+
break if result
|
|
53
|
+
end
|
|
54
|
+
|
|
55
|
+
raise "No route for '#{workspace.path}' request!" unless result
|
|
56
|
+
|
|
57
|
+
klass, method, params = result
|
|
58
|
+
method ||= config.default_method
|
|
59
|
+
params.must_be.defined
|
|
60
|
+
|
|
61
|
+
raise "Invalid route! No method '#{method}' for #{klass}!" unless klass.instance_methods.include? method
|
|
62
|
+
raise "Invalid route! You try to call protected method '#{method}' for '#{klass}'!" unless klass.public_instance_methods.include? method
|
|
63
|
+
|
|
64
|
+
return klass, method, params
|
|
65
|
+
end
|
|
66
|
+
|
|
67
|
+
def encode klass, method, params = {}
|
|
68
|
+
klass.must_be.defined
|
|
69
|
+
method, params = method.to_s, params.to_openobject
|
|
70
|
+
|
|
71
|
+
format = params.delete :format
|
|
72
|
+
|
|
73
|
+
raise "Invalid route! No method '#{method}' for #{klass}!" unless klass.instance_methods.include? method
|
|
74
|
+
raise "Invalid route! You try to call protected method '#{method}' for '#{klass}'!" unless klass.public_instance_methods.include? method
|
|
75
|
+
|
|
76
|
+
result = nil
|
|
77
|
+
routes.each do |name, route|
|
|
78
|
+
result = route.encode klass, method, params
|
|
79
|
+
break if result
|
|
80
|
+
end
|
|
81
|
+
|
|
82
|
+
raise "No route for '#{klass}.#{method}'!" unless result
|
|
83
|
+
|
|
84
|
+
path, params = result
|
|
85
|
+
path.must_be.defined
|
|
86
|
+
params.must_be.defined
|
|
87
|
+
|
|
88
|
+
path = format_processor.add_format path, format if format_processor and format
|
|
89
|
+
|
|
90
|
+
return path, params
|
|
91
|
+
end
|
|
92
|
+
|
|
93
|
+
def persist_params &block
|
|
94
|
+
before = Thread.current[:persist_params]
|
|
95
|
+
begin
|
|
96
|
+
Thread.current[:persist_params] = true
|
|
97
|
+
block.call
|
|
98
|
+
ensure
|
|
99
|
+
Thread.current[:persist_params] = before
|
|
100
|
+
end
|
|
101
|
+
end
|
|
102
|
+
|
|
103
|
+
def dont_persist_params &block
|
|
104
|
+
before = Thread.current[:persist_params]
|
|
105
|
+
begin
|
|
106
|
+
Thread.current[:persist_params] = false
|
|
107
|
+
block.call
|
|
108
|
+
ensure
|
|
109
|
+
Thread.current[:persist_params] = before
|
|
110
|
+
end
|
|
111
|
+
end
|
|
112
|
+
|
|
113
|
+
def persist_params?
|
|
114
|
+
!!Thread.current[:persist_params]
|
|
115
|
+
end
|
|
116
|
+
|
|
117
|
+
def global_persistent_params; @global_persistent_params ||= [] end
|
|
118
|
+
|
|
119
|
+
protected
|
|
120
|
+
def current_class; workspace[@class_variable] end
|
|
121
|
+
|
|
122
|
+
def url_for_class klass, method, params
|
|
123
|
+
klass ||= current_class
|
|
124
|
+
params = params.to_openobject
|
|
125
|
+
|
|
126
|
+
# special params
|
|
127
|
+
format = params.format
|
|
128
|
+
|
|
129
|
+
path, params = encode klass, method.to_s, params
|
|
130
|
+
url = url_for_path path, params
|
|
131
|
+
|
|
132
|
+
url.marks.format = format.to_s if format
|
|
133
|
+
|
|
134
|
+
url
|
|
135
|
+
end
|
|
136
|
+
|
|
137
|
+
def url_for_path path, params
|
|
138
|
+
params = params.to_openobject
|
|
139
|
+
|
|
140
|
+
# special params
|
|
141
|
+
url = if params.include? :url_root
|
|
142
|
+
(params.delete(:url_root) || "") + path
|
|
143
|
+
else
|
|
144
|
+
config.url_root! + path
|
|
145
|
+
end
|
|
146
|
+
host, port = params.delete(:host), params.delete(:port)
|
|
147
|
+
format = params.delete(:format)
|
|
148
|
+
raise ":no_prefix is deprecated!" if params.no_prefix? # TODO3 now it uses :url_root instead, remove this after updating spaces
|
|
149
|
+
|
|
150
|
+
# inject persistent params
|
|
151
|
+
inject_persistent_params! params, params.delete(:persist)
|
|
152
|
+
|
|
153
|
+
# json
|
|
154
|
+
params = {:json => params.to_json}.to_openobject if params.delete :as_json #and !params.empty?
|
|
155
|
+
|
|
156
|
+
# format
|
|
157
|
+
if format
|
|
158
|
+
params.format = format
|
|
159
|
+
url.marks.format = format.to_s
|
|
160
|
+
end
|
|
161
|
+
|
|
162
|
+
# Delete 'nil' parameters
|
|
163
|
+
to_delete = []
|
|
164
|
+
params.each{|k, v| to_delete << k if v.nil?}
|
|
165
|
+
to_delete.each{|k| params.delete k}
|
|
166
|
+
|
|
167
|
+
# build url
|
|
168
|
+
delimiter = path.include?('?') ? '&' : '?'
|
|
169
|
+
url << "#{delimiter}#{params.to_query}" unless params.empty?
|
|
170
|
+
|
|
171
|
+
if host.blank?
|
|
172
|
+
url
|
|
173
|
+
else
|
|
174
|
+
%{http://#{host}#{":#{port}" unless port.blank?}#{url}}
|
|
175
|
+
end
|
|
176
|
+
end
|
|
177
|
+
|
|
178
|
+
DONOT_PERSIST = ['_', '_method']
|
|
179
|
+
|
|
180
|
+
def inject_persistent_params! params, persist
|
|
181
|
+
# global persistent params
|
|
182
|
+
unless cached_global_persistend_params = workspace.cached_global_persistend_params
|
|
183
|
+
cached_global_persistend_params, workspace_params = {}, workspace.params
|
|
184
|
+
global_persistent_params.collect!{|k| k.to_s}
|
|
185
|
+
|
|
186
|
+
workspace_params.each do |k, v|
|
|
187
|
+
k = k.to_s
|
|
188
|
+
cached_global_persistend_params[k] = v if global_persistent_params.include?(k)
|
|
189
|
+
end
|
|
190
|
+
|
|
191
|
+
workspace.cached_global_persistend_params = cached_global_persistend_params
|
|
192
|
+
end
|
|
193
|
+
|
|
194
|
+
cached_global_persistend_params.each do |k, v|
|
|
195
|
+
params[k] = v unless params.include? k
|
|
196
|
+
end
|
|
197
|
+
|
|
198
|
+
# underscored persistent params
|
|
199
|
+
if persist_params? or persist
|
|
200
|
+
unless cached_persistend_params = workspace.cached_persistend_params
|
|
201
|
+
cached_persistend_params, workspace_params = {}, workspace.params
|
|
202
|
+
|
|
203
|
+
workspace_params.each do |k, v|
|
|
204
|
+
k = k.to_s
|
|
205
|
+
cached_persistend_params[k] = v if (k =~ /^_/) and !DONOT_PERSIST.include?(k)
|
|
206
|
+
end
|
|
207
|
+
|
|
208
|
+
workspace.cached_persistend_params = cached_persistend_params
|
|
209
|
+
end
|
|
210
|
+
|
|
211
|
+
cached_persistend_params.each do |k, v|
|
|
212
|
+
params[k] = v unless params.include? k
|
|
213
|
+
end
|
|
214
|
+
end
|
|
215
|
+
end
|
|
216
|
+
|
|
217
|
+
end
|
|
218
|
+
end
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
module Crystal
|
|
2
|
+
module RoutingHelper
|
|
3
|
+
inject :router => :router
|
|
4
|
+
|
|
5
|
+
delegate :url_for, :persist_params, :dont_persist_params, :to => :router
|
|
6
|
+
|
|
7
|
+
def default_path options = {}
|
|
8
|
+
url_for_path config.default_path!, options.merge(:url_root => false)
|
|
9
|
+
end
|
|
10
|
+
|
|
11
|
+
def return_to_path options = {}
|
|
12
|
+
do_not_persist_params do
|
|
13
|
+
url_for_path params[:_return_to] || session[:return_to] || config.default_path!, options.merge(:url_root => false)
|
|
14
|
+
end
|
|
15
|
+
end
|
|
16
|
+
end
|
|
17
|
+
end
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
require 'crystal/conveyor'
|
|
2
|
+
|
|
3
|
+
%w(
|
|
4
|
+
configurator
|
|
5
|
+
router
|
|
6
|
+
routing_helper
|
|
7
|
+
default_router
|
|
8
|
+
named_router
|
|
9
|
+
default_format_processor
|
|
10
|
+
processors/router
|
|
11
|
+
).each{|f| require "crystal/router/#{f}"}
|
|
12
|
+
|
|
13
|
+
Crystal::Config::DEFAULTS.merge!({
|
|
14
|
+
:default_path => '/'
|
|
15
|
+
}.stringify_keys)
|
|
16
|
+
|
|
17
|
+
Crystal.metaclass do
|
|
18
|
+
delegate :routes, :to => Crystal::Routes::Configurator
|
|
19
|
+
end
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
require 'crystal/spec/environment'
|
|
2
|
+
|
|
3
|
+
RSpec::Core::ExampleGroup.class_eval do
|
|
4
|
+
def ccall klass, method, params = {}
|
|
5
|
+
crystal.conveyors.web.call(
|
|
6
|
+
:class => klass, :method_name => method.to_s, :params => Crystal::Params.new(params)
|
|
7
|
+
)
|
|
8
|
+
end
|
|
9
|
+
end
|
|
10
|
+
|
|
11
|
+
Crystal::AbstractController.class_eval do
|
|
12
|
+
def render_ok
|
|
13
|
+
render :inline => 'ok'
|
|
14
|
+
end
|
|
15
|
+
end
|