/usr/share/pyshared/DAV/dbconn.py is in python-webdav 0.9.4.1-1build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 | #Copyright (c) 1999 Christian Scholz (ruebe@aachen.heimat.de)
#
#This library is free software; you can redistribute it and/or
#modify it under the terms of the GNU Library General Public
#License as published by the Free Software Foundation; either
#version 2 of the License, or (at your option) any later version.
#
#This library is distributed in the hope that it will be useful,
#but WITHOUT ANY WARRANTY; without even the implied warranty of
#MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
#Library General Public License for more details.
#
#You should have received a copy of the GNU Library General Public
#License along with this library; if not, write to the Free
#Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
#MA 02111-1307, USA
import logging
import sys
log = logging.getLogger(__name__)
try:
import MySQLdb
except ImportError:
log.info('No SQL support - MySQLdb missing...')
pass
class Mconn:
def connect(self,username,userpasswd,host,port,db):
try:
connection = DB.connect(host=host, port=int(port), user=username, passwd=userpasswd,db=db)
except MySQLdb.OperationalError, message:
log.error("%d:\n%s" % (message[ 0 ], message[ 1 ] ))
return 0
else:
self.db = connection.cursor()
return 1
def execute(self, qry, parameters):
if self.db:
try:
# parameters are escaped by DB API correctly
res = self.db.execute(qry, parameters)
except MySQLdb.OperationalError, message:
log.error("Error %d:\n%s" % (message[ 0 ], message[ 1 ] ))
return 0
except MySQLdb.ProgrammingError, message:
log.error("Error %d:\n%s" % (message[ 0 ], message[ 1 ] ))
return 0
else:
log.debug('Query Returned '+str(res)+' results')
return self.db.fetchall()
def create_user(self,user,passwd):
qry="select * from Users where User=%s"
res=self.execute(qry, user)
if not res or len(res) ==0:
qry="insert into Users (User,Pass) values (%s,%s)"
res=self.execute(qry, (user, passwd))
else:
log.debug("Username already in use")
def create_table(self):
qry="""CREATE TABLE `Users` (
`uid` int(10) NOT NULL auto_increment,
`User` varchar(60) default NULL,
`Pass` varchar(60) default NULL,
`Write` tinyint(1) default '0',
PRIMARY KEY (`uid`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1"""
self.execute(qry, tuple())
def first_run(self,user,passwd):
res= self.execute('select * from Users')
if res or type(res)==type(()) :
pass
else:
self.create_table()
self.create_user(user,passwd)
def __init__(self,user,password,host,port,db):
self.db=0
self.connect(user,password,host,port,db)
|