forked from ArctosDB/arctos
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathChangePassword.cfm
254 lines (250 loc) · 9.35 KB
/
ChangePassword.cfm
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
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
<cfinclude template = "includes/_header.cfm">
<!---------------------------------------------------------------------------------->
<script>
function pwc(p,u){
var r=orapwCheck(p,u);
var elem=document.getElementById('pwstatus');
if (r=='Password is acceptable'){
var clas='goodPW';
} else {
var clas='badPW';
}
elem.innerHTML=r;
elem.className=clas;
}
</script>
<cfset title = "Change Password">
<cfif action is "nothing">
<cfif len(session.username) is 0>
<cflocation url="ChangePassword.cfm?action=lostPass" addtoken="false">
</cfif>
<cfoutput>
<cfquery name="pwExp" datasource="uam_god">
select pw_change_date from cf_users where upper(username) = '#ucase(session.username)#'
</cfquery>
<cfset pwtime = round(now() - pwExp.pw_change_date)>
<cfset pwage = Application.max_pw_age - pwtime>
<cfif session.username is "guest">
Guests are not allowed to change passwords.<cfabort>
</cfif>
You are logged in as #session.username#.
<br>Your password is #pwtime# days old.
<cfquery name="isDb" datasource="uam_god">
select
(select count(*) c from all_users where
upper(username)='#ucase(session.username)#')
+
(select count(*) C from temp_allow_cf_user,
cf_users where temp_allow_cf_user.user_id = cf_users.user_id and upper(cf_users.username)='#ucase(session.username)#')
cnt
from dual
</cfquery>
<cfif isDb.cnt gt 0>
<br>Operators must change password every #Application.max_pw_age# days.
<br>Password rules:
<ul>
<li>At least six characters</li>
<li>May not contain some special characters</li>
<li>May not contain your username</li>
<li>Must contain at least
<ul>
<li>One letter</li>
<li>One number</li>
<li>One special character</li>
</ul>
</li>
</ul>
</cfif>
<form action="ChangePassword.cfm" method="post">
<input type="hidden" name="action" value="update">
<!----
<label for="oldpassword">Old password</label>
<input name="oldpassword" id="oldpassword" type="password">
----->
<label for="newpassword">New password</label>
<input name="newpassword" id="newpassword" type="password"
<cfif isDb.cnt gt 0>
onkeyup="pwc(this.value,'#session.username#')"
</cfif> >
<span id="pwstatus"></span>
<label for="newpassword2">Retype new password</label>
<input name="newpassword2" id="newpassword2" type="password">
<br>
<input type="submit" value="Save Password Change" class="savBtn">
</form>
</cfoutput>
</cfif>
<!----------------------------------------------------------->
<cfif action is "lostPass">
Lost your password? Passwords are stored in an encrypted format and cannot be recovered.
<br>If you have saved your email address in your profile, enter it here to reset your password.
<br>If you have not saved your email address, please submit a bug report to that effect
and we will reset your password for you.
<form name="pw" method="post" action="ChangePassword.cfm">
<input type="hidden" name="action" value="findPass">
<label for="username">Username</label>
<input type="text" name="username" id="username">
<label for="email">Email Address</label>
<input type="text" name="email" id="email">
<br>
<input type="submit" value="Request Password" class="lnkBtn">
</form>
</cfif>
<!-------------------------------------------------------------------->
<cfif action is "update">
<cfoutput>
<cfquery name="getPass" datasource="cf_dbuser">
select password from cf_users where upper(username) = '#ucase(session.username)#'
</cfquery>
<!----
<cfif hash(oldpassword) is not getpass.password>
<span style="background-color:red;">
Incorrect old password. <a href="ChangePassword.cfm">Go Back</a>
</span>
<cfabort>
---->
<cfif getpass.password is hash(newpassword)>
<span style="background-color:red;">
You must pick a new password. <a href="ChangePassword.cfm">Go Back</a>
</span>
<cfabort>
<cfelseif newpassword neq newpassword2>
<span style="background-color:red;">
New passwords do not match. <a href="ChangePassword.cfm">Go Back</a>
</span>
<cfabort>
</cfif>
<!--- Passwords check out for public users, now see if they're a database user --->
<cfquery name="isDb" datasource="uam_god">
select * from all_users where
upper(username)='#ucase(session.username)#'
</cfquery>
<cfif isDb.recordcount is 0>
<cfquery name="setPass" datasource="cf_dbuser">
UPDATE cf_users SET password = '#hash(newpassword)#',
PW_CHANGE_DATE=sysdate
WHERE upper(username) = '#ucase(session.username)#'
</cfquery>
<cfelse>
<cftry>
<cftransaction>
<cfquery name="dbUser" datasource="uam_god">
alter user #session.username#
identified by "#newpassword#"
</cfquery>
<cfquery name="setPass" datasource="uam_god">
UPDATE cf_users
SET password = '#hash(newpassword)#',
PW_CHANGE_DATE=sysdate
WHERE upper(username) = '#ucase(session.username)#'
</cfquery>
</cftransaction>
<cfcatch>
<cfsavecontent variable="errortext">
<!--- do NOT just cfthrow this as we do NOT want sensitive information in email --->
<h3>Error in updating user.</h3>
<p>#cfcatch.Message#</p>
<p>#cfcatch.Detail#"</p>
<p>#session.username#"</p>
<CFIF isdefined("CGI.HTTP_X_Forwarded_For") and #len(CGI.HTTP_X_Forwarded_For)# gt 0>
<CFSET ipaddress="#CGI.HTTP_X_Forwarded_For#">
<CFELSEif isdefined("CGI.Remote_Addr") and #len(CGI.Remote_Addr)# gt 0>
<CFSET ipaddress="#CGI.Remote_Addr#">
<cfelse>
<cfset ipaddress='unknown'>
</CFIF>
<p>ipaddress: <cfoutput><a href="http://network-tools.com/default.asp?prog=network&host=#ipaddress#">#ipaddress#</a></cfoutput></p>
<hr>
<hr>
<p>URL Dump:</p>
<hr>
<cfdump var="#url#" label="url">
<p>CGI Dump:</p>
<hr>
<cfdump var="#CGI#" label="CGI">
</cfsavecontent>
<cfmail subject="Error" to="#Application.bugReportEmail#" from="SomethingBroke@#Application.fromEmail#" type="html">
#errortext#
</cfmail>
<h3>Error in changing password user.</h3>
<p>#cfcatch.Message#</p>
<p>#cfcatch.Detail#"</p>
<cfabort>
</cfcatch>
</cftry>
</cfif>
<cfset session.force_password_change = "">
<cfset initSession('#session.username#','#newpassword#')>
Your password has successfully been changed.
You will be redirected soon, or you may use the menu above now.
<script>
setTimeout("go_now()",5000);
function go_now () {
document.location='#Application.ServerRootUrl#/myArctos.cfm';
}
</script>
</cfoutput>
</cfif>
<!---------------------------------------------------------------------->
<cfif action is "findPass">
<cfoutput>
<cfquery name="isGoodEmail" datasource="cf_dbuser">
select cf_user_data.user_id, email,username from cf_user_data,cf_users
where cf_user_data.user_id = cf_users.user_id and
email = '#email#' and upper(username)='#ucase(username)#'
</cfquery>
<cfif isGoodEmail.recordcount neq 1>
Sorry, that email wasn't found with your username.
<cfabort>
<cfelse>
<cfset charList = "a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,z,y,z,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z,1,2,3,4,5,6,7,8,9,0">
<cfset numList="1,2,3,4,5,6,7,8,9,0">
<cfset specList="!,$,%,&,_,*,?,-,(,),<,>,=,/,:,;,.">
<cfset newPass = "">
<cfset cList="#charList#,#numList#,#specList#">
<cfset c=0>
<cfset i=1>
<cfset thisChar = ListGetAt(charList,RandRange(1,listlen(charList)))>
<cfset newPass=newPass & thisChar>
<cfset thisChar = ListGetAt(numList,RandRange(1,listlen(numList)))>
<cfset newPass=newPass & thisChar>
<cfset thisChar = ListGetAt(specList,RandRange(1,listlen(specList)))>
<cfset newPass=newPass & thisChar>
<cfloop from="1" to="6" index="i">
<cfset thisChar = ListGetAt(cList,RandRange(1,listlen(cList)))>
<cfset newPass=newPass & thisChar>
</cfloop>
<cftransaction>
<cfquery name="stopTrg" datasource="uam_god">
alter trigger CF_PW_CHANGE disable
</cfquery>
<cfquery name="setNewPass" datasource="uam_god">
UPDATE cf_users SET password = '#hash(newPass)#',
pw_change_date=sysdate-91
where user_id = #isGoodEmail.user_id#
</cfquery>
<cftry>
<cfquery name="db" datasource="uam_god">
alter user #isGoodEmail.username# identified by "#newPass#"
</cfquery>
<cfcatch><!--- not a DB user - whatever ---></cfcatch>
</cftry>
<cfquery name="stopTrg" datasource="uam_god">
alter trigger CF_PW_CHANGE enable
</cfquery>
</cftransaction>
<cfmail to="#email#" subject="Arctos password" from="LostFound@#Application.fromEmail#" type="text">
Your Arctos username/password is
#username# / #newPass#
You will be required to change your password
after logging in.
#Application.ServerRootUrl#/login.cfm
If you did not request this change, please reply to #Application.bugReportEmail#.
</cfmail>
An email containing your new password has been sent to the email address on file. It may take a few minutes to arrive.
<cfset initSession()>
</cfif>
</cfoutput>
</cfif>
<!---------------------------------------------------------------------->
<cfinclude template = "includes/_footer.cfm">