factory.py 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. # ============================================================================
  2. # This file is part of Pwman3.
  3. #
  4. # Pwman3 is free software; you can redistribute it and/or modify
  5. # it under the terms of the GNU General Public License, version 2
  6. # as published by the Free Software Foundation;
  7. #
  8. # Pwman3 is distributed in the hope that it will be useful,
  9. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. # GNU General Public License for more details.
  12. #
  13. # You should have received a copy of the GNU General Public License
  14. # along with Pwman3; if not, write to the Free Software
  15. # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
  16. # ============================================================================
  17. # Copyright (C) 2012-2014 Oz Nahum Tiram <nahumoz@gmail.com>
  18. # ============================================================================
  19. # Copyright (C) 2006 Ivan Kelly <ivan@ivankelly.net>
  20. # ============================================================================
  21. """
  22. Factory to create Database instances
  23. A Generic interface for all DB engines.
  24. Usage:
  25. import pwman.data.factory as DBFactory
  26. db = DBFactory.create(params)
  27. db.open()
  28. .....
  29. """
  30. from pwman.data.database import DatabaseException
  31. from pwman.data.drivers import sqlite
  32. def check_db_version(ftype, filename):
  33. if ftype == "SQLite":
  34. ver = sqlite.SQLite.check_db_version(filename)
  35. try:
  36. return float(ver.strip("\'"))
  37. except ValueError:
  38. return 0.3
  39. # TODO: implement version checks for other supported DBs.
  40. if ftype == "Postgresql":
  41. ver = sqlite.PostgresqlDatabase.check_db_version(filename)
  42. def create(dbtype, version=None, filename=None):
  43. """
  44. create(params) -> Database
  45. Create a Database instance.
  46. 'type' can only be 'SQLite' at the moment
  47. """
  48. if dbtype == "SQLite":
  49. from pwman.data.drivers import sqlite
  50. if str(version) == '0.6':
  51. db = sqlite.SQLite(filename)
  52. else:
  53. db = sqlite.SQLite(filename, dbformat=version)
  54. elif dbtype == "Postgresql": # pragma: no cover
  55. try:
  56. from pwman.data.drivers import postgresql
  57. db = postgresql.PostgresqlDatabase()
  58. except ImportError:
  59. raise DatabaseException("python-pygresql not installed")
  60. elif dbtype == "MySQL": # pragma: no cover
  61. try:
  62. from pwman.data.drivers import mysql
  63. db = mysql.MySQLDatabase()
  64. except ImportError:
  65. raise DatabaseException("python-mysqldb not installed")
  66. else:
  67. raise DatabaseException("Unknown database type specified")
  68. return db