/**
* The contents of this file are subject to the OpenMRS Public License
* Version 1.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://license.openmrs.org
*
* Software distributed under the License is distributed on an "AS IS"
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
* License for the specific language governing rights and limitations
* under the License.
*
* Copyright (C) OpenMRS, LLC. All Rights Reserved.
*/
package org.openmrs.module.sync.web.controller;
import java.io.PrintWriter;
import java.util.List;
import java.util.Vector;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.openmrs.User;
import org.openmrs.api.context.Context;
import org.openmrs.module.ModuleUtil;
import org.openmrs.util.OpenmrsConstants;
import org.openmrs.web.WebConstants;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
/**
* Controller behind the upgrades form controller
*/
@Controller
public class UpgradeFormController {
/** Logger for this class and subclasses */
protected final Log log = LogFactory.getLog(getClass());
@SuppressWarnings("unchecked")
@RequestMapping(value = "/module/sync/upgrade", method = RequestMethod.GET)
public void showThePage(ModelMap modelMap) throws Exception {
List<String> fromOptions = new Vector<String>();
// only make 1.5.* an option if running at least 1.6.0
if (ModuleUtil.compareVersion(OpenmrsConstants.OPENMRS_VERSION_SHORT, "1.6.0") >= 0) {
fromOptions.add("1.5.*");
}
modelMap.put("fromOptions", fromOptions);
}
/**
* A user has hit the submit button and we are now printing out the sql to be used on the child db
*
* @param response the http response
* @param session the current http session
* @param fromVersion the user chosen fromVersion (provided by the showThePage method in the
* fromOptions list
* @return the page to redirect to or output is written directly to the HttpServletResponse
* printWriter
* @throws Exception
*/
@RequestMapping(value = "/module/sync/upgrade", method = RequestMethod.POST)
public String printUpgradeScript(HttpServletResponse response, HttpSession session, @RequestParam String fromVersion) throws Exception {
// used to know if we need to redirect the user to the jsp again with a message
boolean upgradePrinted = false;
// only one call to response.getWriter is allowed
PrintWriter writer = null;
if ("1.5.*".equals(fromVersion) && ModuleUtil.compareVersion(OpenmrsConstants.OPENMRS_VERSION_SHORT, "1.6.0") >= 0) {
upgradePrinted = true;
if (writer == null)
writer = response.getWriter();
printUserUuidAdditions(writer);
}
// nothing was printed, so the user will be sent back to upgrade.form
if (!upgradePrinted) {
session.setAttribute(WebConstants.OPENMRS_MSG_ATTR, "sync.upgrade.notneeded");
return "redirect:/module/sync/upgrade.form";
}
else
return null;
}
/**
*
*
* @param writer
*/
private void printUserUuidAdditions(PrintWriter writer) {
writer.println("-- Setting uuids on Users table for 1.5.* database upgrade to 1.6.0 database");
writer.println("-- This should be run on the child database BEFORE upgrading it to 1.6.0");
writer.println("-- The command to run this file is: mysql -u -p -e\"source thisfilename.sql\" openmrs (Assuming openmrs is the name of your database)");
writer.println("");
writer.println("ALTER TABLE users ADD uuid CHAR(38);");
for (User u : Context.getUserService().getAllUsers()) {
writer.println("update users set uuid = '" + u.getUuid() + "' where user_id = " + u.getUserId() + ";");
}
writer.println("ALTER TABLE users MODIFY uuid char(38) NOT NULL;");
}
}