blob: 93d633a9873702c986efb263acd49aba8d83acef [file] [log] [blame]
<%--
Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements. See the NOTICE file
distributed with this work for additional information
regarding copyright ownership. The ASF licenses this file
to you under the Apache License, Version 2.0 (the
"License"); you may not use this file except in compliance
with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing,
software distributed under the License is distributed on an
"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, either express or implied. See the License for the
specific language governing permissions and limitations
under the License.
--%>
<%@ page import="java.util.*"%>
<%@ page import="java.text.*"%>
<%@ page import="javax.mail.*"%>
<%@ page import="javax.servlet.jsp.jstl.fmt.*"%>
<%@ page import="org.apache.log4j.*"%>
<%@ page import="org.apache.wiki.api.core.Context" %>
<%@ page import="org.apache.wiki.api.core.ContextEnum" %>
<%@ page import="org.apache.wiki.api.core.Engine"%>
<%@ page import="org.apache.wiki.api.core.Session"%>
<%@ page import="org.apache.wiki.api.spi.Wiki"%>
<%@ page import="org.apache.wiki.auth.*"%>
<%@ page import="org.apache.wiki.auth.user.*"%>
<%@ page import="org.apache.wiki.i18n.*"%>
<%@ page import="org.apache.wiki.preferences.Preferences" %>
<%@ page import="org.apache.wiki.ui.TemplateManager" %>
<%@ page import="org.apache.wiki.url.URLConstructor"%>
<%@ page import="org.apache.wiki.util.*"%>
<%@ page errorPage="/Error.jsp"%>
<%@ taglib uri="http://jspwiki.apache.org/tags" prefix="wiki" %>
<%!Logger log = Logger.getLogger( "JSPWiki" );
String message = null;
public boolean resetPassword( Engine wiki, HttpServletRequest request, ResourceBundle rb ) {
// Reset pw for account name
String name = request.getParameter( "name" );
UserDatabase userDatabase = wiki.getManager( UserManager.class ).getUserDatabase();
boolean success = false;
try {
UserProfile profile = null;
/*
// This is disabled because it would otherwise be possible to DOS JSPWiki instances
// by requesting new passwords for all users. See https://issues.apache.org/jira/browse/JSPWIKI-78
try {
profile = userDatabase.find(name);
} catch (NoSuchPrincipalException e) {
// Try email as well
}
*/
if( profile == null ) {
profile = userDatabase.findByEmail( name );
}
String email = profile.getEmail();
String randomPassword = TextUtil.generateRandomPassword();
// Try sending email first, as that is more likely to fail.
Object[] args = { profile.getLoginName(), randomPassword, request.getScheme() + "://"+ request.getServerName() + ":" + request.getServerPort() +
wiki.getManager( URLConstructor.class ).makeURL( ContextEnum.PAGE_NONE.getRequestContext(), "Login.jsp", "" ), wiki.getApplicationName() };
String mailMessage = MessageFormat.format( rb.getString( "lostpwd.newpassword.email" ), args );
Object[] args2 = { wiki.getApplicationName() };
MailUtil.sendMessage( wiki.getWikiProperties(),
email,
MessageFormat.format( rb.getString( "lostpwd.newpassword.subject" ), args2 ),
mailMessage );
log.info( "User " + email + " requested and received a new password." );
// Mail succeeded. Now reset the password.
// If this fails, we're kind of screwed, because we already emailed.
profile.setPassword( randomPassword );
userDatabase.save( profile );
success = true;
} catch( NoSuchPrincipalException e ) {
Object[] args = { name };
message = MessageFormat.format( rb.getString( "lostpwd.nouser" ), args );
log.info( "Tried to reset password for non-existent user '" + name + "'" );
} catch( SendFailedException e ) {
message = rb.getString( "lostpwd.nomail" );
log.error( "Tried to reset password and got SendFailedException: " + e );
} catch( AuthenticationFailedException e ) {
message = rb.getString( "lostpwd.nomail" );
log.error( "Tried to reset password and got AuthenticationFailedException: " + e );
} catch( Exception e ) {
message = rb.getString( "lostpwd.nomail" );
log.error( "Tried to reset password and got another exception: " + e );
}
return success;
}
%>
<%
Engine wiki = Wiki.engine().find( getServletConfig() );
//Create wiki context like in Login.jsp:
//don't check for access permissions: if you have lost your password you cannot login!
Context wikiContext = ( Context )pageContext.getAttribute( Context.ATTR_CONTEXT, PageContext.REQUEST_SCOPE );
// If no context, it means we're using container auth. So, create one anyway
if( wikiContext == null ) {
wikiContext = Wiki.context().create( wiki, request, ContextEnum.WIKI_LOGIN.getRequestContext() ); /* reuse login context ! */
pageContext.setAttribute( Context.ATTR_CONTEXT, wikiContext, PageContext.REQUEST_SCOPE );
}
ResourceBundle rb = Preferences.getBundle( wikiContext, "CoreResources" );
Session wikiSession = wikiContext.getWikiSession();
String action = request.getParameter( "action" );
boolean done = false;
if( action != null && action.equals( "resetPassword" ) ) {
if( resetPassword( wiki, request, rb ) ) {
done = true;
wikiSession.addMessage( "resetpwok", rb.getString( "lostpwd.emailed" ) );
pageContext.setAttribute( "passwordreset", "done" );
} else {
// Error
wikiSession.addMessage( "resetpw", message );
}
}
response.setContentType( "text/html; charset=" + wiki.getContentEncoding() );
response.setHeader( "Cache-control", "max-age=0" );
response.setDateHeader( "Expires", new Date().getTime() );
response.setDateHeader( "Last-Modified", new Date().getTime() );
String contentPage = wiki.getManager( TemplateManager.class ).findJSP( pageContext, wikiContext.getTemplate(), "ViewTemplate.jsp" );
%>
<wiki:Include page="<%=contentPage%>" />