diff --git a/components/data/data-services/org.wso2.micro.integrator.dataservices.core/pom.xml b/components/data/data-services/org.wso2.micro.integrator.dataservices.core/pom.xml index 5225fd0593..ba38c74121 100644 --- a/components/data/data-services/org.wso2.micro.integrator.dataservices.core/pom.xml +++ b/components/data/data-services/org.wso2.micro.integrator.dataservices.core/pom.xml @@ -62,6 +62,10 @@ org.apache.poi.wso2 poi-ooxml + + commons-io.wso2 + commons-io + @@ -116,6 +120,25 @@ org.wso2.orbit.org.apache.poi poi-ooxml + + + org.apache.poi + poi-ooxml + 5.3.0 + test + + + org.apache.poi + poi + 5.3.0 + test + + + org.apache.xmlbeans + xmlbeans + 5.2.2 + test + org.wso2.orbit.org.apache.commons commons-collections4 diff --git a/components/data/data-services/org.wso2.micro.integrator.dataservices.core/src/main/java/org/wso2/micro/integrator/dataservices/core/description/query/ExcelQuery.java b/components/data/data-services/org.wso2.micro.integrator.dataservices.core/src/main/java/org/wso2/micro/integrator/dataservices/core/description/query/ExcelQuery.java index 748af5d67e..59fde60c4b 100644 --- a/components/data/data-services/org.wso2.micro.integrator.dataservices.core/src/main/java/org/wso2/micro/integrator/dataservices/core/description/query/ExcelQuery.java +++ b/components/data/data-services/org.wso2.micro.integrator.dataservices.core/src/main/java/org/wso2/micro/integrator/dataservices/core/description/query/ExcelQuery.java @@ -110,19 +110,19 @@ private String[] extractRowData(Row row) { continue; } switch (cell.getCellType()) { - case HSSFCell.CELL_TYPE_STRING: + case STRING: data[i] = cell.getRichStringCellValue().getString(); break; - case HSSFCell.CELL_TYPE_BLANK: + case BLANK: data[i] = ""; break; - case HSSFCell.CELL_TYPE_BOOLEAN: + case BOOLEAN: data[i] = String.valueOf(cell.getBooleanCellValue()); break; - case HSSFCell.CELL_TYPE_FORMULA: + case FORMULA: data[i] = "{formula}"; break; - case HSSFCell.CELL_TYPE_NUMERIC: + case NUMERIC: data[i] = processNumericValue(cell.getNumericCellValue()); break; } diff --git a/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/TDriverUtil.java b/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/TDriverUtil.java index 5ee1f63a09..8114359b71 100644 --- a/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/TDriverUtil.java +++ b/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/TDriverUtil.java @@ -121,7 +121,7 @@ private static ColumnInfo[] getExcelHeaders(Connection connection, Cell header = cellItr.next(); ColumnInfo column = new ColumnInfo(header.getStringCellValue()); column.setTableName(tableName); - column.setSqlType(header.getCellType()); + column.setSqlType(header.getCellType().getCode()); column.setId(header.getColumnIndex()); columns.add(column); diff --git a/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/TExcelConnection.java b/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/TExcelConnection.java index 1f6c50fdcd..f5fc5a3bc0 100644 --- a/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/TExcelConnection.java +++ b/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/TExcelConnection.java @@ -85,7 +85,7 @@ private Workbook createConnectionToExcelDocument(String filePath, boolean releas } catch (FileNotFoundException e) { throw new SQLException("Could not locate the EXCEL datasource in the provided " + "location", e); - } catch (IOException | InvalidFormatException e) { + } catch (IOException e) { throw new SQLException("Error occurred while initializing the EXCEL datasource", e); } catch (InterruptedException e) { throw new SQLException("Error Acquiring the lock for the workbook path - " + filePath, e); diff --git a/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/TResultSet.java b/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/TResultSet.java index a052bcd0bf..1b1247e9ee 100644 --- a/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/TResultSet.java +++ b/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/TResultSet.java @@ -43,7 +43,7 @@ import java.util.List; import java.util.Map; -import org.apache.poi.ss.usermodel.Cell; +import org.apache.poi.ss.usermodel.CellType; import org.wso2.micro.integrator.dataservices.sql.driver.processor.reader.DataCell; import org.wso2.micro.integrator.dataservices.sql.driver.processor.reader.DataRow; import org.wso2.micro.integrator.dataservices.sql.driver.processor.reader.DataTable; @@ -227,7 +227,7 @@ public BigDecimal getBigDecimal(String columnLabel, int scale) throws SQLExcepti if (cell == null) { throw new SQLException("Error occurred while extracting the value"); } - if (cell.getCellType() != Cell.CELL_TYPE_NUMERIC) { + if (cell.getCellType() != CellType.NUMERIC.getCode()) { throw new SQLException("Value cannot be cast to a string"); } return BigDecimal.valueOf(Long.parseLong(cell.getCellValue().toString())); diff --git a/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/processor/reader/ExcelDataReader.java b/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/processor/reader/ExcelDataReader.java index 8f2e785d70..1b9e8e6a9f 100644 --- a/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/processor/reader/ExcelDataReader.java +++ b/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/processor/reader/ExcelDataReader.java @@ -25,6 +25,7 @@ import java.util.List; import org.apache.poi.ss.usermodel.Cell; +import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; @@ -58,7 +59,7 @@ public void populateData() throws SQLException { while (cellItr.hasNext()) { Cell cell = cellItr.next(); DataCell dataCell = - new DataCell(cellIndex + 1, cell.getCellType(), extractCellValue(cell)); + new DataCell(cellIndex + 1, cell.getCellType().getCode(), extractCellValue(cell)); dataRow.addCell(dataCell.getColumnId(), dataCell); cellIndex++; } @@ -77,13 +78,13 @@ public void populateData() throws SQLException { */ private Object extractCellValue(Cell cell) { switch (cell.getCellType()) { - case Cell.CELL_TYPE_NUMERIC: + case NUMERIC: return cell.getNumericCellValue(); - case Cell.CELL_TYPE_BLANK: - case Cell.CELL_TYPE_FORMULA: - case Cell.CELL_TYPE_STRING: + case BLANK: + case FORMULA: + case STRING: return cell.getStringCellValue(); - case Cell.CELL_TYPE_BOOLEAN: + case BOOLEAN: return cell.getBooleanCellValue(); default: return cell.getStringCellValue(); @@ -117,14 +118,14 @@ private ColumnInfo[] extractColumnHeaders(Sheet sheet) throws SQLException { while (itr.hasNext()) { Cell cell = itr.next(); if (cell != null) { - int cellType = cell.getCellType(); + CellType cellType = cell.getCellType(); switch (cellType) { - case Cell.CELL_TYPE_STRING: + case STRING: headers.add(new ColumnInfo(cell.getColumnIndex() + 1, cell.getStringCellValue(), sheet.getSheetName(), Types.VARCHAR, cell.getColumnIndex() + 1)); break; - case Cell.CELL_TYPE_NUMERIC: + case NUMERIC: headers.add(new ColumnInfo(cell.getColumnIndex() + 1, String.valueOf(cell.getNumericCellValue()), sheet.getSheetName(), Types.INTEGER, diff --git a/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/processor/writer/ExcelDataWriter.java b/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/processor/writer/ExcelDataWriter.java index f46fc55fab..974f4561c9 100644 --- a/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/processor/writer/ExcelDataWriter.java +++ b/components/data/data-services/org.wso2.micro.integrator.dataservices.sql.driver/src/main/java/org/wso2/micro/integrator/dataservices/sql/driver/processor/writer/ExcelDataWriter.java @@ -23,7 +23,7 @@ import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; -import org.apache.poi.ss.usermodel.Cell; +import org.apache.poi.ss.usermodel.CellType; import org.wso2.micro.integrator.dataservices.sql.driver.TExcelConnection; import org.wso2.micro.integrator.dataservices.sql.driver.processor.reader.DataCell; import org.wso2.micro.integrator.dataservices.sql.driver.processor.reader.DataRow; @@ -62,16 +62,13 @@ public Map getData() { } private void commitCell(DataCell cell) { - int cellType = cell.getCellType(); + CellType cellType = CellType.forInt(cell.getCellType()); switch(cellType) { - case Cell.CELL_TYPE_NUMERIC: - - case Cell.CELL_TYPE_BLANK: - case Cell.CELL_TYPE_FORMULA: - case Cell.CELL_TYPE_STRING: - - case Cell.CELL_TYPE_BOOLEAN: - + case NUMERIC: + case BLANK: + case FORMULA: + case STRING: + case BOOLEAN: default: } diff --git a/components/mediation/mediators/dataservices-mediator/org.wso2.micro.integrator.mediator.dataservice/src/main/java/org/wso2/micro/integrator/mediator/dataservice/DataServiceCallMediator.java b/components/mediation/mediators/dataservices-mediator/org.wso2.micro.integrator.mediator.dataservice/src/main/java/org/wso2/micro/integrator/mediator/dataservice/DataServiceCallMediator.java index 9a3b609e57..401b930c32 100644 --- a/components/mediation/mediators/dataservices-mediator/org.wso2.micro.integrator.mediator.dataservice/src/main/java/org/wso2/micro/integrator/mediator/dataservice/DataServiceCallMediator.java +++ b/components/mediation/mediators/dataservices-mediator/org.wso2.micro.integrator.mediator.dataservice/src/main/java/org/wso2/micro/integrator/mediator/dataservice/DataServiceCallMediator.java @@ -298,10 +298,6 @@ private void addParams(Param param, OMElement payload, MessageContext msgCtx) { paramValue = param.getParamValue(); } else if (param.getParamExpression() != null) { paramValue = param.getParamExpression().stringValueOf(msgCtx); - if (DataServiceCallMediatorConstants.XML_TYPE.equals(param.getEvaluator()) && - !isJson(paramValue.trim(), param.getParamExpression())) { - paramValue = escapeXMLEnvelope(msgCtx, paramValue); - } } omElement.setText(paramValue); payload.addChild(omElement); @@ -315,33 +311,6 @@ private boolean isJson(String value, SynapsePath expression) { || value.trim().charAt(0) == '[') && expression.getPathType().equals(SynapsePath.JSON_PATH); } - /** - * Escapes XML special characters - * - * @param msgCtx Message Context - * @param value XML String which needs to be escaped - * @return XML special char escaped string - */ - private String escapeXMLEnvelope(MessageContext msgCtx, String value) { - String xmlVersion = "1.0"; //Default is set to 1.0 - - try { - xmlVersion = checkXMLVersion(msgCtx); - } catch (IOException e) { - log.error("Error reading message envelope", e); - } catch (SAXException e) { - log.error("Error parsing message envelope", e); - } catch (ParserConfigurationException e) { - log.error("Error building message envelope document", e); - } - - if ("1.1".equals(xmlVersion)) { - return org.apache.commons.text.StringEscapeUtils.escapeXml11(value); - } else { - return org.apache.commons.text.StringEscapeUtils.escapeXml10(value); - } - } - /** * Checks and returns XML version of the envelope * diff --git a/distribution/pom.xml b/distribution/pom.xml index bcbe5ab4de..b6c2bc2663 100644 --- a/distribution/pom.xml +++ b/distribution/pom.xml @@ -152,6 +152,14 @@ org.graalvm.js js-scriptengine + + org.apache.poi + poi + + + org.apache.poi + poi-ooxml + diff --git a/distribution/src/assembly/bin.xml b/distribution/src/assembly/bin.xml index 1c9afbf7b4..2bfd7c9a54 100755 --- a/distribution/src/assembly/bin.xml +++ b/distribution/src/assembly/bin.xml @@ -694,6 +694,9 @@ io.netty:netty-tcnative-boringssl-static org.codehaus.woodstox:stax2-api:jar + + org.apache.poi:poi:jar + org.apache.poi:poi-ooxml:jar diff --git a/integration/pom.xml b/integration/pom.xml index 4a0b87ffcc..19f5f15d34 100644 --- a/integration/pom.xml +++ b/integration/pom.xml @@ -802,7 +802,7 @@ 42.2.12 8.2.2.jre8 0.7.2 - 2.6 + 2.17.0 2.0.4.wso2v4 3.3.4 1.0.1 diff --git a/pom.xml b/pom.xml index 9522183678..5992c481e5 100644 --- a/pom.xml +++ b/pom.xml @@ -1502,6 +1502,16 @@ icu4j ${icu.version} + + org.apache.poi + poi-ooxml + ${poi-ooxml.version} + + + org.apache.poi + poi + ${poi.version} + @@ -1641,7 +1651,7 @@ 1.5.1 [1.0.0,2.0.0) 1.78.1.wso2v1 - 3.17.0.wso2v1 + 5.3.0.wso2v1 3.0.0.wso2v1 1.1.400.v20130418-1354 9.0.85 @@ -1667,7 +1677,7 @@ 1.6.2.wso2v4 1.4.7-wso2v8 1.4.7 - 1.15 + 1.17.1 0.1.0.wso2v1 3.1.0.wso2v1 1.5.0.wso2v1 @@ -1677,7 +1687,7 @@ 2.6.0.wso2v1 1.0.1.wso2v2 3.17.0.wso2v1 - 3.17.0.wso2v1 + 5.3.0.wso2v1 1.7.36 2.17.1 2.2.5.wso2v1 @@ -1765,7 +1775,7 @@ 0.0.0 [4.4.0,5.0.0) - 2.11.0 + 2.17.0 0.0.0 1.0.0.wso2v1 @@ -1777,9 +1787,12 @@ 1.8.wso2v1 0.0.0 - 3.17.0.wso2v1 + 5.3.0.wso2v1 0.0.0 + 5.3.0 + 5.3.0 + 4.4.wso2v1 0.0.0 @@ -1835,7 +1848,7 @@ 1.33.3.wso2v1 [1.33.1,2.0) - 3.17.0.wso2v1 + 5.3.0.wso2v1 0.0.0 1.33.1.wso2v2