Browse Source

Merge branch 'develop'

pull/4066/merge
Ruud 11 years ago
parent
commit
96def8563b
  1. 25
      couchpotato/core/database.py
  2. 9
      couchpotato/core/helpers/encoding.py
  3. 5
      couchpotato/core/logger.py

25
couchpotato/core/database.py

@ -2,6 +2,7 @@ import json
import os import os
import time import time
import traceback import traceback
from sqlite3 import OperationalError
from CodernityDB.database import RecordNotFound from CodernityDB.database import RecordNotFound
from CodernityDB.index import IndexException, IndexNotFoundException, IndexConflict from CodernityDB.index import IndexException, IndexNotFoundException, IndexConflict
@ -9,7 +10,7 @@ from couchpotato import CPLog
from couchpotato.api import addApiView from couchpotato.api import addApiView
from couchpotato.core.event import addEvent, fireEvent, fireEventAsync from couchpotato.core.event import addEvent, fireEvent, fireEventAsync
from couchpotato.core.helpers.encoding import toUnicode, sp from couchpotato.core.helpers.encoding import toUnicode, sp
from couchpotato.core.helpers.variable import getImdb, tryInt from couchpotato.core.helpers.variable import getImdb, tryInt, randomString
log = CPLog(__name__) log = CPLog(__name__)
@ -311,6 +312,9 @@ class Database(object):
} }
migrate_data = {} migrate_data = {}
rename_old = False
try:
c = conn.cursor() c = conn.cursor()
@ -325,6 +329,7 @@ class Database(object):
if ml == 'category': if ml == 'category':
migrate_data[ml] = {} migrate_data[ml] = {}
else: else:
rename_old = True
raise raise
for p in c.fetchall(): for p in c.fetchall():
@ -612,11 +617,21 @@ class Database(object):
log.info('Total migration took %s', time.time() - migrate_start) log.info('Total migration took %s', time.time() - migrate_start)
log.info('=' * 30) log.info('=' * 30)
rename_old = True
except OperationalError:
log.error('Migrating from faulty database, probably a (too) old version: %s', traceback.format_exc())
except:
log.error('Migration failed: %s', traceback.format_exc())
# rename old database # rename old database
log.info('Renaming old database to %s ', old_db + '.old') if rename_old:
os.rename(old_db, old_db + '.old') random = randomString()
log.info('Renaming old database to %s ', '%s.%s_old' % (old_db, random))
os.rename(old_db, '%s.%s_old' % (old_db, random))
if os.path.isfile(old_db + '-wal'): if os.path.isfile(old_db + '-wal'):
os.rename(old_db + '-wal', old_db + '-wal.old') os.rename(old_db + '-wal', '%s-wal.%s_old' % (old_db, random))
if os.path.isfile(old_db + '-shm'): if os.path.isfile(old_db + '-shm'):
os.rename(old_db + '-shm', old_db + '-shm.old') os.rename(old_db + '-shm', '%s-shm.%s_old' % (old_db, random))

9
couchpotato/core/helpers/encoding.py

@ -5,6 +5,7 @@ import re
import traceback import traceback
import unicodedata import unicodedata
from chardet import detect
from couchpotato.core.logger import CPLog from couchpotato.core.logger import CPLog
import six import six
@ -35,6 +36,9 @@ def toUnicode(original, *args):
return six.text_type(original, *args) return six.text_type(original, *args)
except: except:
try: try:
detected = detect(original)
if detected.get('encoding') == 'utf-8':
return original.decode('utf-8')
return ek(original, *args) return ek(original, *args)
except: except:
raise raise
@ -52,7 +56,10 @@ def ss(original, *args):
return u_original.encode(Env.get('encoding')) return u_original.encode(Env.get('encoding'))
except Exception as e: except Exception as e:
log.debug('Failed ss encoding char, force UTF8: %s', e) log.debug('Failed ss encoding char, force UTF8: %s', e)
return u_original.encode('UTF-8') try:
return u_original.encode(Env.get('encoding'), 'replace')
except:
return u_original.encode('utf-8', 'replace')
def sp(path, *args): def sp(path, *args):

5
couchpotato/core/logger.py

@ -59,11 +59,10 @@ class CPLog(object):
msg = ss(msg) msg = ss(msg)
try: try:
msg = msg % replace_tuple
except:
try:
if isinstance(replace_tuple, tuple): if isinstance(replace_tuple, tuple):
msg = msg % tuple([ss(x) for x in list(replace_tuple)]) msg = msg % tuple([ss(x) for x in list(replace_tuple)])
elif isinstance(replace_tuple, dict):
msg = msg % dict((k, ss(v)) for k, v in replace_tuple.iteritems())
else: else:
msg = msg % ss(replace_tuple) msg = msg % ss(replace_tuple)
except Exception as e: except Exception as e:

Loading…
Cancel
Save