You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
35 lines
876 B
35 lines
876 B
6 years ago
|
import json
|
||
|
|
||
|
try:
|
||
|
import mysql.connector as mysql_connector
|
||
|
except ImportError:
|
||
|
mysql_connector = None
|
||
|
|
||
|
from peewee import ImproperlyConfigured
|
||
|
from peewee import MySQLDatabase
|
||
|
from peewee import TextField
|
||
|
|
||
|
|
||
|
class MySQLConnectorDatabase(MySQLDatabase):
|
||
|
def _connect(self):
|
||
|
if mysql_connector is None:
|
||
|
raise ImproperlyConfigured('MySQL connector not installed!')
|
||
|
return mysql_connector.connect(db=self.database, **self.connect_params)
|
||
|
|
||
|
def cursor(self, commit=None):
|
||
|
if self.is_closed():
|
||
|
self.connect()
|
||
|
return self._state.conn.cursor(buffered=True)
|
||
|
|
||
|
|
||
|
class JSONField(TextField):
|
||
|
field_type = 'JSON'
|
||
|
|
||
|
def db_value(self, value):
|
||
|
if value is not None:
|
||
|
return json.dumps(value)
|
||
|
|
||
|
def python_value(self, value):
|
||
|
if value is not None:
|
||
|
return json.loads(value)
|