IDEMPIERE-1215 Can't find resource bundle specified in report. Can't find resource bundle with country specific language / based on pull request from Daniel Tamn

This commit is contained in:
Carlos Ruiz 2013-10-02 12:06:37 -05:00
parent 0dd29367ae
commit a55f8cbcb3
1 changed files with 126 additions and 49 deletions

View File

@ -172,7 +172,7 @@ public class ReportStarter implements ProcessCall, ClientProcess
fout.close(); fout.close();
return downloadedFile; return downloadedFile;
} catch (FileNotFoundException e) { } catch (FileNotFoundException e) {
if(reportLocation.indexOf("Subreport") == -1) // Only show the warning if it is not a subreport if(reportLocation.indexOf("Subreport") == -1 && !reportLocation.endsWith(".properties")) // Only show the warning if it is not a subreport or properties
log.warning("404 not found: Report cannot be found on server "+ e.getMessage()); log.warning("404 not found: Report cannot be found on server "+ e.getMessage());
return null; return null;
} catch (IOException e) { } catch (IOException e) {
@ -424,7 +424,7 @@ public class ReportStarter implements ProcessCall, ClientProcess
String resourcePath = reportDir.getAbsolutePath(); String resourcePath = reportDir.getAbsolutePath();
if (!resourcePath.endsWith("/") && !resourcePath.endsWith("\\")); if (!resourcePath.endsWith("/") && !resourcePath.endsWith("\\"));
{ {
resourcePath = resourcePath + "/"; resourcePath = resourcePath + File.separator;
} }
params.put("SUBREPORT_DIR", resourcePath); params.put("SUBREPORT_DIR", resourcePath);
if (reportPath.startsWith("http://") || reportPath.startsWith("https://")) { if (reportPath.startsWith("http://") || reportPath.startsWith("https://")) {
@ -515,7 +515,8 @@ public class ReportStarter implements ProcessCall, ClientProcess
} }
else if (reportPath.startsWith("resource:")) else if (reportPath.startsWith("resource:"))
{ {
subreports = getResourceSubreports(name+ "Subreport", reportPath, fileExtension); String path = reportPath.substring(0, reportPath.length() +1 - (name+"."+fileExtension).length());
subreports = getResourceSubreports(name+ "Subreport", path, fileExtension);
} }
else else
{ {
@ -585,26 +586,25 @@ public class ReportStarter implements ProcessCall, ClientProcess
// Resources // Resources
File resFile = null; File resFile = null;
String bundleName = jasperReport.getResourceBundle();
if (bundleName == null) {
// If bundle name is not set, use the same name as the report file (legacy behaviour)
bundleName = jasperName;
}
if (reportPath.startsWith("attachment:") && attachment != null) { if (reportPath.startsWith("attachment:") && attachment != null) {
resFile = getAttachmentResourceFile(jasperName, currLang); resFile = getAttachmentResourceFile(bundleName, currLang);
} else if (reportPath.startsWith("resource:")) { } else if (reportPath.startsWith("resource:")) {
resFile = getResourcesForResourceFile(jasperName, currLang); resFile = getResourceResourceFile("resource:" + bundleName, currLang);
} else if (reportPath.startsWith("http://") || reportPath.startsWith("https://")) {
resFile = getHttpResourceFile(reportPath, bundleName, currLang);
} else { } else {
resFile = new File(jasperName+"_"+currLang.getLocale().getLanguage()+".properties"); resFile = getFileResourceFile(resourcePath, bundleName, currLang);
if (!resFile.exists()) {
resFile = null;
}
if (resFile == null) {
resFile = new File(jasperName+".properties");
if (!resFile.exists()) {
resFile = null;
}
}
} }
if (resFile!=null) { if (resFile!=null) {
try { try {
PropertyResourceBundle res = new PropertyResourceBundle( new FileInputStream(resFile)); PropertyResourceBundle res = new PropertyResourceBundle( new FileInputStream(resFile));
params.put("RESOURCE", res); params.put("RESOURCE", res);
params.put(JRParameter.REPORT_RESOURCE_BUNDLE, res);
} catch (IOException e) { } catch (IOException e) {
; ;
} }
@ -783,47 +783,113 @@ public class ReportStarter implements ProcessCall, ClientProcess
/** /**
* Get .property resource file from process attachment * Get .property resource file from process attachment
* @param jasperName * @param bundleName
* @param currLang * @param currLang
* @return File * @return File
*/ */
private File getAttachmentResourceFile(String jasperName, Language currLang) { private File getAttachmentResourceFile(String bundleName, Language currLang) {
File resFile = null; String resname = bundleName+"_"+currLang.getLocale().getLanguage()+"_"+currLang.getLocale().getCountry()+".properties";
MAttachmentEntry[] entries = attachment.getEntries(); File resFile = getAttachmentEntryFile(resname);
// try baseName + "_" + language if (resFile == null) {
String resname = jasperName + "_" + currLang.getLocale().getLanguage() + ".properties"; resname = bundleName+"_"+currLang.getLocale().getLanguage()+".properties";
resFile = getAttachmentEntryFile(resname);
if (resFile == null) {
resname = bundleName+".properties";
resFile = getAttachmentEntryFile(resname);
}
}
return resFile;
}
private File getAttachmentEntryFile(String resname) {
File fileattach = null;
MAttachmentEntry[] entries = attachment.getEntries();
for( int i=0; i<entries.length; i++) { for( int i=0; i<entries.length; i++) {
if (entries[i].getName().equals(resname)) { if (entries[i].getName().equals(resname)) {
resFile = getAttachmentEntryFile(entries[i]); fileattach = getAttachmentEntryFile(entries[i]);
break; break;
} }
} }
if (resFile==null) { return fileattach;
// try baseName only
resname = jasperName + ".properties";
for( int i=0; i<entries.length; i++) {
if (entries[i].getName().equals(resname)) {
resFile = getAttachmentEntryFile(entries[i]);
break;
}
}
}
return resFile;
} }
/** /**
* Get .property resource file from resources * Get .property resource file from resources
* @param jasperName * @param bundleName
* @param currLang * @param currLang
* @return File * @return File
*/ */
private File getResourcesForResourceFile(String jasperName, Language currLang) { private File getResourceResourceFile(String bundleName, Language currLang) {
File resFile = null; String resname = bundleName+"_"+currLang.getLocale().getLanguage()+"_"+currLang.getLocale().getCountry()+".properties";
File resFile = null;
try { try {
resFile = getFileAsResource(jasperName+"_"+currLang.getLocale().getLanguage()+".properties"); resFile = getFileAsResource(resname);
} catch (Exception e) { } catch (Exception e) {
// ignore exception - file couldn't exist // ignore exception - file couldn't exist
} }
if (resFile == null) {
resname = bundleName+"_"+currLang.getLocale().getLanguage()+".properties";
try {
resFile = getFileAsResource(resname);
} catch (Exception e) {
// ignore exception - file couldn't exist
}
if (resFile == null) {
resname = bundleName+".properties";
try {
resFile = getFileAsResource(resname);
} catch (Exception e) {
// ignore exception - file couldn't exist
}
}
}
return resFile;
}
/**
* Get .property resource file from http URL
* @param reportPath
* @param bundleName
* @param currLang
* @return File
*/
private File getHttpResourceFile(String reportPath, String bundleName, Language currLang)
{
String remoteDir = reportPath.substring(0, reportPath.lastIndexOf("/"));
String resname = bundleName+"_"+currLang.getLocale().getLanguage()+"_"+currLang.getLocale().getCountry()+".properties";
File resFile = httpDownloadedReport(remoteDir + "/" + resname);
if (resFile == null) {
resname = bundleName+"_"+currLang.getLocale().getLanguage()+".properties";
resFile = httpDownloadedReport(remoteDir + "/" + resname);
if (resFile == null) {
resname = bundleName+".properties";
resFile = httpDownloadedReport(remoteDir + "/" + resname);
}
}
return resFile;
}
/**
* Get .property resource file from file://
* @param resourcePath
* @param bundleName
* @param currLang
* @return File
*/
private File getFileResourceFile(String resourcePath, String bundleName, Language currLang) {
String resname = bundleName+"_"+currLang.getLocale().getLanguage()+"_"+currLang.getLocale().getCountry()+".properties";
File resFile = new File(resourcePath, resname);
if (! resFile.exists()) {
resname = bundleName+"_"+currLang.getLocale().getLanguage()+".properties";
resFile = new File(resourcePath, resname);
if (! resFile.exists()) {
resname = bundleName+".properties";
resFile = new File(resourcePath, resname);
if (! resFile.exists()) {
resFile = null;
}
}
}
return resFile; return resFile;
} }
@ -864,15 +930,13 @@ public class ReportStarter implements ProcessCall, ClientProcess
private File[] getResourceSubreports(String reportName, String reportPath, String fileExtension) private File[] getResourceSubreports(String reportName, String reportPath, String fileExtension)
{ {
ArrayList<File> subreports = new ArrayList<File>(); ArrayList<File> subreports = new ArrayList<File>();
String remoteDir = reportPath.substring(0, reportPath.lastIndexOf("/"));
// Currently check hardcoded for max. 10 subreports // Currently check hardcoded for max. 10 subreports
for(int i=1; i<10; i++) for(int i=1; i<10; i++)
{ {
// Check if subreport number i exists // Check if subreport number i exists
File subreport = null; File subreport = null;
try { try {
subreport = getFileAsResource(remoteDir + "/" + reportName + i + fileExtension); subreport = getFileAsResource(reportPath + reportName + i + fileExtension);
} catch (Exception e) { } catch (Exception e) {
// just ignore it // just ignore it
} }
@ -960,18 +1024,31 @@ public class ReportStarter implements ProcessCall, ClientProcess
if (log.isLoggable(Level.INFO)) log.info("localFile = " + localFile); if (log.isLoggable(Level.INFO)) log.info("localFile = " + localFile);
reportFile = new File(localFile); reportFile = new File(localFile);
boolean empty = true;
OutputStream out = null; OutputStream out = null;
out = new FileOutputStream(reportFile); try {
if (out != null){ out = new FileOutputStream(reportFile);
byte buf[]=new byte[1024]; if (out != null){
int len; byte buf[]=new byte[1024];
while((len=inputStream.read(buf))>0) int len;
out.write(buf,0,len); while((len=inputStream.read(buf))>0) {
out.close(); empty = false;
inputStream.close(); out.write(buf,0,len);
}
}
} catch (Exception e) {
throw e;
} finally {
if (out != null)
out.close();
if (inputStream != null)
inputStream.close();
} }
return reportFile; if (empty)
return null;
else
return reportFile;
} }
/** /**