add WowGuild model

This commit is contained in:
2021-05-28 17:04:31 +02:00
parent 558cc52de9
commit f8c539bb87
7 changed files with 108 additions and 2 deletions

View File

@@ -9,6 +9,7 @@ class WowCharacter < ApplicationRecord
belongs_to :wow_class
belongs_to :wow_race
belongs_to :wow_character_title, optional: true
belongs_to :wow_guild, optional: true
belongs_to :last_position, class_name: 'WowGeoPosition', optional: true
belongs_to :bind_position, class_name: 'WowGeoPosition', optional: true
has_one :wow_character_medium, dependent: :nullify

12
app/models/wow_guild.rb Normal file
View File

@@ -0,0 +1,12 @@
# frozen_string_literal: true
class WowGuild < ApplicationRecord
extend Mobility
translates :translated_faction
belongs_to :wow_realm
has_many :wow_characters, dependent: :nullify
validates :name, presence: true
validates :guild_id, presence: true, uniqueness: true
end

View File

@@ -8,7 +8,11 @@ class WowCharacterDetailWorker < WowSidekiqWorker
RBattlenet.set_options(locale: 'en_GB')
# Public data
result = RBattlenet::Wow::Character.find({ name: wow_character.name.downcase, realm: wow_character.wow_realm.slug })
params = {
name: wow_character.name.downcase,
realm: wow_character.wow_realm.slug
}
result = RBattlenet::Wow::Character.find(params)
return unless result.status_code == 200
@@ -17,7 +21,22 @@ class WowCharacterDetailWorker < WowSidekiqWorker
wow_character.average_item_level = result.average_item_level
wow_character.equipped_item_level = result.equipped_item_level
wow_character.wow_character_title = WowCharacterTitle.find_by(title_id: result.active_title.id) if result.active_title
wow_character.wow_guild = find_or_create_wow_guild(result.guild) if result.guild
wow_character.save
end
def find_or_create_wow_guild(guild)
WowGuild.find_by(guild_id: guild.id)
rescue ActiveRecord::RecordNotFound
return unless (wow_realm = WowRealm.find_by(realm_id: guild.realm.id))
wow_guild = WowGuild.create(
guild_id: guild.id,
name: guild.name,
wow_relam: wow_realm
)
WowGuildDetailWorker.perform_async(wow_guild.guild_id)
wow_guild
end
end

View File

@@ -0,0 +1,32 @@
# frozen_string_literal: true
class WowGuildDetailWorker < WowSidekiqWorker
def perform(wow_guild_id)
return unless (wow_guild = WowGuild.find_by(guild_id: wow_guild_id))
RBattlenet.authenticate(client_id: ENV['BLIZZARD_API_CLIENT_ID'], client_secret: ENV['BLIZZARD_API_CLIENT_SECRET'])
RBattlenet.set_options(locale: 'all')
# Public data
params = {
name: wow_guild.name.downcase.tr(' ', '-'),
realm: wow_guild.wow_realm.slug
}
result = RBattlenet::Wow::Guild.find(params)
return unless result.status_code == 200
wow_guild.achievement_points = result.achievement_points
wow_guild.member_count = result.member_count
wow_guild.faction = result.faction.type
# Localisation data
locales.each do |locale|
Mobility.with_locale(locale[0]) do
wow_guild.translated_faction = result.faction.name[locale[1]]
end
end
wow_guild.save
end
end

View File

@@ -0,0 +1,21 @@
class CreateWowGuilds < ActiveRecord::Migration[6.1]
def change
create_table :wow_guilds do |t|
t.string :name
t.integer :guild_id
t.integer :achievement_points
t.integer :member_count
t.string :faction
t.jsonb :translated_faction
t.belongs_to :wow_realm
t.timestamps
end
add_index :wow_guilds, :guild_id, unique: true
change_table :wow_characters do |t|
t.belongs_to :wow_guild
end
end
end

18
db/schema.rb generated
View File

@@ -10,7 +10,7 @@
#
# It's strongly recommended that you check this file into your version control system.
ActiveRecord::Schema.define(version: 2021_04_30_213202) do
ActiveRecord::Schema.define(version: 2021_05_28_125553) do
# These are extensions that must be enabled in order to support this database
enable_extension "plpgsql"
@@ -129,10 +129,12 @@ ActiveRecord::Schema.define(version: 2021_04_30_213202) do
t.datetime "updated_at", precision: 6, null: false
t.bigint "last_position_id"
t.bigint "bind_position_id"
t.bigint "wow_guild_id"
t.index ["character_id"], name: "index_wow_characters_on_character_id", unique: true
t.index ["user_id"], name: "index_wow_characters_on_user_id"
t.index ["wow_character_title_id"], name: "index_wow_characters_on_wow_character_title_id"
t.index ["wow_class_id"], name: "index_wow_characters_on_wow_class_id"
t.index ["wow_guild_id"], name: "index_wow_characters_on_wow_guild_id"
t.index ["wow_race_id"], name: "index_wow_characters_on_wow_race_id"
t.index ["wow_realm_id"], name: "index_wow_characters_on_wow_realm_id"
end
@@ -178,6 +180,20 @@ ActiveRecord::Schema.define(version: 2021_04_30_213202) do
t.index ["zone_id"], name: "index_wow_geo_zones_on_zone_id", unique: true
end
create_table "wow_guilds", force: :cascade do |t|
t.string "name"
t.integer "guild_id"
t.integer "achievement_points"
t.integer "member_count"
t.string "faction"
t.jsonb "translated_faction"
t.bigint "wow_realm_id"
t.datetime "created_at", precision: 6, null: false
t.datetime "updated_at", precision: 6, null: false
t.index ["guild_id"], name: "index_wow_guilds_on_guild_id", unique: true
t.index ["wow_realm_id"], name: "index_wow_guilds_on_wow_realm_id"
end
create_table "wow_mounts", force: :cascade do |t|
t.jsonb "name"
t.string "source_type"

View File

@@ -0,0 +1,5 @@
require 'rails_helper'
RSpec.describe WowGuild, type: :model do
pending "add some examples to (or delete) #{__FILE__}"
end