Search code examples
ruby-on-railspostgresqlruby-on-rails-4hstore

setting hstore in rails4, dynamic key/values


I'm playing around with Hstore for the first time in a rails4 app, and I am using javascript in a form to build out dynamic form fields for the hstore column (:schema)

In rails 4 I dont need to add any setter/getter method in my model, correct?

In my form i am building dynamic input fields and allowing the user to set the key/value pairs. Much like the Hstore Heroku Demo App

So basically my form would have inputs like

input name="app[schema][dynamic_key1]" value="whatever value"
input name="app[schema][dynamic_key2]" value="whatever value2"

In my App Controller:

def app_params
  params.require(:app).permit(:name, :title, :schema )
end

However, when i create a new App record, my schema hstore values are not saving. I saw some things about making the strong param for :schema => [] but that still does not work.

Since I do not know what these values will be, i cant setup store_accessors for these like I have seen in a lot of examples.


Solution

  • found this here: http://guides.rubyonrails.org/action_controller_overview.html#more-examples

    and in my controller I used:

    def app_params
      params.require(:app).permit(:name, :title).tap do |whitelisted|
        whitelisted[:schema] = params[:app][:schema]
      end
    end