1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- """
- 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()
- .....
- """
- from pwman.data.database import Database, DatabaseException
- import pwman.util.config as config
- def check_db_version(type):
- if type == "SQLite":
- try:
- from pwman.data.drivers import sqlite
- except ImportError, e:
- raise DatabaseException("python-sqlite not installed")
- ver = sqlite.check_db_version()
- return ver
-
-
- def create(type, version=None):
- """
- create(params) -> Database
- Create a Database instance.
- 'type' can only be 'SQLite' at the moment
- """
- if (type == "SQLite"):
- try:
- from pwman.data.drivers import sqlite
- if version == 0.4:
- db = sqlite.SQLiteDatabaseNewForm()
- else:
- db = sqlite.SQLiteDatabase()
- except ImportError, e:
- raise DatabaseException("python-sqlite not installed")
- elif (type == "Postgresql"):
- try:
- from pwman.data.drivers import postgresql
- db = postgresql.PostgresqlDatabase()
- except ImportError, e:
- raise DatabaseException("python-pygresql not installed")
- elif (type == "MySQL"):
- try:
- from pwman.data.drivers import mysql
- db = mysql.MySQLDatabase()
- except ImportError, e:
- raise DatabaseException("python-mysqldb not installed")
- else:
- raise DatabaseException("Unknown database type specified")
- return db
|