1
0
Fork 0
forked from OpenNeo/impress

use MobileService for loading the pets for a username

This commit is contained in:
Emi Matchu 2015-05-28 17:12:39 -05:00
parent b0cc4c2396
commit eb665f10a4

View file

@ -1,9 +1,14 @@
require 'rocketamf/remote_gateway'
require 'open-uri' require 'open-uri'
class NeopetsUser class NeopetsUser
include ActiveModel::Conversion include ActiveModel::Conversion
extend ActiveModel::Naming extend ActiveModel::Naming
GATEWAY_URL = 'http://www.neopets.com/amfphp/gateway.php'
GET_PETS_METHOD = RocketAMF::RemoteGateway.new(GATEWAY_URL).
service('MobileService').action('getPets')
attr_accessor :username attr_accessor :username
attr_reader :hangers, :list_id attr_reader :hangers, :list_id
@ -27,15 +32,24 @@ class NeopetsUser
end end
def load! def load!
user = Neopets::User.new(@username) neopets_language_code = I18n.compatible_neopets_language_code_for(I18n.locale)
begin begin
pets = user.pets envelope = GET_PETS_METHOD.request([@username]).post(
rescue Neopets::User::Error => e :timeout => 4,
:headers => {
'Cookie' => "lang=#{neopets_language_code}"
}
)
rescue RocketAMF::RemoteGateway::AMFError => e
raise NotFound, e.message raise NotFound, e.message
rescue RocketAMF::RemoteGateway::ConnectionError => e
raise NotFound, e.message, e.backtrace
end end
pets = pets.map { |pet| Pet.find_or_initialize_by_name(pet.name) }
pets_data = envelope.messages[0].data.body
raise NotFound if pets_data == false
pets = pets_data.map { |pet| Pet.find_or_initialize_by_name(pet['name']) }
items = pets.each(&:load!).map(&:items).flatten items = pets.each(&:load!).map(&:items).flatten
item_ids = items.map(&:id) item_ids = items.map(&:id)
item_quantities = {} item_quantities = {}