123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- """
- Factory to create Database instances
- A Generic interface for all DB engines.
- Usage:
- import pwman.data.factory as DBFactory
- db = DBFactory.create(params)
- db.open()
- .....
- """
- import sys
- if sys.version_info.major > 2:
- from urllib.parse import urlparse
- else:
- from urlparse import urlparse
- import os
- from pwman.data.database import DatabaseException, __DB_FORMAT__
- from pwman.data.drivers import sqlite
- from pwman.data.drivers import postgresql
- def check_db_version(dburi):
- ver = str(__DB_FORMAT__)
- dburi = urlparse(dburi)
- dbtype = dburi.scheme
- filename = os.path.abspath(dburi.path)
- if dbtype == "sqlite":
- ver = sqlite.SQLite.check_db_version(filename)
- if dbtype == "postgresql":
-
- ver = postgresql.PostgresqlDatabase.check_db_version(dburi.geturl())
- return float(ver.strip("\'"))
- def createdb(dburi, version):
- dburi = urlparse(dburi)
- dbtype = dburi.scheme
- filename = dburi.path
- if dbtype == "sqlite":
- from pwman.data.drivers import sqlite
- db = sqlite.SQLite(filename, dbformat=version)
- elif dbtype == "postgresql":
- try:
- from pwman.data.drivers import postgresql
- db = postgresql.PostgresqlDatabase(dburi)
- except ImportError:
- raise DatabaseException("python-psycopg2 not installed")
- elif dbtype == "mysql":
- try:
- from pwman.data.drivers import mysql
- db = mysql.MySQLDatabase()
- except ImportError:
- raise DatabaseException("python-mysqldb not installed")
- else:
- raise DatabaseException("Unknown database type specified")
- return db
|