1
0
mirror of https://github.com/jcwimer/wrestlingApp synced 2026-03-25 01:14:43 +00:00

Use json for tournament backups and imports

This commit is contained in:
2024-12-26 18:12:44 -05:00
parent 15bf39014f
commit e986ce225b
2 changed files with 93 additions and 169 deletions

View File

@@ -1,16 +1,18 @@
class WrestlingdevImporter
def initialize( tournament, import_text )
@tournament = tournament
@import_text = import_text
@attribute_separator = ";;"
@model_separator = ",,"
##### Note, the json contains id's for each row in the tables as well as it's associations
##### this ignores those ids and uses this tournament id and then looks up associations based on name
##### and this tournament id
def initialize(tournament, import_json)
@tournament = tournament
@import_data = JSON.parse(import_json)
end
def import
if Rails.env.production?
self.delay(:job_owner_id => @tournament.id, :job_owner_type => "Importing a backup").import_raw
self.delay(job_owner_id: @tournament.id, job_owner_type: "Importing a backup").import_raw
else
import_raw
import_raw
end
end
@@ -18,168 +20,89 @@ class WrestlingdevImporter
@tournament.curently_generating_matches = 1
@tournament.save
destroy_all
parse_text
parse_data
@tournament.curently_generating_matches = nil
@tournament.save
end
def destroy_all
@tournament.mats.reload.each do | mat |
mat.destroy
end
@tournament.matches.each do | match |
match.destroy
end
@tournament.schools.each do | school |
school.wrestlers.each do | wrestler |
wrestler.destroy
end
@tournament.mats.destroy_all
@tournament.matches.destroy_all
@tournament.schools.each do |school|
school.wrestlers.destroy_all
school.destroy
end
@tournament.weights.each do | weight |
weight.destroy
end
@tournament.weights.destroy_all
end
def parse_text
@import_text.each_line do |line|
line_array = line.split(@model_separator,-1)
if line_array[0] == "--Tournament--"
line_array.shift
parse_tournament(line_array)
elsif line_array[0] == "--Schools--"
line_array.shift
parse_schools(line_array)
elsif line_array[0] == "--Weights--"
line_array.shift
parse_weights(line_array)
elsif line_array[0] == "--Mats--"
line_array.shift
parse_mats(line_array)
elsif line_array[0] == "--Wrestlers--"
line_array.shift
parse_wrestlers(line_array)
elsif line_array[0] == "--Matches--"
line_array.shift
parse_matches(line_array)
end
end
def parse_data
parse_tournament(@import_data["tournament"]["attributes"])
parse_schools(@import_data["tournament"]["schools"])
parse_weights(@import_data["tournament"]["weights"])
parse_mats(@import_data["tournament"]["mats"])
parse_wrestlers(@import_data["tournament"]["wrestlers"])
parse_matches(@import_data["tournament"]["matches"])
end
def parse_tournament(tournament_attributes)
tournament_array = tournament_attributes[0].split(@attribute_separator,-1)
@tournament.name = tournament_array[0]
@tournament.address = tournament_array[1]
@tournament.director = tournament_array[2]
@tournament.director_email = tournament_array[3]
@tournament.tournament_type = tournament_array[4]
@tournament.weigh_in_ref = tournament_array[5]
@tournament.user_id = tournament_array[6]
#@tournament.curently_generating_matches = tournament_array[7]
@tournament.date = tournament_array[8]
@tournament.save
end
def parse_wrestlers(wrestlers)
wrestlers.each do | wrestler |
puts wrestler
wrestler_array = wrestler.split(@attribute_separator,-1)
new_wrestler = Wrestler.new
new_wrestler.name = wrestler_array[0]
school_id = School.where("name = ? and tournament_id = ?",wrestler_array[1],@tournament.id).first.id
weight_id = Weight.where("max = ? and tournament_id = ?",wrestler_array[2],@tournament.id).first.id
new_wrestler.school_id = school_id
new_wrestler.weight_id = weight_id
new_wrestler.bracket_line = wrestler_array[3]
new_wrestler.original_seed = wrestler_array[4]
new_wrestler.season_win = wrestler_array[5]
new_wrestler.season_loss = wrestler_array[6]
new_wrestler.criteria = wrestler_array[7]
new_wrestler.extra = wrestler_array[8]
new_wrestler.offical_weight = wrestler_array[9]
new_wrestler.pool = wrestler_array[10]
new_wrestler.pool_placement = wrestler_array[11]
new_wrestler.pool_placement_tiebreaker = wrestler_array[12]
new_wrestler.save
end
end
def parse_matches(matches)
matches.each do | match |
puts match
@tournament.reload
@tournament.mats.reload
match_array = match.split(@attribute_separator,-1)
new_match = Match.new
weight_id = Weight.where("max = ? and tournament_id = ?",match_array[10],@tournament.id).first.id
if match_array[0].size > 0
w1_id = Wrestler.where("name = ? and weight_id = ?",match_array[0],weight_id).first.id
end
if match_array[1].size > 0
w2_id = Wrestler.where("name = ? and weight_id = ?",match_array[1],weight_id).first.id
end
if match_array[4].size > 0
winner_id = Wrestler.where("name = ? and weight_id = ?",match_array[4],weight_id).first.id
end
if match_array[15].size > 0
# mat_id = Mat.where("name = ? and tournament_id = ?",match_array[15],@tournament.id).first.id
end
new_match.w1 = w1_id if match_array[0].size > 0
new_match.w2 = w2_id if match_array[1].size > 0
new_match.winner_id = winner_id if match_array[4].size > 0
new_match.w1_stat = match_array[2]
new_match.w2_stat = match_array[3]
new_match.win_type = match_array[5]
new_match.score = match_array[6]
new_match.tournament_id = @tournament.id
new_match.round = match_array[7]
new_match. finished = match_array[8]
new_match.bout_number = match_array[9]
new_match.weight_id = weight_id
new_match.bracket_position = match_array[11]
new_match.bracket_position_number = match_array[12]
new_match.loser1_name = match_array[13]
new_match.loser2_name = match_array[14]
# new_match.mat_id = mat_id if match_array[15].size > 0
new_match.overtime_type = match_array[16]
new_match.save
end
def parse_tournament(attributes)
attributes.except!("id")
@tournament.update(attributes)
end
def parse_schools(schools)
schools.each do | school |
puts school
school_array = school.split(@attribute_separator,-1)
new_school = School.new
new_school.tournament_id = @tournament.id
new_school.name = school_array[0]
new_school.score = school_array[1]
new_school.save
schools.each do |school_attributes|
school_attributes.except!("id")
School.create(school_attributes.merge(tournament_id: @tournament.id))
end
end
def parse_weights(weights)
weights.each do | weight |
puts weight
weight_array = weight.split(@attribute_separator,-1)
new_weight = Weight.new
new_weight.tournament_id = @tournament.id
new_weight.max = weight_array[0]
new_weight.save
weights.each do |weight_attributes|
weight_attributes.except!("id")
Weight.create(weight_attributes.merge(tournament_id: @tournament.id))
end
end
def parse_mats(mats)
mats.each do | mat |
puts mat
mat_array = mat.split(@attribute_separator,-1)
new_mat = Mat.new
new_mat.tournament_id = @tournament.id
new_mat.name = mat_array[0]
new_mat.save
mats.each do |mat_attributes|
mat_attributes.except!("id")
Mat.create(mat_attributes.merge(tournament_id: @tournament.id))
end
end
end
def parse_wrestlers(wrestlers)
wrestlers.each do |wrestler_attributes|
school = School.find_by(name: wrestler_attributes["school"]["name"], tournament_id: @tournament.id)
weight = Weight.find_by(max: wrestler_attributes["weight"]["max"], tournament_id: @tournament.id)
wrestler_attributes.except!("id", "school", "weight")
Wrestler.create(wrestler_attributes.merge(
school_id: school&.id,
weight_id: weight&.id
))
end
end
def parse_matches(matches)
matches.each do |match_attributes|
next unless match_attributes # Skip if match_attributes is nil
weight = Weight.find_by(max: match_attributes.dig("weight", "max"), tournament_id: @tournament.id)
mat = Mat.find_by(name: match_attributes.dig("mat", "name"), tournament_id: @tournament.id)
w1 = Wrestler.find_by(name: match_attributes["w1_name"], weight_id: weight&.id) if match_attributes["w1_name"]
w2 = Wrestler.find_by(name: match_attributes["w2_name"], weight_id: weight&.id) if match_attributes["w2_name"]
winner = Wrestler.find_by(name: match_attributes["winner_name"], weight_id: weight&.id) if match_attributes["winner_name"]
match_attributes.except!("id", "weight", "mat", "w1_name", "w2_name", "winner_name", "tournament_id")
Match.create(match_attributes.merge(
tournament_id: @tournament.id,
weight_id: weight&.id,
mat_id: mat&.id,
w1: w1&.id,
w2: w2&.id,
winner_id: winner&.id
))
end
end
end