db_manage.py
94 lines
| 2.9 KiB
| text/x-python
|
PythonLexer
r239 | from os.path import dirname as dn, join as jn | |||
from pylons_app.lib.auth import get_crypt_password | ||||
from pylons_app.model import init_model | ||||
from pylons_app.model.db import User, Permission | ||||
from pylons_app.model.meta import Session, Base | ||||
from sqlalchemy.engine import create_engine | ||||
Marcin Kuzminski
|
r59 | import logging | ||
import os | ||||
r228 | import sys | |||
ROOT = dn(dn(dn(os.path.realpath(__file__)))) | ||||
sys.path.append(ROOT) | ||||
Marcin Kuzminski
|
r59 | |||
r229 | log = logging.getLogger('db manage') | |||
log.setLevel(logging.DEBUG) | ||||
console_handler = logging.StreamHandler() | ||||
console_handler.setFormatter(logging.Formatter("%(asctime)s.%(msecs)03d" | ||||
" %(levelname)-5.5s [%(name)s] %(message)s")) | ||||
log.addHandler(console_handler) | ||||
Marcin Kuzminski
|
r66 | |||
r226 | class DbManage(object): | |||
r229 | def __init__(self, log_sql): | |||
self.dbname = 'hg_app.db' | ||||
r234 | dburi = 'sqlite:////%s' % jn(ROOT, self.dbname) | |||
r229 | engine = create_engine(dburi, echo=log_sql) | |||
r226 | init_model(engine) | |||
self.sa = Session() | ||||
def check_for_db(self, override): | ||||
r229 | log.info('checking for exisiting db') | |||
r234 | if os.path.isfile(jn(ROOT, self.dbname)): | |||
r229 | log.info('database exisist') | |||
if not override: | ||||
r226 | raise Exception('database already exists') | |||
r229 | ||||
r226 | def create_tables(self, override=False): | |||
""" | ||||
Create a auth database | ||||
""" | ||||
self.check_for_db(override) | ||||
r229 | if override: | |||
log.info("database exisist and it's going to be destroyed") | ||||
r234 | os.remove(jn(ROOT, self.dbname)) | |||
r226 | Base.metadata.create_all(checkfirst=override) | |||
r229 | log.info('Created tables for %s', self.dbname) | |||
Marcin Kuzminski
|
r59 | |||
r226 | def admin_prompt(self): | |||
import getpass | ||||
r229 | username = raw_input('Specify admin username:') | |||
r226 | password = getpass.getpass('Specify admin password:') | |||
self.create_user(username, password, True) | ||||
def create_user(self, username, password, admin=False): | ||||
r229 | log.info('creating administrator user %s', username) | |||
r226 | ||||
r234 | new_user = User() | |||
r226 | new_user.username = username | |||
new_user.password = get_crypt_password(password) | ||||
new_user.admin = admin | ||||
new_user.active = True | ||||
try: | ||||
self.sa.add(new_user) | ||||
self.sa.commit() | ||||
except: | ||||
self.sa.rollback() | ||||
raise | ||||
Marcin Kuzminski
|
r66 | |||
r239 | def create_permissions(self): | |||
perms = [('can_view_admin_users', 'Access to admin user view'), | ||||
] | ||||
for p in perms: | ||||
new_perm = Permission() | ||||
new_perm.permission_name = p[0] | ||||
new_perm.permission_longname = p[1] | ||||
try: | ||||
self.sa.add(new_perm) | ||||
self.sa.commit() | ||||
except: | ||||
self.sa.rollback() | ||||
raise | ||||
Marcin Kuzminski
|
r66 | if __name__ == '__main__': | ||
r229 | dbmanage = DbManage(log_sql=True) | |||
r226 | dbmanage.create_tables(override=True) | |||
r239 | dbmanage.admin_prompt() | |||
dbmanage.create_permissions() | ||||
Marcin Kuzminski
|
r66 | |||