2

У меня есть Сервер, работающий с активными моделями (не активная запись) и клиентская сторона с activeresource.Rails 3.1.3 REST: Не удается получить ошибки со стороны activeresource (json serializer)

Например стороне сервера контроллера есть такой код

... 
     def update 

     if @supplier.update_attributes(params[:supplier]) 
      respond_to do |format| 
       format.any { head :ok } 
      end 
     else 

      respond_with(@supplier.errors,:status => :unprocessable_entity) 
     end  
     end 
... 

Активный модель имеет следующее кодовое

... 
    class Subscriber < BaseModel 
    include ActiveModel::Validations 
    include ActiveModel::Serialization 
    include ActiveModel::Callbacks 
    extend ActiveModel::Naming 
    validates :email, :format => /\A([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})\Z/i 
    def update_attributes(attributes={}) 
     self.attributes.merge!(attributes) 
     self.save 
     end 

     def save 
      if self.valid? 
      super 
      else 
      false 
      end  
     end 
... 

я типа следующий код с рельсов консоли клиентского приложения

s = Supplier.find(13) 
s.email = '' 
s.save 

возврата ложной из-за недействительного сообщения электронной почты

это ошибка объекта с сервера перед отправкой с respond_with

#<ActiveModel::Errors:0x000001012e9d78 @base=#<Supplier:0x000001032bf8c8 @attributes={:id=>13, :company_name=>.......}, @validation_context=nil, @errors=#<ActiveModel::Errors:0x000001012e9d78 ...>>, @messages={:email=>["is invalid"]}> 

и клиент имеет следующие значения с

.... @remote_errors=#<ActiveResource::ResourceInvalid: Failed. Response code = 422. Response message = .>, @validation_context=nil, @errors=#<ActiveResource::Errors:0x000001034991d0 @base=#<Didww::Supplier:0x000001034af048 ...>, @messages={}>> 

Почему я не могу взять ошибки в стороне клиента (сообщения пустого хэша) ?

UPD: клиент прибудет {} в теле ответа

"--- !ruby/object:Net::HTTPClientError \nbody: \"{}\"\nbody_exist: true\ncode: \"422\"\nheader: \n content-type: \n - application/json; charset=utf-8\n x-ua-compatible: \n - IE=Edge\n cache-control: \n - no-cache\n x-runtime: \n - \"0.128106\"\n content-length: \n - \"2\"\n server: \n - WEBrick/1.3.1 (Ruby/1.9.2/2011-02-18)\n date: \n - Thu, 29 Dec 2011 10:57:50 GMT\n connection: \n - close\n set-cookie: \n - _api_session=BAh7BkkiD3Nlc3Npb25faWQGOgZFRkkiJTM5OWQwNTZhMzI1MzcxYzdjZGI2NzNkZWZjNWE0OTQwBjsAVA%3D%3D--b9a0f65001dd994f269800f1c56259523ab669b1; path=/; HttpOnly\nhttp_version: \"1.1\"\nmessage: \"\"\nread: true\nsocket: \n" 

UPD2 если действие контроллера выглядит следующий

@supplier.update_attributes(params[:supplier]) 
respond_with(@supplier) 

чем ответ выглядит следующий

"--- !ruby/object:Net::HTTPClientError \nbody: \"{\\\"email\\\":[\\\"is invalid\\\"]}\"\nbody_exist: true\ncode: \"422\"\nheader: \n... 

так I th Проблема чернил в том, что клиент и сервер используют различную логику для сериализации

class Errors < ActiveModel::Errors 

    # Grabs errors from a json response. 
    def from_json(json, save_cache = false) 
     array = Array.wrap(ActiveSupport::JSON.decode(json)['errors']) rescue [] 
     from_array array, save_cache 
    end 

клиент ожидает, что сервер использует ключ ошибки для ошибки хэша ({: ошибки => {: электронная почта => [ «недействителен»]}}), но сервер (просто {: email => ["недействительно"]})

Что я пропустил ???

ответ

 Смежные вопросы

  • Нет связанных вопросов^_^