import json import mysql.connector import django.db.utils import onebet.settings import mainapp.models class Legacy: def __init__(self, host=onebet.settings.MYSQL_HOST, port=onebet.settings.MYSQL_PORT, username=onebet.settings.MYSQL_USERNAME, password=onebet.settings.MYSQL_PASSWORD, database=onebet.settings.MYSQL_DATABASE): self._host = host self._port = port self._username = username self._password = password self._database = database self._connection = None self._cursor = None def _open_cursor(self): if not self._connection: self._connection = mysql.connector.connect( host=self._host, port=self._port, user=self._username, password=self._password, db=self._database ) if not self._cursor: self._cursor = self._connection.cursor() def _close_cursor(self): if self._cursor: self._cursor.close() if self._connection: self._connection.close() def _migrate_sports(self): print('[+] Starting migrate sports...') mainapp.models.Sport.objects.all().delete() self._cursor.execute("SELECT * FROM sports") for row in self._cursor.fetchall(): points = list(map(int, row[4].split(','))) sport = mainapp.models.Sport( id=row[0], name=row[1], clean_name=mainapp.models.Utils.sanitize(row[1]), display_sets=bool(row[2]), points={'win': points[0], 'tie': points[1], 'loss': points[2]}, enabled=bool(row[5]) ) sport.save() def _migrate_countries(self): print('[+] Starting migrate countries...') mainapp.models.Country.objects.all().delete() self._cursor.execute("SELECT * FROM countries") for row in self._cursor.fetchall(): country = mainapp.models.Country( id=row[0], name=row[1], clean_name=mainapp.models.Utils.sanitize(row[1]), short_name=row[2], source_names=json.loads(row[3]) ) country.save() def _migrate_leagues(self): print('[+] Starting migrate leagues...') mainapp.models.League.objects.all().delete() self._cursor.execute("SELECT * FROM leagues WHERE id < 700") for row in self._cursor.fetchall(): urls = dict() if row[17]: urls['schedule'] = row[15] if row[18]: urls['ranking'] = row[16] if row[19]: urls['tvschedule'] = row[17] tags = json.loads(row[27]) or [] league = mainapp.models.League( id=row[0], sport=mainapp.models.Sport(id=row[1]), country=mainapp.models.Country(id=row[2]), name=row[3], clean_name=mainapp.models.Utils.sanitize(row[3]), degree=row[7], gender={'M': 1, 'F': 2}[row[8]], schedule_url=row[17] or None, ranking_url=row[18] or None, channel_url=row[19] or None, mdays=row[9] or None, current_mday=row[10] or None, matches_by_mday=row[11] or None, team_count=row[12] or 0, rounds=row[13].split(',') if row[13] else None, groups=row[14].split(',') if row[14] else None, points=json.loads(row[15]) if row[15] else None, promotions=json.loads(row[16]) if row[16] else None, images=json.loads(row[26]), tags=tags, clean_tags=[mainapp.models.Utils.sanitize(tag) for tag in tags], news_count=row[28], error=None, trace=None ) league.save() def _migrate_sources(self): print('[+] Starting migrate news sources...') names = { 'lequipe': "L'équipe", 'eurosport': 'Eurosport', 'fftt': 'FFTT', 'foot-mercato': 'Foot Mercato' } mainapp.models.Source.objects.all().delete() self._cursor.execute("SELECT * FROM news_source") for row in self._cursor.fetchall(): try: source = mainapp.models.Source.objects.get(name=names[row[2]]) source.urls[row[1]] = row[3] except mainapp.models.Source.DoesNotExist: source = mainapp.models.Source( name=names[row[2]], clean_name=mainapp.models.Utils.sanitize(names[row[2]]), image_name=mainapp.models.Utils.sanitize(names[row[2]]) + '.png', big_image_name='big-' + mainapp.models.Utils.sanitize(names[row[2]]) + '.png', urls={row[1]: row[3]} ) try: source.save() except django.db.utils.IntegrityError: pass def migrate(self): self._open_cursor() self._migrate_sports() self._migrate_countries() self._migrate_leagues() self._migrate_sources() self._close_cursor()