aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRafael Mendonça França <rafaelmfranca@gmail.com>2014-04-11 11:10:59 -0300
committerRafael Mendonça França <rafaelmfranca@gmail.com>2014-04-11 11:10:59 -0300
commit08775e347f40e60374a0661e97fa21edbfbbf403 (patch)
tree52d711f8c48d1039e396a31ed7cb9a66a283bcb9
parentd91117f225915ec32dc10974d39355d315f490ac (diff)
parentaca64fed43d0c9eafabaf6a36c749796783c899c (diff)
downloadrails-08775e347f40e60374a0661e97fa21edbfbbf403.tar.gz
rails-08775e347f40e60374a0661e97fa21edbfbbf403.tar.bz2
rails-08775e347f40e60374a0661e97fa21edbfbbf403.zip
Merge pull request #14707 from minio-sk/fix-issue-14702
Be explicit about allowed constraint values, fixes #14702
-rw-r--r--guides/source/routing.md2
1 files changed, 2 insertions, 0 deletions
diff --git a/guides/source/routing.md b/guides/source/routing.md
index eef618f28d..921658a71e 100644
--- a/guides/source/routing.md
+++ b/guides/source/routing.md
@@ -694,6 +694,8 @@ namespace :admin do
end
```
+NOTE: Request constraints work by calling a method on the <a href="action_controller_overview.html#the-request-object">Request object</a> with the same name as the hash key and then compare the return value with the hash value. Therefore, constraint values should match the corresponding Request object method return type. For example: `constraints: { subdomain: 'api' }` will match an `api` subdomain as expected, however using a symbol `constraints: { subdomain: :api }` will not, because `request.subdomain` returns `'api'` as a String.
+
### Advanced Constraints
If you have a more advanced constraint, you can provide an object that responds to `matches?` that Rails should use. Let's say you wanted to route all users on a blacklist to the `BlacklistController`. You could do: