net.sourceforge.msscodefactory.cfasterisk.v2_4.CFAsteriskSMWar.CFAsteriskSMWarCancelResetPasswordHtml.java Source code

Java tutorial

Introduction

Here is the source code for net.sourceforge.msscodefactory.cfasterisk.v2_4.CFAsteriskSMWar.CFAsteriskSMWarCancelResetPasswordHtml.java

Source

// Description: Java 8 Security Manager Cancel Reset Password Servlet

/*
 *   Code Factory Asterisk 11 Configuration Model
 *
 *   Copyright (c) 2014-2015 Mark Sobkow
 *   
 *   This program is available as free software under the GNU GPL v3, or
 *   under a commercial license from Mark Sobkow.  For commercial licensing
 *   details, please contact msobkow@sasktel.net.
 *   
 *   Under the terms of the GPL:
 *   
 *      This program is free software: you can redistribute it and/or modify
 *      it under the terms of the GNU 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 General Public License for more details.
 *     
 *      You should have received a copy of the GNU General Public License
 *      along with this program.  If not, see <http://www.gnu.org/licenses/>.
 *   
 */

package net.sourceforge.msscodefactory.cfasterisk.v2_4.CFAsteriskSMWar;

import java.io.IOException;
import java.io.PrintWriter;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Calendar;
import java.util.Date;
import java.util.Iterator;
import java.util.Properties;
import java.util.UUID;

import javax.mail.*;
import javax.mail.internet.*;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.*;

import org.apache.commons.codec.binary.Base64;

import net.sourceforge.msscodefactory.cflib.v2_3.CFLib.CFLib;
import net.sourceforge.msscodefactory.cfsecurity.v2_4.CFSecurity.*;
import net.sourceforge.msscodefactory.cfinternet.v2_4.CFInternet.*;
import net.sourceforge.msscodefactory.cfasterisk.v2_4.CFAsterisk.*;
import net.sourceforge.msscodefactory.cfsecurity.v2_4.CFSecurityObj.*;
import net.sourceforge.msscodefactory.cfinternet.v2_4.CFInternetObj.*;
import net.sourceforge.msscodefactory.cfasterisk.v2_4.CFAsteriskObj.*;

/**
 * Servlet implementation class CFAsteriskSMWarCancelResetPasswordHtml
 */
@WebServlet("/CFAsteriskSMWarCancelResetPasswordHtml")
public class CFAsteriskSMWarCancelResetPasswordHtml extends HttpServlet {
    private static final long serialVersionUID = 1L;

    /**
     * @see HttpServlet#HttpServlet()
     */
    public CFAsteriskSMWarCancelResetPasswordHtml() {
        super();
    }

    /**
     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        final String S_ProcName = "doGet";
        ICFAsteriskSchemaObj schemaObj;
        HttpSession sess = request.getSession(false);
        if (sess == null) {
            sess = request.getSession(true);
            schemaObj = new CFAsteriskSchemaPooledObj();
            sess.setAttribute("SchemaObj", schemaObj);
        } else {
            schemaObj = (ICFAsteriskSchemaObj) sess.getAttribute("SchemaObj");
            if (schemaObj == null) {
                schemaObj = new CFAsteriskSchemaPooledObj();
                sess.setAttribute("SchemaObj", schemaObj);
            }
        }

        ICFAsteriskSchema dbSchema = null;
        try {
            CFSecurityAuthorization auth = schemaObj.getAuthorization();
            if (auth != null) {
                response.sendRedirect("CFAsteriskSMWarSecurityMainHtml");
                return;
            }

            dbSchema = (ICFAsteriskSchema) CFAsteriskSchemaPool.getSchemaPool().getInstance();
            schemaObj.setBackingStore(dbSchema);
            schemaObj.beginTransaction();
            ICFSecuritySecUserObj systemUser = schemaObj.getSecUserTableObj().readSecUserByULoginIdx("system");
            String passwordHash = systemUser.getRequiredPasswordHash();
            if ((passwordHash == null) || (passwordHash.length() <= 0) || passwordHash.equals("bootstrap")) {
                response.sendRedirect("CFAsteriskSMWarSetSystemPasswordHtml");
                return;
            }

            ICFSecuritySysClusterObj sysCluster = schemaObj.getSysClusterTableObj().readSysClusterByIdIdx(1, false);
            if (sysCluster == null) {
                throw CFLib.getDefaultExceptionFactory().newNullArgumentException(getClass(), S_ProcName, 0,
                        "sysCluster");
            }

            ICFSecurityClusterObj resolvedCluster = sysCluster.getRequiredContainerCluster();
            if (resolvedCluster == null) {
                throw CFLib.getDefaultExceptionFactory().newNullArgumentException(getClass(), S_ProcName,
                        "resolvedCluster");
            }
            String clusterDomainName = resolvedCluster.getRequiredFullDomainName();
            String clusterDescription = resolvedCluster.getRequiredDescription();

            String resetUUIDStr = (String) request.getParameter("ResetUUID");
            if ((resetUUIDStr == null) || (resetUUIDStr.length() <= 0)) {
                response.setContentType("text/html");
                PrintWriter out = response.getWriter();
                out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01//EN\">");
                out.println("<HTML>");
                out.println("<BODY>");
                out.println("<form method=\"post\" formaction=\"CFAsteriskSMWarResetPasswordHtml\">");
                out.println("<H1 style=\"text-align:center\">" + clusterDescription + " Security Manager</H1>");
                out.println("<H2 style=\"text-align:center\">ERROR</H2>");
                out.println("<p>");
                out.println("<center>");
                out.println("<p>");
                out.println(
                        "The ResetUUID parameter was missing in your request.  Please use the link provided by your Password Reset email.");
                out.println("</BODY>");
                out.println("</HTML>");
                return;
            }

            UUID resetUUID = UUID.fromString(resetUUIDStr);
            if (resetUUID == null) {
                response.setContentType("text/html");
                PrintWriter out = response.getWriter();
                out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01//EN\">");
                out.println("<HTML>");
                out.println("<BODY>");
                out.println("<form method=\"post\" formaction=\"CFAsteriskSMWarResetPasswordHtml\">");
                out.println("<H1 style=\"text-align:center\">" + clusterDescription + " Security Manager</H1>");
                out.println("<H2 style=\"text-align:center\">ERROR</H2>");
                out.println("<p>");
                out.println("<center>");
                out.println("<p>");
                out.println("Invalid ResetUUID \"" + resetUUIDStr
                        + "\".  Please use the link provided by your Password Reset email.");
                out.println("</BODY>");
                out.println("</HTML>");
                return;
            }

            ICFSecuritySecUserObj resetUser = null;
            Iterator<ICFSecuritySecUserObj> secUserForUUID = schemaObj.getSecUserTableObj()
                    .readSecUserByPwdResetIdx(resetUUID).iterator();
            if (secUserForUUID.hasNext()) {
                resetUser = secUserForUUID.next();
                if (secUserForUUID.hasNext()) {
                    throw CFLib.getDefaultExceptionFactory().newRuntimeException(getClass(), S_ProcName,
                            "Multiple SecUser instances found for ResetUUID \"" + resetUUIDStr + "\"");
                }
            } else {
                response.setContentType("text/html");
                PrintWriter out = response.getWriter();
                out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01//EN\">");
                out.println("<HTML>");
                out.println("<BODY>");
                out.println("<form method=\"post\" formaction=\"CFAsteriskSMWarResetPasswordHtml\">");
                out.println("<H1 style=\"text-align:center\">" + clusterDescription + " Security Manager</H1>");
                out.println("<H2 style=\"text-align:center\">ERROR</H2>");
                out.println("<p>");
                out.println("<center>");
                out.println("<p>");
                out.println("Invalid ResetUUID \"" + resetUUIDStr
                        + "\".  Please use the link provided by your HTML Passsword Reset email.");
                out.println("</BODY>");
                out.println("</HTML>");
                return;
            }

            ICFSecurityClusterObj systemCluster = schemaObj.getClusterTableObj()
                    .readClusterByUDomainNameIdx("system");
            ICFSecurityTenantObj systemTenant = schemaObj.getTenantTableObj()
                    .readTenantByUNameIdx(systemCluster.getRequiredId(), "system");
            ICFSecuritySecSessionObj systemSession = schemaObj.getSecSessionTableObj().newInstance();
            ICFSecuritySecSessionEditObj editSystemSession = (ICFSecuritySecSessionEditObj) systemSession
                    .beginEdit();
            editSystemSession.setRequiredContainerSecUser(systemUser);
            editSystemSession.setRequiredStart(Calendar.getInstance());
            systemSession = editSystemSession.create();
            editSystemSession.endEdit();

            auth = new CFSecurityAuthorization();
            auth.setSecCluster(systemCluster);
            auth.setSecTenant(systemTenant);
            auth.setSecSession(systemSession);
            schemaObj.setAuthorization(auth);

            ICFSecuritySecUserEditObj editResetUser = resetUser.beginEdit();
            editResetUser.setOptionalPasswordResetUuid(null);
            editResetUser.update();
            editResetUser.endEdit();

            editSystemSession = (ICFSecuritySecSessionEditObj) systemSession.beginEdit();
            editSystemSession.setOptionalFinish(Calendar.getInstance());
            editSystemSession.update();
            editSystemSession.endEdit();

            schemaObj.commit();

            schemaObj.setAuthorization(null);

            response.setContentType("text/html");
            PrintWriter out = response.getWriter();
            out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01//EN\">");
            out.println("<HTML>");
            out.println("<BODY>");
            out.println("<form method=\"post\" formaction=\"CFAsteriskSMWarResetPasswordHtml\">");
            out.println("<H1 style=\"text-align:center\">" + clusterDescription + " Security Manager</H1>");
            out.println("<H2 style=\"text-align:center\">Password Reset request cancelled for "
                    + resetUser.getRequiredEMailAddress() + "</H2>");
            out.println("<p>");
            out.println("<center>");
            out.println("<table style=\"width:75%\">");
            out.println(
                    "<tr><td colSpan=\"2\" style=\"text-align:center\"><A HRef=\"CFAsteriskSMWarLoginHtml\">Take me to the "
                            + clusterDescription + " Security Manager Login</A></td></tr>");
            out.println("</table>");
            out.println("</center>");
            out.println("</form>");
            out.println("</BODY>");
            out.println("</HTML>");
        } catch (RuntimeException e) {
            throw CFLib.getDefaultExceptionFactory().newRuntimeException(getClass(), S_ProcName,
                    "Caught RuntimeException -- " + e.getMessage(), e);
        } finally {
            if (dbSchema != null) {
                try {
                    if (schemaObj.isTransactionOpen()) {
                        schemaObj.rollback();
                    }
                } catch (RuntimeException e) {
                }
                schemaObj.setBackingStore(null);
                CFAsteriskSchemaPool.getSchemaPool().releaseInstance(dbSchema);
            }
        }
    }

    /**
     * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        final String S_ProcName = "doPost";

        ICFAsteriskSchemaObj schemaObj;
        HttpSession sess = request.getSession(false);
        if (sess == null) {
            sess = request.getSession(true);
            schemaObj = new CFAsteriskSchemaPooledObj();
            sess.setAttribute("SchemaObj", schemaObj);
        } else {
            schemaObj = (ICFAsteriskSchemaObj) sess.getAttribute("SchemaObj");
            if (schemaObj == null) {
                throw CFLib.getDefaultExceptionFactory().newNullArgumentException(getClass(), S_ProcName, 0,
                        "schemaObj");
            }
        }

        ICFAsteriskSchema dbSchema = null;
        try {
            CFSecurityAuthorization auth = schemaObj.getAuthorization();
            if (auth != null) {
                response.sendRedirect("CFAsteriskSMWarSecurityMainHtml");
                return;
            }

            dbSchema = (ICFAsteriskSchema) CFAsteriskSchemaPool.getSchemaPool().getInstance();
            schemaObj.setBackingStore(dbSchema);
            schemaObj.beginTransaction();
            ICFSecuritySecUserObj systemUser = schemaObj.getSecUserTableObj().readSecUserByULoginIdx("system");
            String passwordHash = systemUser.getRequiredPasswordHash();
            if ((passwordHash == null) || (passwordHash.length() <= 0) || passwordHash.equals("bootstrap")) {
                response.sendRedirect("CFAsteriskSMWarSetSystemPasswordHtml");
                return;
            }

            ICFSecuritySysClusterObj sysCluster = schemaObj.getSysClusterTableObj().readSysClusterByIdIdx(1, false);
            if (sysCluster == null) {
                throw CFLib.getDefaultExceptionFactory().newNullArgumentException(getClass(), S_ProcName, 0,
                        "sysCluster");
            }

            ICFSecurityClusterObj resolvedCluster = sysCluster.getRequiredContainerCluster();
            if (resolvedCluster == null) {
                throw CFLib.getDefaultExceptionFactory().newNullArgumentException(getClass(), S_ProcName,
                        "resolvedCluster");
            }
            String clusterDomainName = resolvedCluster.getRequiredFullDomainName();
            String clusterDescription = resolvedCluster.getRequiredDescription();

            String resetUUIDStr = (String) request.getParameter("ResetUUID");
            if ((resetUUIDStr == null) || (resetUUIDStr.length() <= 0)) {
                response.setContentType("text/html");
                PrintWriter out = response.getWriter();
                out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01//EN\">");
                out.println("<HTML>");
                out.println("<BODY>");
                out.println("<form method=\"post\" formaction=\"CFAsteriskSMWarResetPasswordHtml\">");
                out.println("<H1 style=\"text-align:center\">" + clusterDescription + " Security Manager</H1>");
                out.println("<H2 style=\"text-align:center\">ERROR</H2>");
                out.println("<p>");
                out.println("<center>");
                out.println("<p>");
                out.println(
                        "The ResetUUID parameter was missing in your request.  Please use the link provided by your Password Reset email.");
                out.println("</BODY>");
                out.println("</HTML>");
                return;
            }

            UUID resetUUID = UUID.fromString(resetUUIDStr);
            if (resetUUID == null) {
                response.setContentType("text/html");
                PrintWriter out = response.getWriter();
                out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01//EN\">");
                out.println("<HTML>");
                out.println("<BODY>");
                out.println("<form method=\"post\" formaction=\"CFAsteriskSMWarResetPasswordHtml\">");
                out.println("<H1 style=\"text-align:center\">" + clusterDescription + " Security Manager</H1>");
                out.println("<H2 style=\"text-align:center\">ERROR</H2>");
                out.println("<p>");
                out.println("<center>");
                out.println("<p>");
                out.println("Invalid ResetUUID \"" + resetUUIDStr
                        + "\".  Please use the link provided by your Password Reset email.");
                out.println("</BODY>");
                out.println("</HTML>");
                return;
            }

            ICFSecuritySecUserObj resetUser = null;
            Iterator<ICFSecuritySecUserObj> secUserForUUID = schemaObj.getSecUserTableObj()
                    .readSecUserByPwdResetIdx(resetUUID).iterator();
            if (secUserForUUID.hasNext()) {
                resetUser = secUserForUUID.next();
                if (secUserForUUID.hasNext()) {
                    throw CFLib.getDefaultExceptionFactory().newRuntimeException(getClass(), S_ProcName,
                            "Multiple SecUser instances found for ResetUUID \"" + resetUUIDStr + "\"");
                }
            } else {
                response.setContentType("text/html");
                PrintWriter out = response.getWriter();
                out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01//EN\">");
                out.println("<HTML>");
                out.println("<BODY>");
                out.println("<form method=\"post\" formaction=\"CFAsteriskSMWarResetPasswordHtml\">");
                out.println("<H1 style=\"text-align:center\">" + clusterDescription + " Security Manager</H1>");
                out.println("<H2 style=\"text-align:center\">ERROR</H2>");
                out.println("<p>");
                out.println("<center>");
                out.println("<p>");
                out.println("Invalid ResetUUID \"" + resetUUIDStr
                        + "\".  Please use the link provided by your HTML Passsword Reset email.");
                out.println("</BODY>");
                out.println("</HTML>");
                return;
            }

            String password = (String) request.getParameter("Password");
            if ((password == null) || (password.length() <= 0)) {
                response.setContentType("text/html");
                PrintWriter out = response.getWriter();
                out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01//EN\">");
                out.println("<HTML>");
                out.println("<BODY>");
                out.println("<form method=\"post\" formaction=\"CFAsteriskSMWarResetPasswordHtml\">");
                out.println("<H1 style=\"text-align:center\">" + clusterDescription + " Security Manager</H1>");
                out.println("<H2 style=\"text-align:center\">ERROR</H2>");
                out.println("<p style=\"text-align:center\">");
                out.println("New Password must be specified.");
                out.println("<p>");
                out.println("<center>");
                out.println("<table style=\"width:75%\">");
                out.println(
                        "<tr><th style=\"text-align:left\">Reset UUID:</th><td><input type=\"text\" name=\"ResetUUID\" readonly=\"true\" value=\""
                                + resetUUID.toString() + "\"/></td></tr>");
                out.println(
                        "<tr><th style=\"text-align:left\">Login Id:</th><td><input type=\"text\" name=\"LoginId\" readonly=\"true\" value=\""
                                + resetUser.getRequiredEMailAddress() + "\"/></td></tr>");
                out.println(
                        "<tr><th style=\"text-align:left\">New Password:</th><td><input type=\"password\" name=\"Password\"/></td></tr>");
                out.println(
                        "<tr><th style=\"text-align:left\">Confirm New Password:</th><td><input type=\"password\" name=\"ConfirmPassword\"/></td></tr>");
                out.println(
                        "<tr><td colspan=\"2\" style=\"text-align:center\"><button type=\"submit\" name=\"Ok\"\">Ok</button></td></tr>");
                out.println(
                        "<tr><td colSpan=\"2\" style=\"text-align:center\"><A HRef=\"CFAsteriskSMWarLoginHtml\">Take me to the "
                                + clusterDescription + " Security Manager Login</A></td></tr>");
                out.println("</table>");
                out.println("</center>");
                out.println("</form>");
                out.println("</BODY>");
                out.println("</HTML>");
                return;
            }

            String confirmPassword = (String) request.getParameter("ConfirmPassword");
            if ((confirmPassword == null) || (confirmPassword.length() <= 0)) {
                response.setContentType("text/html");
                PrintWriter out = response.getWriter();
                out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01//EN\">");
                out.println("<HTML>");
                out.println("<BODY>");
                out.println("<form method=\"post\" formaction=\"CFAsteriskSMWarResetPasswordHtml\">");
                out.println("<H1 style=\"text-align:center\">" + clusterDescription + " Security Manager</H1>");
                out.println("<H2 style=\"text-align:center\">ERROR</H2>");
                out.println("<p style=\"text-align:center\">");
                out.println("Confirm New Password must be specified.");
                out.println("<p>");
                out.println("<center>");
                out.println("<table style=\"width:75%\">");
                out.println(
                        "<tr><th style=\"text-align:left\">Reset UUID:</th><td><input type=\"text\" name=\"ResetUUID\" readonly=\"true\" value=\""
                                + resetUUID.toString() + "\"/></td></tr>");
                out.println(
                        "<tr><th style=\"text-align:left\">Login Id:</th><td><input type=\"text\" name=\"LoginId\" readonly=\"true\" value=\""
                                + resetUser.getRequiredEMailAddress() + "\"/></td></tr>");
                out.println(
                        "<tr><th style=\"text-align:left\">New Password:</th><td><input type=\"password\" name=\"Password\"/></td></tr>");
                out.println(
                        "<tr><th style=\"text-align:left\">Confirm New Password:</th><td><input type=\"password\" name=\"ConfirmPassword\"/></td></tr>");
                out.println(
                        "<tr><td colspan=\"2\" style=\"text-align:center\"><button type=\"submit\" name=\"Ok\"\">Ok</button></td></tr>");
                out.println(
                        "<tr><td colSpan=\"2\" style=\"text-align:center\"><A HRef=\"CFAsteriskSMWarLoginHtml\">Take me to the "
                                + clusterDescription + " Security Manager Login</A></td></tr>");
                out.println("</table>");
                out.println("</center>");
                out.println("</form>");
                out.println("</BODY>");
                out.println("</HTML>");
                return;
            }

            if (!confirmPassword.equals(password)) {
                response.setContentType("text/html");
                PrintWriter out = response.getWriter();
                out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01//EN\">");
                out.println("<HTML>");
                out.println("<BODY>");
                out.println("<form method=\"post\" formaction=\"CFAsteriskSMWarResetPasswordHtml\">");
                out.println("<H1 style=\"text-align:center\">" + clusterDescription + " Security Manager</H1>");
                out.println("<H2 style=\"text-align:center\">ERROR</H2>");
                out.println("<p style=\"text-align:center\">");
                out.println("New Password and Confirm New Password do not match.");
                out.println("<p>");
                out.println("<center>");
                out.println("<table style=\"width:75%\">");
                out.println(
                        "<tr><th style=\"text-align:left\">Reset UUID:</th><td><input type=\"text\" name=\"ResetUUID\" readonly=\"true\" value=\""
                                + resetUUID.toString() + "\"/></td></tr>");
                out.println(
                        "<tr><th style=\"text-align:left\">Login Id:</th><td><input type=\"text\" name=\"LoginId\" readonly=\"true\" value=\""
                                + resetUser.getRequiredEMailAddress() + "\"/></td></tr>");
                out.println(
                        "<tr><th style=\"text-align:left\">New Password:</th><td><input type=\"password\" name=\"Password\"/></td></tr>");
                out.println(
                        "<tr><th style=\"text-align:left\">Confirm New Password:</th><td><input type=\"password\" name=\"ConfirmPassword\"/></td></tr>");
                out.println(
                        "<tr><td colspan=\"2\" style=\"text-align:center\"><button type=\"submit\" name=\"Ok\"\">Ok</button></td></tr>");
                out.println(
                        "<tr><td colSpan=\"2\" style=\"text-align:center\"><A HRef=\"CFAsteriskSMWarLoginHtml\">Take me to the "
                                + clusterDescription + " Security Manager Login</A></td></tr>");
                out.println("</table>");
                out.println("</center>");
                out.println("</form>");
                out.println("</BODY>");
                out.println("</HTML>");
                return;
            }

            MessageDigest msgDigest = MessageDigest.getInstance("SHA-512");
            msgDigest.update(password.getBytes("UTF-8"));
            byte[] hash = msgDigest.digest();
            byte[] encodedHash = Base64.encodeBase64(hash);
            String hashedAndEncodedPassword = new String(encodedHash);

            ICFSecurityClusterObj systemCluster = schemaObj.getClusterTableObj()
                    .readClusterByUDomainNameIdx("system");
            ICFSecurityTenantObj systemTenant = schemaObj.getTenantTableObj()
                    .readTenantByUNameIdx(systemCluster.getRequiredId(), "system");
            ICFSecuritySecSessionObj systemSession = schemaObj.getSecSessionTableObj().newInstance();
            ICFSecuritySecSessionEditObj editSystemSession = (ICFSecuritySecSessionEditObj) systemSession
                    .beginEdit();
            editSystemSession.setRequiredContainerSecUser(systemUser);
            editSystemSession.setRequiredStart(Calendar.getInstance());
            systemSession = editSystemSession.create();
            editSystemSession.endEdit();

            auth = new CFSecurityAuthorization();
            auth.setSecCluster(systemCluster);
            auth.setSecTenant(systemTenant);
            auth.setSecSession(systemSession);
            schemaObj.setAuthorization(auth);

            ICFSecuritySecUserEditObj editResetUser = resetUser.beginEdit();
            editResetUser.setRequiredPasswordHash(hashedAndEncodedPassword);
            editResetUser.setOptionalPasswordResetUuid(null);
            editResetUser.update();
            editResetUser.endEdit();

            editSystemSession = (ICFSecuritySecSessionEditObj) systemSession.beginEdit();
            editSystemSession.setOptionalFinish(Calendar.getInstance());
            editSystemSession.update();
            editSystemSession.endEdit();

            schemaObj.commit();

            schemaObj.setAuthorization(null);

            response.setContentType("text/html");
            PrintWriter out = response.getWriter();
            out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01//EN\">");
            out.println("<HTML>");
            out.println("<BODY>");
            out.println("<form method=\"post\" formaction=\"CFAsteriskSMWarConfirmEMailAddressHtml\">");
            out.println("<H1 style=\"text-align:center\">" + clusterDescription + " Security Manager</H1>");
            out.println("<H2 style=\"text-align:center\">Password Set.</H2>");
            out.println("<p>");
            out.println("<center>");
            out.println("<table style=\"width:75%\">");
            out.println(
                    "<tr><td colSpan=\"2\" style=\"text-align:center\">You may now <A HRef=\"CFAsteriskSMWarLoginHtml\">log in</A> to the "
                            + clusterDescription + " Security Manager</td></tr>");
            out.println("</table>");
            out.println("</center>");
            out.println("</form>");
            out.println("</BODY>");
            out.println("</HTML>");
        } catch (NoSuchAlgorithmException e) {
            throw CFLib.getDefaultExceptionFactory().newRuntimeException(getClass(), S_ProcName,
                    "Caught NoSuchAlgorithmException -- " + e.getMessage(), e);
        } catch (RuntimeException e) {
            throw CFLib.getDefaultExceptionFactory().newRuntimeException(getClass(), S_ProcName,
                    "Caught RuntimeException -- " + e.getMessage(), e);
        } finally {
            if (dbSchema != null) {
                try {
                    if (schemaObj.isTransactionOpen()) {
                        schemaObj.rollback();
                    }
                } catch (RuntimeException e) {
                }
                schemaObj.setBackingStore(null);
                CFAsteriskSchemaPool.getSchemaPool().releaseInstance(dbSchema);
            }
        }
    }
}