README.md in metaractor-3.0.1 vs README.md in metaractor-3.1.0
- old
+ new
@@ -1,6 +1,6 @@
-# Metaractor
+# Metaractor [data:image/s3,"s3://crabby-images/61bb7/61bb70f5f8a943824193f6b1d8ab645c6cf6a619" alt="Build status"](https://buildkite.com/outstand/metaractor)
Adds parameter validation and error control to [interactor](https://github.com/collectiveidea/interactor).
## Installation
Add this line to your application's Gemfile:
@@ -100,9 +100,27 @@
This works with `allow_blank` and can also be anything that responds to `#call`.
```ruby
parameter :role, allow_blank: true, default: -> { context.default_role }
```
+
+#### Typecasting/Coersion
+You can supply Metaractor with a callable that will typecast incoming parameters:
+```ruby
+optional :needs_to_be_a_string, type: ->(value) { value.to_s }
+```
+
+You can also configure Metaractor with named types and use them:
+```ruby
+Metaractor.configure do |config|
+ config.register_type(:boolean, ->(value) { ActiveModel::Type::Boolean.new.cast(value) })
+end
+```
+```ruby
+required :is_awesome, type: :boolean
+```
+
+**Note**: Typecasters will _not_ be called on `nil` values.
### Custom Validation
Metaractor supports doing custom validation before any user supplied before_hooks run.
```ruby
validate_parameters do