Merge pull request #38 from jedmund/character-mods
Implements mods on GridCharacter
This commit is contained in:
commit
d91fd72431
12 changed files with 337 additions and 39 deletions
|
|
@ -14,6 +14,10 @@ module Api
|
||||||
field :errors, if: ->(_field_name, _error, options) { options.key?(:exception) } do |_, options|
|
field :errors, if: ->(_field_name, _error, options) { options.key?(:exception) } do |_, options|
|
||||||
options[:exception]
|
options[:exception]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
field :errors, if: ->(_field_name, object, options) { options.key?(:errors) } do |_, options|
|
||||||
|
options[:errors]
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
||||||
|
|
@ -11,11 +11,33 @@ module Api
|
||||||
view :nested do
|
view :nested do
|
||||||
fields :position, :uncap_level, :perpetuity
|
fields :position, :uncap_level, :perpetuity
|
||||||
|
|
||||||
|
field :transcendence_step, if: lambda { |_fn, obj, _opt|
|
||||||
|
obj.character.ulb
|
||||||
|
} do |c|
|
||||||
|
c.transcendence_step
|
||||||
|
end
|
||||||
|
|
||||||
field :awakening do |c|
|
field :awakening do |c|
|
||||||
{
|
c.awakening
|
||||||
type: c.awakening_type,
|
end
|
||||||
level: c.awakening_level
|
|
||||||
}
|
field :over_mastery, if: lambda { |_fn, obj, _opt|
|
||||||
|
!obj.ring1['modifier'].nil? && !obj.ring2['modifier'].nil?
|
||||||
|
} do |c|
|
||||||
|
rings = []
|
||||||
|
|
||||||
|
rings.push(c.ring1) unless c.ring1['modifier'].nil?
|
||||||
|
rings.push(c.ring2) unless c.ring2['modifier'].nil?
|
||||||
|
rings.push(c.ring3) unless c.ring3['modifier'].nil?
|
||||||
|
rings.push(c.ring4) unless c.ring4['modifier'].nil?
|
||||||
|
|
||||||
|
rings
|
||||||
|
end
|
||||||
|
|
||||||
|
field :aetherial_mastery, if: lambda { |_fn, obj, _opt|
|
||||||
|
!obj.earring['modifier'].nil?
|
||||||
|
} do |c|
|
||||||
|
c.earring
|
||||||
end
|
end
|
||||||
|
|
||||||
association :character, name: :object, blueprint: CharacterBlueprint
|
association :character, name: :object, blueprint: CharacterBlueprint
|
||||||
|
|
@ -25,6 +47,10 @@ module Api
|
||||||
include_view :nested
|
include_view :nested
|
||||||
association :party, blueprint: PartyBlueprint, view: :minimal
|
association :party, blueprint: PartyBlueprint, view: :minimal
|
||||||
end
|
end
|
||||||
|
|
||||||
|
view :destroyed do
|
||||||
|
fields :position, :created_at, :updated_at
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
||||||
|
|
@ -43,6 +43,10 @@ module Api
|
||||||
include_view :nested
|
include_view :nested
|
||||||
association :party, blueprint: PartyBlueprint, view: :minimal
|
association :party, blueprint: PartyBlueprint, view: :minimal
|
||||||
end
|
end
|
||||||
|
|
||||||
|
view :destroyed do
|
||||||
|
fields :mainhand, :position, :created_at, :updated_at
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
||||||
|
|
@ -6,6 +6,8 @@ module Api
|
||||||
attr_reader :party, :incoming_character, :current_characters
|
attr_reader :party, :incoming_character, :current_characters
|
||||||
|
|
||||||
before_action :find_party, only: :create
|
before_action :find_party, only: :create
|
||||||
|
before_action :set, only: %i[update destroy]
|
||||||
|
before_action :check_authorization, only: %i[update destroy]
|
||||||
before_action :find_incoming_character, only: :create
|
before_action :find_incoming_character, only: :create
|
||||||
before_action :find_current_characters, only: :create
|
before_action :find_current_characters, only: :create
|
||||||
|
|
||||||
|
|
@ -19,17 +21,16 @@ module Api
|
||||||
conflict_view = render_conflict_view(conflict_characters, incoming_character, character_params[:position])
|
conflict_view = render_conflict_view(conflict_characters, incoming_character, character_params[:position])
|
||||||
render json: conflict_view
|
render json: conflict_view
|
||||||
else
|
else
|
||||||
# Replace the grid character in the position if it is already filled
|
# Destroy the grid character in the position if it is already filled
|
||||||
if GridCharacter.where(party_id: party.id, position: character_params[:position]).exists?
|
if GridCharacter.where(party_id: party.id, position: character_params[:position]).exists?
|
||||||
character = GridCharacter.where(party_id: party.id, position: character_params[:position]).limit(1)[0]
|
character = GridCharacter.where(party_id: party.id, position: character_params[:position]).limit(1)[0]
|
||||||
character.character_id = incoming_character.id
|
character.destroy
|
||||||
|
|
||||||
# Otherwise, create a new grid character
|
|
||||||
else
|
|
||||||
character = GridCharacter.create!(character_params.merge(party_id: party.id,
|
|
||||||
character_id: incoming_character.id))
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Then, create a new grid character
|
||||||
|
character = GridCharacter.create!(character_params.merge(party_id: party.id,
|
||||||
|
character_id: incoming_character.id))
|
||||||
|
|
||||||
if character.save!
|
if character.save!
|
||||||
grid_character_view = render_grid_character_view(character)
|
grid_character_view = render_grid_character_view(character)
|
||||||
render json: grid_character_view, status: :created
|
render json: grid_character_view, status: :created
|
||||||
|
|
@ -37,6 +38,24 @@ module Api
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def update
|
||||||
|
mastery = {}
|
||||||
|
%i[ring1 ring2 ring3 ring4 earring awakening].each do |key|
|
||||||
|
value = character_params.to_h[key]
|
||||||
|
mastery[key] = value unless value.nil?
|
||||||
|
end
|
||||||
|
|
||||||
|
@character.attributes = character_params.merge(mastery)
|
||||||
|
|
||||||
|
if @character.save
|
||||||
|
ap 'Saved character'
|
||||||
|
return render json: GridCharacterBlueprint.render(@character, view: :full) if @character.save
|
||||||
|
else
|
||||||
|
ap 'Could not save'
|
||||||
|
render_validation_error_response(@character)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def resolve
|
def resolve
|
||||||
incoming = Character.find(resolve_params[:incoming])
|
incoming = Character.find(resolve_params[:incoming])
|
||||||
conflicting = resolve_params[:conflicting].map { |id| GridCharacter.find(id) }
|
conflicting = resolve_params[:conflicting].map { |id| GridCharacter.find(id) }
|
||||||
|
|
@ -76,7 +95,10 @@ module Api
|
||||||
end
|
end
|
||||||
|
|
||||||
# TODO: Implement removing characters
|
# TODO: Implement removing characters
|
||||||
def destroy; end
|
def destroy
|
||||||
|
render_unauthorized_response if @character.party.user != current_user
|
||||||
|
return render json: GridCharacterBlueprint.render(@character, view: :destroyed) if @character.destroy
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
|
|
@ -103,6 +125,10 @@ module Api
|
||||||
end.flatten
|
end.flatten
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def set
|
||||||
|
@character = GridCharacter.find(params[:id])
|
||||||
|
end
|
||||||
|
|
||||||
def find_incoming_character
|
def find_incoming_character
|
||||||
@incoming_character = Character.find(character_params[:character_id])
|
@incoming_character = Character.find(character_params[:character_id])
|
||||||
end
|
end
|
||||||
|
|
@ -112,10 +138,21 @@ module Api
|
||||||
render_unauthorized_response if current_user && (party.user != current_user)
|
render_unauthorized_response if current_user && (party.user != current_user)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def check_authorization
|
||||||
|
render_unauthorized_response if @character.party.user != current_user
|
||||||
|
end
|
||||||
|
|
||||||
# Specify whitelisted properties that can be modified.
|
# Specify whitelisted properties that can be modified.
|
||||||
def character_params
|
def character_params
|
||||||
params.require(:character).permit(:id, :party_id, :character_id, :position, :uncap_level, :conflicting,
|
params.require(:character).permit(:id, :party_id, :character_id, :position,
|
||||||
:incoming)
|
:uncap_level, :transcendence_step, :perpetuity,
|
||||||
|
ring1: %i[modifier strength], ring2: %i[modifier strength],
|
||||||
|
ring3: %i[modifier strength], ring4: %i[modifier strength],
|
||||||
|
earring: %i[modifier strength], awakening: %i[type level])
|
||||||
|
end
|
||||||
|
|
||||||
|
def resolve_params
|
||||||
|
params.require(:resolve).permit(:position, :incoming, conflicting: [])
|
||||||
end
|
end
|
||||||
|
|
||||||
def render_conflict_view(conflict_characters, incoming_character, incoming_position)
|
def render_conflict_view(conflict_characters, incoming_character, incoming_position)
|
||||||
|
|
@ -129,10 +166,6 @@ module Api
|
||||||
def render_grid_character_view(grid_character)
|
def render_grid_character_view(grid_character)
|
||||||
GridCharacterBlueprint.render(grid_character, view: :nested)
|
GridCharacterBlueprint.render(grid_character, view: :nested)
|
||||||
end
|
end
|
||||||
|
|
||||||
def resolve_params
|
|
||||||
params.require(:resolve).permit(:position, :incoming, conflicting: [])
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,7 @@
|
||||||
module Api
|
module Api
|
||||||
module V1
|
module V1
|
||||||
class GridWeaponsController < Api::V1::ApiController
|
class GridWeaponsController < Api::V1::ApiController
|
||||||
before_action :set, except: %w[create update_uncap_level destroy]
|
before_action :set, except: %w[create update_uncap_level]
|
||||||
|
|
||||||
attr_reader :party, :incoming_weapon
|
attr_reader :party, :incoming_weapon
|
||||||
|
|
||||||
|
|
@ -56,7 +56,10 @@ module Api
|
||||||
end
|
end
|
||||||
|
|
||||||
# TODO: Implement removing characters
|
# TODO: Implement removing characters
|
||||||
def destroy; end
|
def destroy
|
||||||
|
render_unauthorized_response if @weapon.party.user != current_user
|
||||||
|
return render json: GridCharacterBlueprint.render(@weapon, view: :destroyed) if @weapon.destroy
|
||||||
|
end
|
||||||
|
|
||||||
def update_uncap_level
|
def update_uncap_level
|
||||||
weapon = GridWeapon.find(weapon_params[:id])
|
weapon = GridWeapon.find(weapon_params[:id])
|
||||||
|
|
@ -115,15 +118,15 @@ module Api
|
||||||
# Render the conflict view as a string
|
# Render the conflict view as a string
|
||||||
def render_conflict_view(conflict_weapon, incoming_weapon, incoming_position)
|
def render_conflict_view(conflict_weapon, incoming_weapon, incoming_position)
|
||||||
ConflictBlueprint.render(nil, view: :weapons,
|
ConflictBlueprint.render(nil, view: :weapons,
|
||||||
conflict_weapon: conflict_weapon,
|
conflict_weapon: conflict_weapon,
|
||||||
incoming_weapon: incoming_weapon,
|
incoming_weapon: incoming_weapon,
|
||||||
incoming_position: incoming_position)
|
incoming_position: incoming_position)
|
||||||
end
|
end
|
||||||
|
|
||||||
def render_grid_weapon_view(grid_weapon, conflict_position)
|
def render_grid_weapon_view(grid_weapon, conflict_position)
|
||||||
GridWeaponBlueprint.render(grid_weapon, view: :full,
|
GridWeaponBlueprint.render(grid_weapon, view: :full,
|
||||||
root: :grid_weapon,
|
root: :grid_weapon,
|
||||||
meta: { replaced: conflict_position })
|
meta: { replaced: conflict_position })
|
||||||
end
|
end
|
||||||
|
|
||||||
def save_weapon(weapon)
|
def save_weapon(weapon)
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,64 @@
|
||||||
class GridCharacter < ApplicationRecord
|
class GridCharacter < ApplicationRecord
|
||||||
belongs_to :party
|
belongs_to :party
|
||||||
|
|
||||||
|
validate :awakening_level, on: :update
|
||||||
|
validate :transcendence, on: :update
|
||||||
|
validate :validate_over_mastery_values, on: :update
|
||||||
|
validate :validate_aetherial_mastery_value, on: :update
|
||||||
|
validate :over_mastery_attack_matches_hp, on: :update
|
||||||
|
|
||||||
|
def awakening_level
|
||||||
|
return if awakening.nil?
|
||||||
|
|
||||||
|
errors.add(:awakening, 'awakening level too low') if awakening['level'] < 1
|
||||||
|
errors.add(:awakening, 'awakening level too high') if awakening['level'] > 9
|
||||||
|
end
|
||||||
|
|
||||||
|
def transcendence
|
||||||
|
errors.add(:transcendence_step, 'character has no transcendence') if transcendence_step.positive? && !character.ulb
|
||||||
|
errors.add(:transcendence_step, 'transcendence step too high') if transcendence_step > 5 && character.ulb
|
||||||
|
errors.add(:transcendence_step, 'transcendence step too low') if transcendence_step.negative? && character.ulb
|
||||||
|
end
|
||||||
|
|
||||||
|
def over_mastery_attack
|
||||||
|
errors.add(:ring1, 'invalid value') unless ring1['modifier'].nil? || atk_values.include?(ring1['strength'])
|
||||||
|
end
|
||||||
|
|
||||||
|
def over_mastery_hp
|
||||||
|
return if ring2['modifier'].nil?
|
||||||
|
|
||||||
|
errors.add(:ring2, 'invalid value') unless hp_values.include?(ring2['strength'])
|
||||||
|
end
|
||||||
|
|
||||||
|
def over_mastery_attack_matches_hp
|
||||||
|
return if ring1[:modifier].nil? && ring2[:modifier].nil?
|
||||||
|
|
||||||
|
return if ring2[:strength] == (ring1[:strength] / 2)
|
||||||
|
|
||||||
|
errors.add(:over_mastery,
|
||||||
|
'over mastery attack and hp values do not match')
|
||||||
|
end
|
||||||
|
|
||||||
|
def validate_over_mastery_values
|
||||||
|
[ring1, ring2, ring3, ring4].each_with_index do |ring, index|
|
||||||
|
next if ring['modifier'].nil?
|
||||||
|
|
||||||
|
modifier = over_mastery_modifiers[ring['modifier']]
|
||||||
|
check_value({ "ring#{index}": { ring[modifier] => ring['strength'] } },
|
||||||
|
'over_mastery')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def validate_aetherial_mastery_value
|
||||||
|
return if earring['modifier'].nil?
|
||||||
|
|
||||||
|
return unless earring['modifier'].positive?
|
||||||
|
|
||||||
|
modifier = aetherial_mastery_modifiers[earring['modifier']].to_sym
|
||||||
|
check_value({ "earring": { modifier => earring['strength'] } },
|
||||||
|
'aetherial_mastery')
|
||||||
|
end
|
||||||
|
|
||||||
def character
|
def character
|
||||||
Character.find(character_id)
|
Character.find(character_id)
|
||||||
end
|
end
|
||||||
|
|
@ -10,4 +68,132 @@ class GridCharacter < ApplicationRecord
|
||||||
def blueprint
|
def blueprint
|
||||||
GridCharacterBlueprint
|
GridCharacterBlueprint
|
||||||
end
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def check_value(property, type)
|
||||||
|
# Input format
|
||||||
|
# { ring1: { atk: 300 } }
|
||||||
|
|
||||||
|
key = property.keys.first
|
||||||
|
modifier = property[key].keys.first
|
||||||
|
|
||||||
|
return if modifier.nil?
|
||||||
|
|
||||||
|
case type
|
||||||
|
when 'over_mastery'
|
||||||
|
errors.add(key, 'invalid value') unless over_mastery_values.include?(key['strength'])
|
||||||
|
when 'aetherial_mastery'
|
||||||
|
errors.add(key, 'value too low') if aetherial_mastery_values[modifier][:min] > self[key]['strength']
|
||||||
|
errors.add(key, 'value too high') if aetherial_mastery_values[modifier][:max] < self[key]['strength']
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def over_mastery_modifiers
|
||||||
|
{
|
||||||
|
1 => 'atk',
|
||||||
|
2 => 'hp',
|
||||||
|
3 => 'debuff_success',
|
||||||
|
4 => 'skill_cap',
|
||||||
|
5 => 'ca_dmg',
|
||||||
|
6 => 'ca_cap',
|
||||||
|
7 => 'stamina',
|
||||||
|
8 => 'enmity',
|
||||||
|
9 => 'crit',
|
||||||
|
10 => 'da',
|
||||||
|
11 => 'ta',
|
||||||
|
12 => 'def',
|
||||||
|
13 => 'heal',
|
||||||
|
14 => 'debuff_resist',
|
||||||
|
15 => 'dodge'
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def over_mastery_values
|
||||||
|
{
|
||||||
|
atk: [300, 600, 900, 1200, 1500, 1800, 2100, 2400, 2700, 3000],
|
||||||
|
hp: [150, 300, 450, 600, 750, 900, 1050, 1200, 1350, 1500],
|
||||||
|
debuff_success: [6, 7, 8, 9, 10, 11, 12, 13, 14, 15],
|
||||||
|
skill_cap: [6, 7, 8, 9, 10, 11, 12, 13, 14, 15],
|
||||||
|
ca_dmg: [10, 12, 14, 16, 18, 20, 22, 24, 27, 30],
|
||||||
|
ca_cap: [6, 7, 8, 9, 10, 11, 12, 13, 14, 15],
|
||||||
|
crit: [10, 12, 14, 16, 18, 20, 22, 24, 27, 30],
|
||||||
|
enmity: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10],
|
||||||
|
stamina: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10],
|
||||||
|
def: [6, 7, 8, 9, 10, 12, 14, 16, 18, 20],
|
||||||
|
heal: [3, 6, 9, 12, 15, 18, 21, 24, 27, 30],
|
||||||
|
debuff_resist: [6, 7, 8, 9, 10, 11, 12, 13, 14, 15],
|
||||||
|
dodge: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10],
|
||||||
|
da: [6, 7, 8, 9, 10, 11, 12, 13, 14, 15],
|
||||||
|
ta: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def aetherial_mastery_modifiers
|
||||||
|
{
|
||||||
|
1 => 'da',
|
||||||
|
2 => 'ta',
|
||||||
|
3 => 'ele_atk',
|
||||||
|
4 => 'ele_resist',
|
||||||
|
5 => 'stamina',
|
||||||
|
6 => 'enmity',
|
||||||
|
7 => 'supplemental',
|
||||||
|
8 => 'crit',
|
||||||
|
9 => 'counter_dodge',
|
||||||
|
10 => 'counter_dmg'
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def aetherial_mastery_values
|
||||||
|
{
|
||||||
|
da: {
|
||||||
|
min: 10,
|
||||||
|
max: 17
|
||||||
|
},
|
||||||
|
ta: {
|
||||||
|
min: 5,
|
||||||
|
max: 12
|
||||||
|
},
|
||||||
|
ele_atk: {
|
||||||
|
min: 15,
|
||||||
|
max: 22
|
||||||
|
},
|
||||||
|
ele_resist: {
|
||||||
|
min: 5,
|
||||||
|
max: 12
|
||||||
|
},
|
||||||
|
stamina: {
|
||||||
|
min: 5,
|
||||||
|
max: 12
|
||||||
|
},
|
||||||
|
enmity: {
|
||||||
|
min: 5,
|
||||||
|
max: 12
|
||||||
|
},
|
||||||
|
supplemental: {
|
||||||
|
min: 5,
|
||||||
|
max: 12
|
||||||
|
},
|
||||||
|
crit: {
|
||||||
|
min: 18,
|
||||||
|
max: 35
|
||||||
|
},
|
||||||
|
counter_dodge: {
|
||||||
|
min: 5,
|
||||||
|
max: 12
|
||||||
|
},
|
||||||
|
counter_dmg: {
|
||||||
|
min: 10,
|
||||||
|
max: 17
|
||||||
|
}
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def atk_values
|
||||||
|
[300, 600, 900, 1200, 1500, 1800, 2100, 2400, 2700, 3000]
|
||||||
|
end
|
||||||
|
|
||||||
|
def hp_values
|
||||||
|
[150, 300, 450, 600, 750, 900, 1050, 1200, 1350, 1500]
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
||||||
|
|
@ -8,7 +8,8 @@ Rails.application.routes.draw do
|
||||||
namespace :v1 do
|
namespace :v1 do
|
||||||
resources :parties, only: %i[index create update destroy]
|
resources :parties, only: %i[index create update destroy]
|
||||||
resources :users, only: %i[create update show]
|
resources :users, only: %i[create update show]
|
||||||
resources :grid_weapons, only: [:update]
|
resources :grid_weapons, only: %i[update destroy]
|
||||||
|
resources :grid_characters, only: %i[update destroy]
|
||||||
resources :favorites, only: [:create]
|
resources :favorites, only: [:create]
|
||||||
|
|
||||||
get 'users/info/:id', to: 'users#info'
|
get 'users/info/:id', to: 'users#info'
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,5 @@
|
||||||
|
class ChangeAwakeningTypeDefaultValue < ActiveRecord::Migration[7.0]
|
||||||
|
def change
|
||||||
|
change_column :grid_characters, :awakening_type, :integer, null: false, default: 1
|
||||||
|
end
|
||||||
|
end
|
||||||
22
db/migrate/20230107121520_change_mastery_columns_to_jsonb.rb
Normal file
22
db/migrate/20230107121520_change_mastery_columns_to_jsonb.rb
Normal file
|
|
@ -0,0 +1,22 @@
|
||||||
|
class ChangeMasteryColumnsToJsonb < ActiveRecord::Migration[7.0]
|
||||||
|
def change
|
||||||
|
# Remove old columns
|
||||||
|
remove_column :grid_characters, :ring_modifier1, :integer
|
||||||
|
remove_column :grid_characters, :ring_modifier2, :integer
|
||||||
|
remove_column :grid_characters, :ring_modifier3, :integer
|
||||||
|
remove_column :grid_characters, :ring_modifier4, :integer
|
||||||
|
remove_column :grid_characters, :ring_strength1, :integer
|
||||||
|
remove_column :grid_characters, :ring_strength2, :integer
|
||||||
|
remove_column :grid_characters, :ring_strength3, :integer
|
||||||
|
remove_column :grid_characters, :ring_strength4, :integer
|
||||||
|
remove_column :grid_characters, :earring_modifier, :integer
|
||||||
|
remove_column :grid_characters, :earring_strength, :integer
|
||||||
|
|
||||||
|
# Add new columns
|
||||||
|
add_column :grid_characters, :ring1, :jsonb, default: { modifier: nil, strength: nil }
|
||||||
|
add_column :grid_characters, :ring2, :jsonb, default: { modifier: nil, strength: nil }
|
||||||
|
add_column :grid_characters, :ring3, :jsonb, default: { modifier: nil, strength: nil }
|
||||||
|
add_column :grid_characters, :ring4, :jsonb, default: { modifier: nil, strength: nil }
|
||||||
|
add_column :grid_characters, :earring, :jsonb, default: { modifier: nil, strength: nil }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
@ -0,0 +1,10 @@
|
||||||
|
class ChangeAwakeningColumnsToJsonb < ActiveRecord::Migration[7.0]
|
||||||
|
def change
|
||||||
|
# Remove old columns
|
||||||
|
remove_column :grid_characters, :awakening_type, :integer
|
||||||
|
remove_column :grid_characters, :awakening_level, :integer
|
||||||
|
|
||||||
|
# Add new column
|
||||||
|
add_column :grid_characters, :awakening, :jsonb, default: { type: 1, level: 1 }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
@ -0,0 +1,10 @@
|
||||||
|
class MakeMasteryColumnsNotNullable < ActiveRecord::Migration[7.0]
|
||||||
|
def change
|
||||||
|
change_column :grid_characters, :ring1, :jsonb, null: false
|
||||||
|
change_column :grid_characters, :ring2, :jsonb, null: false
|
||||||
|
change_column :grid_characters, :ring3, :jsonb, null: false
|
||||||
|
change_column :grid_characters, :ring4, :jsonb, null: false
|
||||||
|
change_column :grid_characters, :earring, :jsonb, null: false
|
||||||
|
change_column :grid_characters, :awakening, :jsonb, null: false
|
||||||
|
end
|
||||||
|
end
|
||||||
20
db/schema.rb
20
db/schema.rb
|
|
@ -10,7 +10,7 @@
|
||||||
#
|
#
|
||||||
# It's strongly recommended that you check this file into your version control system.
|
# It's strongly recommended that you check this file into your version control system.
|
||||||
|
|
||||||
ActiveRecord::Schema[7.0].define(version: 2023_01_03_180458) do
|
ActiveRecord::Schema[7.0].define(version: 2023_01_07_153724) do
|
||||||
# These are extensions that must be enabled in order to support this database
|
# These are extensions that must be enabled in order to support this database
|
||||||
enable_extension "btree_gin"
|
enable_extension "btree_gin"
|
||||||
enable_extension "pg_trgm"
|
enable_extension "pg_trgm"
|
||||||
|
|
@ -67,19 +67,13 @@ ActiveRecord::Schema[7.0].define(version: 2023_01_03_180458) do
|
||||||
t.datetime "created_at", null: false
|
t.datetime "created_at", null: false
|
||||||
t.datetime "updated_at", null: false
|
t.datetime "updated_at", null: false
|
||||||
t.boolean "perpetuity", default: false, null: false
|
t.boolean "perpetuity", default: false, null: false
|
||||||
t.integer "awakening_type", default: 0, null: false
|
|
||||||
t.integer "awakening_level", default: 1, null: false
|
|
||||||
t.integer "transcendence_step", default: 0, null: false
|
t.integer "transcendence_step", default: 0, null: false
|
||||||
t.integer "ring_modifier1"
|
t.jsonb "ring1", default: {"modifier"=>nil, "strength"=>nil}, null: false
|
||||||
t.float "ring_strength1"
|
t.jsonb "ring2", default: {"modifier"=>nil, "strength"=>nil}, null: false
|
||||||
t.integer "ring_modifier2"
|
t.jsonb "ring3", default: {"modifier"=>nil, "strength"=>nil}, null: false
|
||||||
t.float "ring_strength2"
|
t.jsonb "ring4", default: {"modifier"=>nil, "strength"=>nil}, null: false
|
||||||
t.integer "ring_modifier3"
|
t.jsonb "earring", default: {"modifier"=>nil, "strength"=>nil}, null: false
|
||||||
t.float "ring_strength3"
|
t.jsonb "awakening", default: {"type"=>1, "level"=>1}, null: false
|
||||||
t.integer "ring_modifier4"
|
|
||||||
t.float "ring_strength4"
|
|
||||||
t.integer "earring_modifier"
|
|
||||||
t.float "earring_strength"
|
|
||||||
t.index ["character_id"], name: "index_grid_characters_on_character_id"
|
t.index ["character_id"], name: "index_grid_characters_on_character_id"
|
||||||
t.index ["party_id"], name: "index_grid_characters_on_party_id"
|
t.index ["party_id"], name: "index_grid_characters_on_party_id"
|
||||||
end
|
end
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue