Rails 4 model always returns nil

I'm going crazy with the following error. I have a User class, and its two attributes (birthday and created_at => datetime) always return to zero, in addition, it has a value in the database.

I am using an authentication management device.

This is the db table:

CREATE TABLE users
(
  id serial NOT NULL,
  email character varying(255) NOT NULL DEFAULT ''::character varying,
  encrypted_password character varying(255) NOT NULL DEFAULT ''::character varying,
  reset_password_token character varying(255),
  reset_password_sent_at timestamp without time zone,
  remember_created_at timestamp without time zone,
  sign_in_count integer NOT NULL DEFAULT 0,
  current_sign_in_at timestamp without time zone,
  last_sign_in_at timestamp without time zone,
  current_sign_in_ip character varying(255),
  last_sign_in_ip character varying(255),
  name character varying(255),
  lastname character varying(255),
  birthday timestamp without time zone,
  gender character varying(255),
  created_at timestamp without time zone,
  updated_at timestamp without time zone,
  authentication_token character varying(255),
  facebook_uid character varying(255),
  gplus_uid character varying(255),
  CONSTRAINT users_pkey PRIMARY KEY (id)
)
WITH (
  OIDS=FALSE
);

and this is a model

#encoding: utf-8
class User < ActiveRecord::Base

  has_many :user_benefits
  has_many :benefits, through: :user_benefits

  devise :database_authenticatable, :registerable,
         :recoverable, :rememberable, :trackable, :validatable

  validates :gender, :inclusion => { :in => %w(m f)}
  validates :email, email_format: { message: "Email invalido" }

  before_save :ensure_authentication_token

  def ensure_authentication_token
    if authentication_token.blank?
      self.authentication_token = generate_authentication_token
    end
  end

  def set_gender new_gender

    case new_gender.downcase
      when "male"
        self.gender = 'm'
      when "female"
        self.gender = 'f'
      when "m"
        self.gender = 'm'
      when "f"
        self.gender = 'f'
      else
        self.gender = nil
    end

  end

  def get_response
    {
        :auth_token=>self.authentication_token,
        :user => {
          :email=> self.email,
          :name=> self.name,
          :lastname=> self.lastname,
          :birthday=> self.birthday,
          :gender=> self.gender,
          :auth_token=> self.authentication_token,
          :created_at=> self.created_at,
          :updated_at=> self.updated_at,
          :facebook_uid=> self.facebook_uid,
          :gplus_uid=> self.gplus_uid
        }
    }
  end

  private

  def generate_authentication_token
    loop do
      token = Devise.friendly_token
      break token unless User.where(authentication_token: token).first
    end
  end

end

When I call get_response, I get:

{
  auth_token: "fRoi1RPTuP64m55jXCSS"
  user: {
    email: "testg@habitues.com"
    name: "Lalo"
    lastname: "Landa"
    birthday: null
    gender: "m"
    auth_token: "fRoi1RPTuP64m55jXCSS"
    created_at: null
    updated_at: "2013-11-27T20:14:22.534-03:00"
    facebook_uid: null
    gplus_uid: null
  }
  new: false
}

Does anyone have an idea?

thanks

+4
source share
3 answers

I found a problem.

A few days ago, I changed the config / application.rb file, adding the following configuration to solve some problems with time zones:

config.time_zone and config.active_record.default_timezone

I just deleted them and everything works fine again.

+3
source

config.active_record.default_timezone character is required: local or: utc.

config.time_zone , .

config.active_record.default_timezone , Time.local( : local) Time.utc( : utc) . : utc.

http://guides.rubyonrails.org/configuring.html#configuring-active-record

+5

There was the same problem, and that was specifically

config.active_record.default_timezone

This made activerecord return all timestamps stored in UTC as null. I don’t know why, but deleting it brought all the data. I managed to leave default config.time_zone in place.

+3
source

All Articles