##// END OF EJS Templates
ignore db file
ignore db file

File last commit:

r67:ffd9ff6e default
r72:596eb21f default
Show More
db_manage.py
71 lines | 2.1 KiB | text/x-python | PythonLexer
Marcin Kuzminski
added db_manage script
r59 import logging
import sqlite3
Marcin Kuzminski
updated db manage script for creating interactive admin account and db
r66
Marcin Kuzminski
added db_manage script
r59 import os
import crypt
from os.path import dirname as dn
ROOT = dn(dn(dn(os.path.realpath(__file__))))
Marcin Kuzminski
updated db manage script for creating interactive admin account and db
r66 logging.basicConfig(level=logging.DEBUG)
Marcin Kuzminski
added db_manage script
r59
def get_sqlite_conn_cur():
Marcin Kuzminski
updated db manage script for creating interactive admin account and db
r66 conn = sqlite3.connect(os.path.join(ROOT, 'hg_app.db'))
Marcin Kuzminski
added db_manage script
r59 cur = conn.cursor()
return conn, cur
Marcin Kuzminski
updated db manage script for creating interactive admin account and db
r66 def check_for_db():
if os.path.isfile(os.path.join(ROOT, 'hg_app.db')):
raise Exception('database already exists')
def create_tables():
Marcin Kuzminski
added db_manage script
r59 """
Create a auth database
"""
Marcin Kuzminski
updated db manage script for creating interactive admin account and db
r66 check_for_db()
Marcin Kuzminski
added db_manage script
r59 conn, cur = get_sqlite_conn_cur()
try:
Marcin Kuzminski
updated db manage script for creating interactive admin account and db
r66 logging.info('creating table %s', 'users')
Marcin Kuzminski
added db_manage script
r59 cur.execute("""DROP TABLE IF EXISTS users """)
cur.execute("""CREATE TABLE users
(user_id INTEGER PRIMARY KEY AUTOINCREMENT,
username TEXT,
password TEXT,
active INTEGER,
admin INTEGER)""")
Marcin Kuzminski
fixed name bug in create db script
r67 logging.info('creating table %s', 'user_logs')
cur.execute("""DROP TABLE IF EXISTS user_logs """)
cur.execute("""CREATE TABLE user_logs
Marcin Kuzminski
added db_manage script
r59 (id INTEGER PRIMARY KEY AUTOINCREMENT,
user_id INTEGER,
Marcin Kuzminski
updated db manage script for creating interactive admin account and db
r66 repository TEXT,
action TEXT,
action_date DATETIME)""")
Marcin Kuzminski
added db_manage script
r59 conn.commit()
except:
conn.rollback()
raise
cur.close()
Marcin Kuzminski
updated db manage script for creating interactive admin account and db
r66
def admin_prompt():
import getpass
username = raw_input('give username:')
password = getpass.getpass('Specify admin password:')
create_user(username, password, True)
Marcin Kuzminski
added db_manage script
r59
def create_user(username, password, admin=False):
conn, cur = get_sqlite_conn_cur()
password_crypt = crypt.crypt(password, '6a')
Marcin Kuzminski
updated db manage script for creating interactive admin account and db
r66 logging.info('creating user %s', username)
Marcin Kuzminski
added db_manage script
r59 try:
cur.execute("""INSERT INTO users values (?,?,?,?,?) """,
(None, username, password_crypt, 1, admin))
conn.commit()
except:
conn.rollback()
raise
Marcin Kuzminski
updated db manage script for creating interactive admin account and db
r66
if __name__ == '__main__':
create_tables()
admin_prompt()