-
Notifications
You must be signed in to change notification settings - Fork 139
/
Copy pathATM MANAGER.py
220 lines (219 loc) · 8.79 KB
/
ATM MANAGER.py
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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
import mysql.connector
# GLOBAL VARIABLES DECLARATION
myConnnection =""
cursor=""
userName=""
password =""
cid=""
#MODULE TO CHECK MYSQL CONNECTIVITY
def MYSQLconnectionCheck ():
global myConnection
global userName
global password
userName = input("\n ENTER MYSQL SERVER'S USERNAME : ")
password = input("\n ENTER MYSQL SERVER'S PASSWORD : ")
myConnection=mysql.connector.connect(host="localhost",user=userName,passwd=password , auth_plugin='mysql_native_password' )
if myConnection:
print("\n CONGRATULATIONS ! YOUR MYSQL CONNECTION HAS BEEN ESTABLISHED !")
cursor=myConnection.cursor()
cursor.execute("CREATE DATABASE IF NOT EXISTS ATM")
cursor.execute("COMMIT")
cursor.close()
return myConnection
else:
print("\nERROR ESTABLISHING MYSQL CONNECTION CHECK USERNAME AND PASSWORD !")
#MODULE TO ESTABLISHED MYSQL CONNECTION
def MYSQLconnection ():
global userName
global password
global myConnection
myConnection=mysql.connector.connect(host="localhost",user=userName,passwd=password , database="ATM" , auth_plugin='mysql_native_password' )
if myConnection:
return myConnection
else:
print("\nERROR ESTABLISHING MYSQL CONNECTION !")
myConnection.close()
# MODULE TO CREATE NEW CUSATOMER
def newCustomer():
global cid
if myConnection:
cursor=myConnection.cursor()
createTable ="""CREATE TABLE IF NOT EXISTS CUSTOMER(CID VARCHAR(10) PRIMARY KEY ,CNAME VARCHAR(30) NOT NULL,ADDRESS VARCHAR(30)NOT NULL ,PHONE VARCHAR(12) NOT NULL)"""
cursor.execute(createTable)
print("\nPlease Fill All The Information Carefully !")
cid=input("Please Enter Customer ID : ")
cname=input("Please Enter Customer Name : ")
address=input("Please Enter Customer Address : ")
phone=input("Please Enter Customer Contact No. : ")
sql='INSERT INTO CUSTOMER(cid,cname,address,phone) values(%s,%s,%s,%s)'
values=(cid,cname,address,phone)
cursor.execute(sql,values)
cursor.execute("COMMIT")
cursor.close()
print("\nNew Customer Added Successfully !")
# MODULE TO DISPLAY CUSTOMER INFORMATION :
def displayAllCustomer():
if myConnection:
cursor=myConnection.cursor()
cursor.execute("SELECT * FROM CUSTOMER")
data = cursor.fetchall()
if data:
print("\n*****DETAILS OF ALL CUSTOMER*****")
print(data)
else:
print("Sorry ! No Record Found , Please Try Again ! ")
else:
print("\nERROR ESTABLISHING MYSQL CONNECTION !")
# MODULE TO SEARCH A CUSTOMER
def searchCustomer():
global cid
if myConnection:
cursor=myConnection.cursor()
cid=input("Please Enter Customer ID : ")
sql="SELECT * FROM CUSTOMER WHERE CID = %s"
values=(cid,)
data=cursor.execute(sql,values)
data = cursor.fetchall()
if data:
print("\n*****CUSTOMER DETAILS*****")
print(data)
else:
print("Sorry ! Customer NOT Found , Please Try Again ! ")
else:
print("\nSomthing Went Wrong ,Please Try Again !")
# MODULE TO OPEN A NEW ACCOUNT
def newAccount():
global cid
if myConnection:
cursor=myConnection.cursor()
cid=input("Please Enter Customer ID : ")
sql="SELECT * FROM CUSTOMER WHERE CID = %s"
values=(cid,)
data=cursor.execute(sql,values)
data = cursor.fetchall()
if data:
createTable ="""CREATE TABLE IF NOT EXISTS ACCOUNT(CID VARCHAR(10),ACCOUNT_NO INT PRIMARY KEY,ACCOUNT_TYPE VARCHAR(20) NOT NULL ,AMOUNT INT NOT NULL , PIN INT NOT NULL UNIQUE)"""
cursor.execute(createTable)
account_no=int(input("PLEASE ENTER THE ACCOUNT NUMBER [0-9]: "))
account_type=input("PLEASE ENTER THE ACCOUNT TYPE [ S-SAVING / C - CURRENT : ")
amount=int(input("PLEASE ENTER THE AMOUNT TO DEPOSIT : "))
ATM_pin=int(input("PLEASE ENTER THE ATM PIN [ FOUR DIGITIS ONLY ] : "))
sql='INSERT INTO ACCOUNT (cid,account_no,account_type,amount ,pin) VALUES (%s,%s,%s,%s,%s)'
values1=(cid,account_no,account_type,amount,ATM_pin)
cursor.execute(sql,values1)
cursor.execute("COMMIT")
print("\nNew Account Opend Successfully !")
else:
print("Sorry ! Customer NOT Found , Please Try Again ! ")
else:
print("\nSomthing Went Wrong ,Please Try Again !")
# MODULE TO DISPLAY ALL ACCOUNTS
def displayAllAccounts():
if myConnection:
cursor=myConnection.cursor()
cursor.execute("SELECT * FROM ACCOUNT")
data = cursor.fetchall()
if data:
print("\n*****DETAILS OF ALL CUSTOMER*****")
print(data)
else:
print("Sorry ! No Account Information , Please Try Again ! ")
else:
print("\nERROR ESTABLISHING MYSQL CONNECTION !")
# MODULE TO SEARCH AN ACCOUNT
def searchAccount():
global cid
if myConnection:
cursor=myConnection.cursor()
cid=input("PLEASE ENTER CUSTOMER ID : ")
account_no=int(input("PLEASE ENTER THE ACCOUNT NUMBER [0-9]: "))
sql="SELECT * FROM ACCOUNT WHERE CID = %s AND ACCOUNT_NO =%s"
values=(cid,account_no)
data=cursor.execute(sql,values)
data = cursor.fetchall()
if data:
print("\n*****CUSTOMER ACCOUNT DETAILS*****")
print(data)
else:
print("Sorry ! Account Infromation NOT Found , Please Try Again ! ")
else:
print("Somthing Went Wrong ,Please Try Again !")
# MODULE TO WITHDRAW AMOUNT
def withdrawAmount():
count =3
if myConnection:
cursor=myConnection.cursor()
account_no=int(input("PLEASE ENTER THE ACCOUNT NUMBER [0-9]: "))
sql="SELECT * FROM ACCOUNT WHERE ACCOUNT_NO =%s"
values=(account_no,)
data=cursor.execute(sql,values)
data = cursor.fetchall()
if data:
while True:
ATM_PIN=int(input("PLEASE ENTER THE ATM PIN - ONLY 3 ATTEMPTS ARE ALLOWED : "))
sql='SELECT * FROM ACCOUNT WHERE PIN = %s'
values=(ATM_PIN,)
cursor.execute(sql,values)
data = cursor.fetchall()
if data:
amount=int(input("PLEASE ENTER AMOUNT TO WITHDRAW : "))
sql='UPDATE ACCOUNT SET AMOUNT = AMOUNT - %s'
cursor.execute(sql ,(amount,))
cursor.execute("COMMIT")
print("******* TRANSACTION SUCCESSFULLY COMPLETED ! *******")
print("***** PLEASE TAKE MONEY AND REMOVE YOUR CARD ! *****")
break
else:
print("Wrong Pin ! Please enter a Valid PIN")
count=count-1
print("You are left with only ",count ,"Attempts")
if count == 0:
print("Your Card has been Blocked , Please Visit the Branch to activate it")
break
else:
print("Sorry ! Account Infromation NOT Found , Please Try Again ! ")
#MODULE TO PROVIDE HELP FOR USER
def helpMe():
print("Please, Contact Chiranjeev Vishnoi - 9001029458 for help !!!")
# MAIN SCREEN
print("****************** AATMANIRBHAR BHARAT - ATM MANAGER *********************")
print("*****Designed and Maintained By: CHIRANJEEV VISHNOI - CLASS XII A ********")
#STARTING POINT OF THE SYSTEM
myConnection = MYSQLconnectionCheck ()
if myConnection:
MYSQLconnection ()
while(1):
print("\n!=========================*************=======================!")
print("! PLEASE ENTER 1 FOR NEW USER !")
print("! PLEASE ENTER 2 TO DISPLAY ALL CUSTOMERS !")
print("! PLEASE ENTER 3 TO SEARCH A CUSTOMER !")
print("! PLEASE ENTER 4 TO OPEN NEW ACCOUNT !")
print("! PLEASE ENTER 5 TO DISPLAY ALL ACCOUNTS !")
print("! PLEASE ENTER 6 TO SEARCH AN ACCOUNT !")
print("! PLEASE ENTER 7 TO WITHDRAW AMOUNT !")
print("! PLEASE ENTER 8 TO EXIT !")
print("! PLEASE ENTER 0 FOR HELP !")
print("\n!============================*****END*****====================!")
choice = int(input("\n Please Enter Your Choice : "))
if choice == 1:
newCustomer()
elif choice == 2:
displayAllCustomer()
elif choice == 3:
searchCustomer()
elif choice == 4:
newAccount()
elif choice==5:
displayAllAccounts()
elif choice==6:
searchAccount()
elif choice==7:
withdrawAmount()
elif choice==8:
break
elif choice==0:
helpMe()
else:
print("Sorry ,May Be You Are Giving Me Wrong Input, Please Try Again !!! ")
else:
print("Check Your MYSQL Connection First !!! ")