Rack middleware which transforms incoming and outgoing JSON keys to support the development of Rails JSON-based APIs.
By default, incoming JSON keys are transformed from camelCase
to snake_case
and outgoing JSON keys are transformed from snake_case
to camelCase
.
Add this to your Gemfile:
gem 'json_key_transformer_middleware'
Then execute:
$ bundle install
Or, install it directly:
$ gem install json_key_transformer_middleware
Simply including the gem in the Gemfile for a Rails application will initialize the rack middleware which transforms incoming and outgoing JSON keys.
The primary purpose of this gem is to:
- Transform incoming parameter names from JSON-style
camelCase
to Ruby-stylesnake_case
. Clients sendcamelCase
parameters, you work withsnake_case
params in your Rails controllers. - Transform outgoing parameter names from Ruby-style
snake_case
to JSON-stylecamelCase
. When rendering a JSON response, you send asnake_case
hash response, the client will receive acamelCase
response.
In both cases the transformation process walks the entire incoming and outgoing data structure.
Incoming transformation example
From (JSON):
{"paramName": "value", "paramName2": [{"paramName3": "value"}]}
To (Rails params):
{"param_name" => "value", "param_name2" => [{"param_name3" => "value"}]}
Outgoing transformation example
From (Rails response):
{"param_name" => "value", "param_name2" => [{"param_name3" => "value"}]}
To (JSON):
{"paramName": "value", "paramName2": [{"paramName3": "value"}]}
This middleware uses the hash_key_transformer
gem to perform deep transformation of hash keys. You can configure incoming and outgoing hash transformations. Use any of the available transformations and transformation options provided by hash_key_transformer
.
The Railtie provides these configuration options:
incoming_strategy
- default value of:transform_camel_to_underscore
.incoming_strategy_options
- no options set by default.outgoing_strategy
- default value of:transform_underscore_to_camel
.outgoing_strategy_options
- no options set by default.skip_paths
- skip the transformation if HTTP request path matches. e.g.[/^\/admin/, '/graphql']
should_skip_if
- skip the transformation if return true. called with Rackenv
. e.g.->(env) { env['HTTP_SOME_HEADER'] == 'true' }
incoming_should_skip_if
- likeshould_skip_if
but only for skipping incoming params / json bodyoutgoing_should_skip_if
- likeshould_skip_if
but only for skipping outgoing json bodycheck_content_type
- skip the transformation unlessContent-Type
containsapplication/json
(defaults totrue
)
Here is an example Rails initializer which turns on the outgoing_strategy_options.keep_lead_underscore
option:
# initializers/json_key_transformer_middleware.rb
Rails.application.config.json_key_transformer_middleware.outgoing_strategy_options.keep_lead_underscore = true
This gem serves a very specific purpose. As such, it only targets a specific version of Rails. Over time more versions of Rails may be supported.
Apache License, Version 2.0