about summary refs log tree commit diff
path: root/web/webqtl/management/createUserAccountPage.py
diff options
context:
space:
mode:
Diffstat (limited to 'web/webqtl/management/createUserAccountPage.py')
-rwxr-xr-xweb/webqtl/management/createUserAccountPage.py161
1 files changed, 161 insertions, 0 deletions
diff --git a/web/webqtl/management/createUserAccountPage.py b/web/webqtl/management/createUserAccountPage.py
new file mode 100755
index 00000000..f002c6ed
--- /dev/null
+++ b/web/webqtl/management/createUserAccountPage.py
@@ -0,0 +1,161 @@
+# Copyright (C) University of Tennessee Health Science Center, Memphis, TN.
+#
+# This program is free software: you can redistribute it and/or modify it
+# under the terms of the GNU Affero General Public License
+# as published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program 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 Affero General Public License for more details.
+#
+# This program is available from Source Forge: at GeneNetwork Project
+# (sourceforge.net/projects/genenetwork/).
+#
+# Contact Drs. Robert W. Williams and Xiaodong Zhou (2010)
+# at rwilliams@uthsc.edu and xzhou15@uthsc.edu
+#
+#
+#
+# This module is used by GeneNetwork project (www.genenetwork.org)
+#
+# Created by GeneNetwork Core Team 2010/08/10
+#
+# Last updated by GeneNetwork Core Team 2010/10/20
+
+import os
+import string
+
+from htmlgen import HTMLgen2 as HT
+
+from base.templatePage import templatePage
+from base import webqtlConfig
+
+
+
+#XZ, 02/06/2009: Xiaodong created this class
+class createUserAccountPage(templatePage):
+
+    def __init__(self, fd):
+
+        templatePage.__init__(self, fd)
+
+        if not self.openMysql():
+            return
+
+
+        ifVerified = fd.formdata.getvalue('ifVerified')
+
+        if ifVerified != 'GN@UTHSC':
+            heading = "Error page"
+            detail = ["You are NoT verified as administrator."]
+            self.error(heading=heading,detail=detail)
+            return
+        else:
+
+            user_name = fd.formdata.getvalue('user_name')
+            password = fd.formdata.getvalue('password')
+            retype_password = fd.formdata.getvalue('retype_password')
+
+            if user_name or password or retype_password:
+                user_name = string.strip(user_name)
+                password = string.strip(password)
+                retype_password = string.strip(retype_password)
+
+                #XZ, check if the input user name exists.
+
+                if len(user_name) == 0:
+                    heading = "Error page"
+                    detail = ["The user name can NOT be empty."]
+                    self.error(heading=heading,detail=detail)
+                    return
+
+                self.cursor.execute( 'select count(name) from User where name="%s"' % user_name )
+                result = self.cursor.fetchone()
+                if result:
+                    row_count = result[0]
+                    if row_count:
+                        heading = "Error page"
+                        detail = ["The user name %s already exists in database. Please make up another user name." % user_name]
+                        self.error(heading=heading,detail=detail)
+                        return
+                else:
+                    heading = "Error page"
+                    detail = ["No sql result returned when check user name."]
+                    self.error(heading=heading,detail=detail)
+                    return
+
+                # check password
+                if len(password) == 0 or len(retype_password) == 0:
+                    heading = "Error page"
+                    detail = ["The password can NOT be empty."]
+                    self.error(heading=heading,detail=detail)
+                    return
+ 
+                if password != retype_password:
+                    heading = "Error page"
+                    detail = ["The passwords you entered are NOT consistent. Please go back and try again."]
+                    self.error(heading=heading,detail=detail)
+                    return
+
+                #XZ, create new account
+                self.cursor.execute( "insert into User (name, password, createtime, privilege) values ('%s', SHA('%s'), Now(), 'user')" % (user_name, password) )
+
+
+            #show user table.
+            TD_LR = HT.TD(height=200,width="100%",bgColor='#eeeeee')
+
+            userHeading = HT.Paragraph('User Table', Class="title")
+
+            self.cursor.execute( 'select id, name, privilege from User order by name' )
+
+            result = self.cursor.fetchall()
+
+            userInfo = HT.Blockquote( 'There are %d users.' % len(result) )
+
+            userTable = HT.TableLite(border=0, cellpadding=0, cellspacing=0, Class="collap", width="100%")
+
+            userHeaderRow = HT.TR()
+            userHeaderRow.append(HT.TD("User Id", Class='fs14 fwb ffl b1 cw cbrb'))
+            userHeaderRow.append(HT.TD("User name", Class='fs14 fwb ffl b1 cw cbrb'))
+            userHeaderRow.append(HT.TD("User privilege", Class='fs14 fwb ffl b1 cw cbrb'))
+            userTable.append(userHeaderRow)
+
+            for one_row in result:
+                User_Id, User_name, User_privilege = one_row
+                userRow = HT.TR()
+                userRow.append(HT.TD("%s" % User_Id, Class='fs12 fwn ffl b1 c222'))
+                userRow.append(HT.TD("%s" % User_name, Class='fs12 fwn ffl b1 c222'))
+                userRow.append(HT.TD("%s" % User_privilege, Class='fs12 fwn ffl b1 c222'))
+                userTable.append(userRow)
+
+            #add user form
+            createUserAccountForm = HT.Form(cgi= os.path.join(webqtlConfig.CGIDIR, webqtlConfig.SCRIPTFILE), enctype='multipart/form-data', name='createUserAccountForm', submit=HT.Input(type='hidden'))
+
+            user_name = HT.Input(type='text' ,name='user_name',value='', size=20,maxlength=20)
+            password = HT.Input(type='password' ,name='password',value='', size=20,maxlength=20)
+            retype_password = HT.Input(type='password' ,name='retype_password',value='', size=20,maxlength=20)
+            submit_button = HT.Input(type='Submit', value='Submit', Class="button")
+
+            createUserAccountForm.append(
+                HT.Blockquote( HT.Font('Create one new account:     User Name ', color='red'), user_name, HT.Font('   Password ', color='red'), password, HT.Font('   Retype Password ', color='red'), retype_password, submit_button ),
+                HT.Input(type='hidden',name='FormID',value='createUserAccount'),
+                HT.Input(type='hidden',name='ifVerified',value='GN@UTHSC')
+            )
+
+            """
+            #manager form
+            managerForm = HT.Form(cgi= os.path.join(webqtlConfig.CGIDIR, webqtlConfig.SCRIPTFILE), enctype='multipart/form-data', name='managerForm', submit=HT.Input(type='hidden'))
+            managerForm.append(
+                HT.Input(type='Submit', value='Go to manager main page', Class="button"),
+                HT.Input(type='hidden',name='FormID',value='managerMain'),
+                HT.Input(type='hidden',name='ifVerified',value='GN@UTHSC')
+            )
+            """
+
+            #TD_LR.append(managerForm, HT.BR(), userHeading, userInfo, HT.P(), createUserAccountForm, userTable, createUserAccountForm, HT.BR(), managerForm)
+            TD_LR.append(userHeading, userInfo, HT.P(), createUserAccountForm, userTable, createUserAccountForm)
+
+            self.dict['body'] =  str(TD_LR)
+            self.dict['title'] = 'User account'