mirror of
https://gitee.com/dolphinscheduler/DolphinScheduler.git
synced 2024-11-30 03:08:01 +08:00
Merge remote-tracking branch 'upstream/dev' into json_split
# Conflicts: # dolphinscheduler-server/src/main/java/org/apache/dolphinscheduler/server/master/runner/MasterExecThread.java # dolphinscheduler-server/src/main/java/org/apache/dolphinscheduler/server/utils/DependentExecute.java
This commit is contained in:
commit
156dadac69
@ -56,6 +56,10 @@
|
|||||||
<groupId>org.apache.poi</groupId>
|
<groupId>org.apache.poi</groupId>
|
||||||
<artifactId>poi</artifactId>
|
<artifactId>poi</artifactId>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.apache.poi</groupId>
|
||||||
|
<artifactId>poi-ooxml</artifactId>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.google.guava</groupId>
|
<groupId>com.google.guava</groupId>
|
||||||
|
@ -73,7 +73,7 @@ public class EmailConstants {
|
|||||||
|
|
||||||
public static final String UTF_8 = "UTF-8";
|
public static final String UTF_8 = "UTF-8";
|
||||||
|
|
||||||
public static final String EXCEL_SUFFIX_XLS = ".xls";
|
public static final String EXCEL_SUFFIX_XLSX = ".xlsx";
|
||||||
|
|
||||||
public static final String SINGLE_SLASH = "/";
|
public static final String SINGLE_SLASH = "/";
|
||||||
}
|
}
|
||||||
|
@ -21,16 +21,15 @@ import org.apache.dolphinscheduler.plugin.alert.email.exception.AlertEmailExcept
|
|||||||
import org.apache.dolphinscheduler.spi.utils.JSONUtils;
|
import org.apache.dolphinscheduler.spi.utils.JSONUtils;
|
||||||
|
|
||||||
import org.apache.commons.collections4.CollectionUtils;
|
import org.apache.commons.collections4.CollectionUtils;
|
||||||
import org.apache.poi.hssf.usermodel.HSSFCell;
|
import org.apache.poi.ss.usermodel.Cell;
|
||||||
import org.apache.poi.hssf.usermodel.HSSFRow;
|
|
||||||
import org.apache.poi.hssf.usermodel.HSSFSheet;
|
|
||||||
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
|
|
||||||
import org.apache.poi.ss.usermodel.CellStyle;
|
import org.apache.poi.ss.usermodel.CellStyle;
|
||||||
import org.apache.poi.ss.usermodel.HorizontalAlignment;
|
import org.apache.poi.ss.usermodel.HorizontalAlignment;
|
||||||
|
import org.apache.poi.ss.usermodel.Row;
|
||||||
|
import org.apache.poi.ss.usermodel.Sheet;
|
||||||
|
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
import java.io.IOException;
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.LinkedHashMap;
|
import java.util.LinkedHashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -50,6 +49,8 @@ public class ExcelUtils {
|
|||||||
|
|
||||||
private static final Logger logger = LoggerFactory.getLogger(ExcelUtils.class);
|
private static final Logger logger = LoggerFactory.getLogger(ExcelUtils.class);
|
||||||
|
|
||||||
|
private static final int XLSX_WINDOW_ROW = 10000;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* generate excel file
|
* generate excel file
|
||||||
*
|
*
|
||||||
@ -58,10 +59,13 @@ public class ExcelUtils {
|
|||||||
* @param xlsFilePath the xls path
|
* @param xlsFilePath the xls path
|
||||||
*/
|
*/
|
||||||
public static void genExcelFile(String content, String title, String xlsFilePath) {
|
public static void genExcelFile(String content, String title, String xlsFilePath) {
|
||||||
List<LinkedHashMap> itemsList;
|
File file = new File(xlsFilePath);
|
||||||
|
if (!file.exists() && !file.mkdirs()) {
|
||||||
|
logger.error("Create xlsx directory error, path:{}", xlsFilePath);
|
||||||
|
throw new AlertEmailException("Create xlsx directory error");
|
||||||
|
}
|
||||||
|
|
||||||
//The JSONUtils.toList has been try catch ex
|
List<LinkedHashMap> itemsList = JSONUtils.toList(content, LinkedHashMap.class);
|
||||||
itemsList = JSONUtils.toList(content, LinkedHashMap.class);
|
|
||||||
|
|
||||||
if (CollectionUtils.isEmpty(itemsList)) {
|
if (CollectionUtils.isEmpty(itemsList)) {
|
||||||
logger.error("itemsList is null");
|
logger.error("itemsList is null");
|
||||||
@ -75,15 +79,12 @@ public class ExcelUtils {
|
|||||||
for (Map.Entry<String, Object> en : headerMap.entrySet()) {
|
for (Map.Entry<String, Object> en : headerMap.entrySet()) {
|
||||||
headerList.add(en.getKey());
|
headerList.add(en.getKey());
|
||||||
}
|
}
|
||||||
|
try (SXSSFWorkbook wb = new SXSSFWorkbook(XLSX_WINDOW_ROW);
|
||||||
HSSFWorkbook wb = null;
|
FileOutputStream fos = new FileOutputStream(String.format("%s/%s.xlsx", xlsFilePath, title))) {
|
||||||
FileOutputStream fos = null;
|
|
||||||
try {
|
|
||||||
// declare a workbook
|
// declare a workbook
|
||||||
wb = new HSSFWorkbook();
|
|
||||||
// generate a table
|
// generate a table
|
||||||
HSSFSheet sheet = wb.createSheet();
|
Sheet sheet = wb.createSheet();
|
||||||
HSSFRow row = sheet.createRow(0);
|
Row row = sheet.createRow(0);
|
||||||
//set the height of the first line
|
//set the height of the first line
|
||||||
row.setHeight((short) 500);
|
row.setHeight((short) 500);
|
||||||
|
|
||||||
@ -93,7 +94,7 @@ public class ExcelUtils {
|
|||||||
|
|
||||||
//setting excel headers
|
//setting excel headers
|
||||||
for (int i = 0; i < headerList.size(); i++) {
|
for (int i = 0; i < headerList.size(); i++) {
|
||||||
HSSFCell cell = row.createCell(i);
|
Cell cell = row.createCell(i);
|
||||||
cell.setCellStyle(cellStyle);
|
cell.setCellStyle(cellStyle);
|
||||||
cell.setCellValue(headerList.get(i));
|
cell.setCellValue(headerList.get(i));
|
||||||
}
|
}
|
||||||
@ -107,7 +108,7 @@ public class ExcelUtils {
|
|||||||
row.setHeight((short) 500);
|
row.setHeight((short) 500);
|
||||||
rowIndex++;
|
rowIndex++;
|
||||||
for (int j = 0; j < values.length; j++) {
|
for (int j = 0; j < values.length; j++) {
|
||||||
HSSFCell cell1 = row.createCell(j);
|
Cell cell1 = row.createCell(j);
|
||||||
cell1.setCellStyle(cellStyle);
|
cell1.setCellStyle(cellStyle);
|
||||||
cell1.setCellValue(String.valueOf(values[j]));
|
cell1.setCellValue(String.valueOf(values[j]));
|
||||||
}
|
}
|
||||||
@ -117,33 +118,11 @@ public class ExcelUtils {
|
|||||||
sheet.setColumnWidth(i, headerList.get(i).length() * 800);
|
sheet.setColumnWidth(i, headerList.get(i).length() * 800);
|
||||||
}
|
}
|
||||||
|
|
||||||
File file = new File(xlsFilePath);
|
|
||||||
if (!file.exists()) {
|
|
||||||
file.mkdirs();
|
|
||||||
}
|
|
||||||
|
|
||||||
//setting file output
|
//setting file output
|
||||||
fos = new FileOutputStream(xlsFilePath + EmailConstants.SINGLE_SLASH + title + EmailConstants.EXCEL_SUFFIX_XLS);
|
|
||||||
|
|
||||||
wb.write(fos);
|
wb.write(fos);
|
||||||
|
wb.dispose();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
throw new AlertEmailException("generate excel error", e);
|
throw new AlertEmailException("generate excel error", e);
|
||||||
} finally {
|
|
||||||
if (wb != null) {
|
|
||||||
try {
|
|
||||||
wb.close();
|
|
||||||
} catch (IOException e) {
|
|
||||||
logger.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (fos != null) {
|
|
||||||
try {
|
|
||||||
fos.close();
|
|
||||||
} catch (IOException e) {
|
|
||||||
logger.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -173,6 +173,7 @@ public class MailSender {
|
|||||||
}
|
}
|
||||||
|
|
||||||
receivers.removeIf(StringUtils::isEmpty);
|
receivers.removeIf(StringUtils::isEmpty);
|
||||||
|
Thread.currentThread().setContextClassLoader(getClass().getClassLoader());
|
||||||
|
|
||||||
if (showType.equals(ShowType.TABLE.getDescp()) || showType.equals(ShowType.TEXT.getDescp())) {
|
if (showType.equals(ShowType.TABLE.getDescp()) || showType.equals(ShowType.TEXT.getDescp())) {
|
||||||
// send email
|
// send email
|
||||||
@ -204,7 +205,9 @@ public class MailSender {
|
|||||||
} else if (showType.equals(ShowType.ATTACHMENT.getDescp()) || showType.equals(ShowType.TABLEATTACHMENT.getDescp())) {
|
} else if (showType.equals(ShowType.ATTACHMENT.getDescp()) || showType.equals(ShowType.TABLEATTACHMENT.getDescp())) {
|
||||||
try {
|
try {
|
||||||
|
|
||||||
String partContent = (showType.equals(ShowType.ATTACHMENT.getDescp()) ? "Please see the attachment " + title + EmailConstants.EXCEL_SUFFIX_XLS : htmlTable(content, false));
|
String partContent = (showType.equals(ShowType.ATTACHMENT.getDescp())
|
||||||
|
? "Please see the attachment " + title + EmailConstants.EXCEL_SUFFIX_XLSX
|
||||||
|
: htmlTable(content, false));
|
||||||
|
|
||||||
attachment(title, content, partContent);
|
attachment(title, content, partContent);
|
||||||
|
|
||||||
@ -338,7 +341,7 @@ public class MailSender {
|
|||||||
part1.setContent(partContent, EmailConstants.TEXT_HTML_CHARSET_UTF_8);
|
part1.setContent(partContent, EmailConstants.TEXT_HTML_CHARSET_UTF_8);
|
||||||
// set attach file
|
// set attach file
|
||||||
MimeBodyPart part2 = new MimeBodyPart();
|
MimeBodyPart part2 = new MimeBodyPart();
|
||||||
File file = new File(xlsFilePath + EmailConstants.SINGLE_SLASH + title + EmailConstants.EXCEL_SUFFIX_XLS);
|
File file = new File(xlsFilePath + EmailConstants.SINGLE_SLASH + title + EmailConstants.EXCEL_SUFFIX_XLSX);
|
||||||
if (!file.getParentFile().exists()) {
|
if (!file.getParentFile().exists()) {
|
||||||
file.getParentFile().mkdirs();
|
file.getParentFile().mkdirs();
|
||||||
}
|
}
|
||||||
@ -347,7 +350,7 @@ public class MailSender {
|
|||||||
ExcelUtils.genExcelFile(content, title, xlsFilePath);
|
ExcelUtils.genExcelFile(content, title, xlsFilePath);
|
||||||
|
|
||||||
part2.attachFile(file);
|
part2.attachFile(file);
|
||||||
part2.setFileName(MimeUtility.encodeText(title + EmailConstants.EXCEL_SUFFIX_XLS, EmailConstants.UTF_8, "B"));
|
part2.setFileName(MimeUtility.encodeText(title + EmailConstants.EXCEL_SUFFIX_XLSX, EmailConstants.UTF_8, "B"));
|
||||||
// add components to collection
|
// add components to collection
|
||||||
partList.addBodyPart(part1);
|
partList.addBodyPart(part1);
|
||||||
partList.addBodyPart(part2);
|
partList.addBodyPart(part2);
|
||||||
@ -378,7 +381,6 @@ public class MailSender {
|
|||||||
|
|
||||||
// send
|
// send
|
||||||
email.setDebug(true);
|
email.setDebug(true);
|
||||||
Thread.currentThread().setContextClassLoader(getClass().getClassLoader());
|
|
||||||
email.send();
|
email.send();
|
||||||
|
|
||||||
alertResult.setStatus("true");
|
alertResult.setStatus("true");
|
||||||
@ -394,12 +396,12 @@ public class MailSender {
|
|||||||
public void deleteFile(File file) {
|
public void deleteFile(File file) {
|
||||||
if (file.exists()) {
|
if (file.exists()) {
|
||||||
if (file.delete()) {
|
if (file.delete()) {
|
||||||
logger.info("delete success: {}", file.getAbsolutePath() + file.getName());
|
logger.info("delete success: {}", file.getAbsolutePath());
|
||||||
} else {
|
} else {
|
||||||
logger.info("delete fail: {}", file.getAbsolutePath() + file.getName());
|
logger.info("delete fail: {}", file.getAbsolutePath());
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
logger.info("file not exists: {}", file.getAbsolutePath() + file.getName());
|
logger.info("file not exists: {}", file.getAbsolutePath());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -78,7 +78,7 @@ public class ExcelUtilsTest {
|
|||||||
ExcelUtils.genExcelFile(correctContent, title, xlsFilePath);
|
ExcelUtils.genExcelFile(correctContent, title, xlsFilePath);
|
||||||
|
|
||||||
//Test file exists
|
//Test file exists
|
||||||
File xlsFile = new File(xlsFilePath + EmailConstants.SINGLE_SLASH + title + EmailConstants.EXCEL_SUFFIX_XLS);
|
File xlsFile = new File(xlsFilePath + EmailConstants.SINGLE_SLASH + title + EmailConstants.EXCEL_SUFFIX_XLSX);
|
||||||
assertTrue(xlsFile.exists());
|
assertTrue(xlsFile.exists());
|
||||||
|
|
||||||
//Expected RuntimeException
|
//Expected RuntimeException
|
||||||
@ -98,7 +98,7 @@ public class ExcelUtilsTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testGenExcelFileByCheckDir() {
|
public void testGenExcelFileByCheckDir() {
|
||||||
ExcelUtils.genExcelFile("[{\"a\": \"a\"},{\"a\": \"a\"}]", "t", "/tmp/xls");
|
ExcelUtils.genExcelFile("[{\"a\": \"a\"},{\"a\": \"a\"}]", "t", "/tmp/xls");
|
||||||
File file = new File("/tmp/xls" + EmailConstants.SINGLE_SLASH + "t" + EmailConstants.EXCEL_SUFFIX_XLS);
|
File file = new File("/tmp/xls" + EmailConstants.SINGLE_SLASH + "t" + EmailConstants.EXCEL_SUFFIX_XLSX);
|
||||||
file.delete();
|
file.delete();
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -19,6 +19,7 @@ package org.apache.dolphinscheduler.common.plugin;
|
|||||||
|
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
|
import org.junit.Ignore;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableList;
|
import com.google.common.collect.ImmutableList;
|
||||||
@ -29,6 +30,7 @@ public class DolphinSchedulerPluginLoaderTest {
|
|||||||
* Method: loadPlugins()
|
* Method: loadPlugins()
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
|
@Ignore
|
||||||
public void testLoadPlugins() {
|
public void testLoadPlugins() {
|
||||||
PluginManagerTest pluginManager = new PluginManagerTest();
|
PluginManagerTest pluginManager = new PluginManagerTest();
|
||||||
DolphinPluginManagerConfig alertPluginManagerConfig = new DolphinPluginManagerConfig();
|
DolphinPluginManagerConfig alertPluginManagerConfig = new DolphinPluginManagerConfig();
|
||||||
|
@ -233,7 +233,7 @@ The text of each license is also included at licenses/LICENSE-[project].txt.
|
|||||||
commons-codec 1.11: https://mvnrepository.com/artifact/commons-codec/commons-codec/1.11, Apache 2.0
|
commons-codec 1.11: https://mvnrepository.com/artifact/commons-codec/commons-codec/1.11, Apache 2.0
|
||||||
commons-collections 3.2.2: https://mvnrepository.com/artifact/commons-collections/commons-collections/3.2.2, Apache 2.0
|
commons-collections 3.2.2: https://mvnrepository.com/artifact/commons-collections/commons-collections/3.2.2, Apache 2.0
|
||||||
commons-collections4 4.1: https://mvnrepository.com/artifact/org.apache.commons/commons-collections4/4.1, Apache 2.0
|
commons-collections4 4.1: https://mvnrepository.com/artifact/org.apache.commons/commons-collections4/4.1, Apache 2.0
|
||||||
commons-compress 1.4.1: https://mvnrepository.com/artifact/org.apache.commons/commons-compress/1.4.1, Apache 2.0
|
commons-compress 1.19: https://mvnrepository.com/artifact/org.apache.commons/commons-compress/1.19, Apache 2.0
|
||||||
commons-configuration 1.10: https://mvnrepository.com/artifact/commons-configuration/commons-configuration/1.10, Apache 2.0
|
commons-configuration 1.10: https://mvnrepository.com/artifact/commons-configuration/commons-configuration/1.10, Apache 2.0
|
||||||
commons-daemon 1.0.13 https://mvnrepository.com/artifact/commons-daemon/commons-daemon/1.0.13, Apache 2.0
|
commons-daemon 1.0.13 https://mvnrepository.com/artifact/commons-daemon/commons-daemon/1.0.13, Apache 2.0
|
||||||
commons-dbcp 1.4: https://github.com/apache/commons-dbcp, Apache 2.0
|
commons-dbcp 1.4: https://github.com/apache/commons-dbcp, Apache 2.0
|
||||||
@ -242,7 +242,7 @@ The text of each license is also included at licenses/LICENSE-[project].txt.
|
|||||||
commons-io 2.4: https://github.com/apache/commons-io, Apache 2.0
|
commons-io 2.4: https://github.com/apache/commons-io, Apache 2.0
|
||||||
commons-lang 2.6: https://github.com/apache/commons-lang, Apache 2.0
|
commons-lang 2.6: https://github.com/apache/commons-lang, Apache 2.0
|
||||||
commons-logging 1.1.1: https://github.com/apache/commons-logging, Apache 2.0
|
commons-logging 1.1.1: https://github.com/apache/commons-logging, Apache 2.0
|
||||||
commons-math3 3.1.1: https://github.com/apache/commons-math, Apache 2.0
|
commons-math3 3.6.1: https://mvnrepository.com/artifact/org.apache.commons/commons-math3/3.6.1, Apache 2.0
|
||||||
commons-net 3.1: https://github.com/apache/commons-net, Apache 2.0
|
commons-net 3.1: https://github.com/apache/commons-net, Apache 2.0
|
||||||
commons-pool 1.6: https://github.com/apache/commons-pool, Apache 2.0
|
commons-pool 1.6: https://github.com/apache/commons-pool, Apache 2.0
|
||||||
cron-utils 5.0.5: https://mvnrepository.com/artifact/com.cronutils/cron-utils/5.0.5, Apache 2.0
|
cron-utils 5.0.5: https://mvnrepository.com/artifact/com.cronutils/cron-utils/5.0.5, Apache 2.0
|
||||||
@ -355,7 +355,9 @@ The text of each license is also included at licenses/LICENSE-[project].txt.
|
|||||||
netty-all 4.1.53.Final: https://github.com/netty/netty/blob/netty-4.1.53.Final/LICENSE.txt, Apache 2.0
|
netty-all 4.1.53.Final: https://github.com/netty/netty/blob/netty-4.1.53.Final/LICENSE.txt, Apache 2.0
|
||||||
opencsv 2.3: https://mvnrepository.com/artifact/net.sf.opencsv/opencsv/2.3, Apache 2.0
|
opencsv 2.3: https://mvnrepository.com/artifact/net.sf.opencsv/opencsv/2.3, Apache 2.0
|
||||||
parquet-hadoop-bundle 1.8.1: https://mvnrepository.com/artifact/org.apache.parquet/parquet-hadoop-bundle/1.8.1, Apache 2.0
|
parquet-hadoop-bundle 1.8.1: https://mvnrepository.com/artifact/org.apache.parquet/parquet-hadoop-bundle/1.8.1, Apache 2.0
|
||||||
poi 3.17: https://mvnrepository.com/artifact/org.apache.poi/poi/3.17, Apache 2.0
|
poi 4.1.2: https://mvnrepository.com/artifact/org.apache.poi/poi/4.1.2, Apache 2.0
|
||||||
|
poi-ooxml 4.1.2: https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml/4.1.2, Apache 2.0
|
||||||
|
poi-ooxml-schemas-4.1.2: https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml-schemas/4.1.2, Apache 2.0
|
||||||
plexus-cipher 1.7.0: https://mvnrepository.com/artifact/org.sonatype.plexus/plexus-cipher/1.7.0, Apache 2.0
|
plexus-cipher 1.7.0: https://mvnrepository.com/artifact/org.sonatype.plexus/plexus-cipher/1.7.0, Apache 2.0
|
||||||
plexus-classworlds 2.4: https://mvnrepository.com/artifact/org.codehaus.plexus/plexus-classworlds/2.4, Apache 2.0
|
plexus-classworlds 2.4: https://mvnrepository.com/artifact/org.codehaus.plexus/plexus-classworlds/2.4, Apache 2.0
|
||||||
plexus-component-annotations 1.5.5: https://mvnrepository.com/artifact/org.codehaus.plexus/plexus-component-annotations/1.5.5, Apache 2.0
|
plexus-component-annotations 1.5.5: https://mvnrepository.com/artifact/org.codehaus.plexus/plexus-component-annotations/1.5.5, Apache 2.0
|
||||||
@ -369,6 +371,7 @@ The text of each license is also included at licenses/LICENSE-[project].txt.
|
|||||||
snakeyaml 1.23: https://mvnrepository.com/artifact/org.yaml/snakeyaml/1.23, Apache 2.0
|
snakeyaml 1.23: https://mvnrepository.com/artifact/org.yaml/snakeyaml/1.23, Apache 2.0
|
||||||
snappy 0.2: https://mvnrepository.com/artifact/org.iq80.snappy/snappy/0.2, Apache 2.0
|
snappy 0.2: https://mvnrepository.com/artifact/org.iq80.snappy/snappy/0.2, Apache 2.0
|
||||||
snappy-java 1.0.4.1: https://github.com/xerial/snappy-java, Apache 2.0
|
snappy-java 1.0.4.1: https://github.com/xerial/snappy-java, Apache 2.0
|
||||||
|
SparseBitSet 1.2: https://mvnrepository.com/artifact/com.zaxxer/SparseBitSet, Apache 2.0
|
||||||
spring-aop 5.1.19.RELEASE: https://mvnrepository.com/artifact/org.springframework/spring-aop/5.1.19.RELEASE, Apache 2.0
|
spring-aop 5.1.19.RELEASE: https://mvnrepository.com/artifact/org.springframework/spring-aop/5.1.19.RELEASE, Apache 2.0
|
||||||
spring-beans 5.1.19.RELEASE: https://mvnrepository.com/artifact/org.springframework/spring-beans/5.1.19.RELEASE, Apache 2.0
|
spring-beans 5.1.19.RELEASE: https://mvnrepository.com/artifact/org.springframework/spring-beans/5.1.19.RELEASE, Apache 2.0
|
||||||
spring-boot 2.1.18.RELEASE: https://mvnrepository.com/artifact/org.springframework.boot/spring-boot/2.1.18.RELEASE, Apache 2.0
|
spring-boot 2.1.18.RELEASE: https://mvnrepository.com/artifact/org.springframework.boot/spring-boot/2.1.18.RELEASE, Apache 2.0
|
||||||
@ -405,6 +408,7 @@ The text of each license is also included at licenses/LICENSE-[project].txt.
|
|||||||
wagon-provider-api 2.2: https://mvnrepository.com/artifact/org.apache.maven.wagon/wagon-provider-api/2.2, Apache 2.0
|
wagon-provider-api 2.2: https://mvnrepository.com/artifact/org.apache.maven.wagon/wagon-provider-api/2.2, Apache 2.0
|
||||||
xbean-reflect 3.4: https://mvnrepository.com/artifact/org.apache.xbean/xbean-reflect/3.4, Apache 2.0
|
xbean-reflect 3.4: https://mvnrepository.com/artifact/org.apache.xbean/xbean-reflect/3.4, Apache 2.0
|
||||||
xercesImpl 2.9.1: https://mvnrepository.com/artifact/xerces/xercesImpl/2.9.1, Apache 2.0
|
xercesImpl 2.9.1: https://mvnrepository.com/artifact/xerces/xercesImpl/2.9.1, Apache 2.0
|
||||||
|
xmlbeans 3.1.0: https://mvnrepository.com/artifact/org.apache.xmlbeans/xmlbeans/3.1.0, Apache 2.0
|
||||||
xml-apis 1.4.01: https://mvnrepository.com/artifact/xml-apis/xml-apis/1.4.01, Apache 2.0 and W3C
|
xml-apis 1.4.01: https://mvnrepository.com/artifact/xml-apis/xml-apis/1.4.01, Apache 2.0 and W3C
|
||||||
zookeeper 3.4.14: https://mvnrepository.com/artifact/org.apache.zookeeper/zookeeper/3.4.14, Apache 2.0
|
zookeeper 3.4.14: https://mvnrepository.com/artifact/org.apache.zookeeper/zookeeper/3.4.14, Apache 2.0
|
||||||
presto-jdbc 0.238.1 https://mvnrepository.com/artifact/com.facebook.presto/presto-jdbc/0.238.1
|
presto-jdbc 0.238.1 https://mvnrepository.com/artifact/com.facebook.presto/presto-jdbc/0.238.1
|
||||||
@ -421,6 +425,7 @@ The following components are provided under a BSD license. See project link for
|
|||||||
The text of each license is also included at licenses/LICENSE-[project].txt.
|
The text of each license is also included at licenses/LICENSE-[project].txt.
|
||||||
|
|
||||||
asm 3.1: https://github.com/jdf/javalin/tree/master/lib/asm-3.1, BSD
|
asm 3.1: https://github.com/jdf/javalin/tree/master/lib/asm-3.1, BSD
|
||||||
|
curvesapi 1.06: https://mvnrepository.com/artifact/com.github.virtuald/curvesapi/1.06, BSD 3-clause
|
||||||
javolution 5.5.1: https://mvnrepository.com/artifact/javolution/javolution/5.5.1, BSD
|
javolution 5.5.1: https://mvnrepository.com/artifact/javolution/javolution/5.5.1, BSD
|
||||||
jline 0.9.94: https://github.com/jline/jline3, BSD
|
jline 0.9.94: https://github.com/jline/jline3, BSD
|
||||||
jsch 0.1.42: https://mvnrepository.com/artifact/com.jcraft/jsch/0.1.42, BSD
|
jsch 0.1.42: https://mvnrepository.com/artifact/com.jcraft/jsch/0.1.42, BSD
|
||||||
|
@ -628,13 +628,10 @@ with the following copyright notice:
|
|||||||
========================================================================
|
========================================================================
|
||||||
|
|
||||||
|
|
||||||
Apache POI NOTICE
|
|
||||||
|
|
||||||
========================================================================
|
|
||||||
Apache POI
|
Apache POI
|
||||||
Copyright 2003-2017 The Apache Software Foundation
|
Copyright 2003-2020 The Apache Software Foundation
|
||||||
|
|
||||||
This product includes software developed by
|
This product includes software developed at
|
||||||
The Apache Software Foundation (https://www.apache.org/).
|
The Apache Software Foundation (https://www.apache.org/).
|
||||||
|
|
||||||
This product contains parts that were originally based on software from BEA.
|
This product contains parts that were originally based on software from BEA.
|
||||||
@ -647,9 +644,6 @@ This product contains W3C XML Schema documents. Copyright 2001-2003 (c)
|
|||||||
World Wide Web Consortium (Massachusetts Institute of Technology, European
|
World Wide Web Consortium (Massachusetts Institute of Technology, European
|
||||||
Research Consortium for Informatics and Mathematics, Keio University)
|
Research Consortium for Informatics and Mathematics, Keio University)
|
||||||
|
|
||||||
This product contains the Piccolo XML Parser for Java
|
|
||||||
(http://piccolo.sourceforge.net/). Copyright 2002 Yuval Oren.
|
|
||||||
|
|
||||||
This product contains the chunks_parse_cmds.tbl file from the vsdump program.
|
This product contains the chunks_parse_cmds.tbl file from the vsdump program.
|
||||||
Copyright (C) 2006-2007 Valek Filippov (frob@df.ru)
|
Copyright (C) 2006-2007 Valek Filippov (frob@df.ru)
|
||||||
|
|
||||||
@ -1963,3 +1957,95 @@ ANT NOTICE
|
|||||||
|
|
||||||
Please read the different LICENSE files present in the root directory of
|
Please read the different LICENSE files present in the root directory of
|
||||||
this distribution.
|
this distribution.
|
||||||
|
|
||||||
|
=========================================================================
|
||||||
|
|
||||||
|
Commons Compress NOTICE
|
||||||
|
|
||||||
|
=========================================================================
|
||||||
|
|
||||||
|
Apache Commons Compress
|
||||||
|
Copyright 2002-2020 The Apache Software Foundation
|
||||||
|
|
||||||
|
This product includes software developed at
|
||||||
|
The Apache Software Foundation (https://www.apache.org/).
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
The files in the package org.apache.commons.compress.archivers.sevenz
|
||||||
|
were derived from the LZMA SDK, version 9.20 (C/ and CPP/7zip/),
|
||||||
|
which has been placed in the public domain:
|
||||||
|
|
||||||
|
"LZMA SDK is placed in the public domain." (http://www.7-zip.org/sdk.html)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
The test file lbzip2_32767.bz2 has been copied from libbzip2's source
|
||||||
|
repository:
|
||||||
|
|
||||||
|
This program, "bzip2", the associated library "libbzip2", and all
|
||||||
|
documentation, are copyright (C) 1996-2019 Julian R Seward. All
|
||||||
|
rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions
|
||||||
|
are met:
|
||||||
|
|
||||||
|
1. Redistributions of source code must retain the above copyright
|
||||||
|
notice, this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2. The origin of this software must not be misrepresented; you must
|
||||||
|
not claim that you wrote the original software. If you use this
|
||||||
|
software in a product, an acknowledgment in the product
|
||||||
|
documentation would be appreciated but is not required.
|
||||||
|
|
||||||
|
3. Altered source versions must be plainly marked as such, and must
|
||||||
|
not be misrepresented as being the original software.
|
||||||
|
|
||||||
|
4. The name of the author may not be used to endorse or promote
|
||||||
|
products derived from this software without specific prior written
|
||||||
|
permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
|
||||||
|
OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||||
|
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
|
||||||
|
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
|
||||||
|
GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
||||||
|
WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
|
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
Julian Seward, jseward@acm.org
|
||||||
|
|
||||||
|
=========================================================================
|
||||||
|
|
||||||
|
Xmlbeans NOTICE
|
||||||
|
|
||||||
|
=========================================================================
|
||||||
|
|
||||||
|
=========================================================================
|
||||||
|
== NOTICE file corresponding to section 4(d) of the Apache License, ==
|
||||||
|
== Version 2.0, in this case for the Apache XmlBeans distribution. ==
|
||||||
|
=========================================================================
|
||||||
|
|
||||||
|
This product includes software developed at
|
||||||
|
The Apache Software Foundation (http://www.apache.org/).
|
||||||
|
|
||||||
|
Portions of this software were originally based on the following:
|
||||||
|
- software copyright (c) 2000-2003, BEA Systems, <http://www.bea.com/>.
|
||||||
|
|
||||||
|
Aside from contributions to the Apache XMLBeans project, this
|
||||||
|
software also includes:
|
||||||
|
|
||||||
|
- one or more source files from the Apache Xerces-J and Apache Axis
|
||||||
|
products, Copyright (c) 1999-2003 Apache Software Foundation
|
||||||
|
|
||||||
|
- W3C XML Schema documents Copyright 2001-2003 (c) World Wide Web
|
||||||
|
Consortium (Massachusetts Institute of Technology, European Research
|
||||||
|
Consortium for Informatics and Mathematics, Keio University)
|
||||||
|
|
||||||
|
- resolver.jar from Apache Xml Commons project,
|
||||||
|
Copyright (c) 2001-2003 Apache Software Foundation
|
||||||
|
@ -0,0 +1,167 @@
|
|||||||
|
Apache License
|
||||||
|
Version 2.0, January 2004
|
||||||
|
http://www.apache.org/licenses/
|
||||||
|
|
||||||
|
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||||
|
|
||||||
|
1. Definitions.
|
||||||
|
|
||||||
|
"License" shall mean the terms and conditions for use, reproduction, and
|
||||||
|
distribution as defined by Sections 1 through 9 of this document.
|
||||||
|
|
||||||
|
"Licensor" shall mean the copyright owner or entity authorized by the copyright
|
||||||
|
owner that is granting the License.
|
||||||
|
|
||||||
|
"Legal Entity" shall mean the union of the acting entity and all other entities
|
||||||
|
that control, are controlled by, or are under common control with that entity.
|
||||||
|
For the purposes of this definition, "control" means (i) the power, direct or
|
||||||
|
indirect, to cause the direction or management of such entity, whether by
|
||||||
|
contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||||
|
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||||
|
|
||||||
|
"You" (or "Your") shall mean an individual or Legal Entity exercising
|
||||||
|
permissions granted by this License.
|
||||||
|
|
||||||
|
"Source" form shall mean the preferred form for making modifications, including
|
||||||
|
but not limited to software source code, documentation source, and configuration
|
||||||
|
files.
|
||||||
|
|
||||||
|
"Object" form shall mean any form resulting from mechanical transformation or
|
||||||
|
translation of a Source form, including but not limited to compiled object code,
|
||||||
|
generated documentation, and conversions to other media types.
|
||||||
|
|
||||||
|
"Work" shall mean the work of authorship, whether in Source or Object form, made
|
||||||
|
available under the License, as indicated by a copyright notice that is included
|
||||||
|
in or attached to the work (an example is provided in the Appendix below).
|
||||||
|
|
||||||
|
"Derivative Works" shall mean any work, whether in Source or Object form, that
|
||||||
|
is based on (or derived from) the Work and for which the editorial revisions,
|
||||||
|
annotations, elaborations, or other modifications represent, as a whole, an
|
||||||
|
original work of authorship. For the purposes of this License, Derivative Works
|
||||||
|
shall not include works that remain separable from, or merely link (or bind by
|
||||||
|
name) to the interfaces of, the Work and Derivative Works thereof.
|
||||||
|
|
||||||
|
"Contribution" shall mean any work of authorship, including the original version
|
||||||
|
of the Work and any modifications or additions to that Work or Derivative Works
|
||||||
|
thereof, that is intentionally submitted to Licensor for inclusion in the Work
|
||||||
|
by the copyright owner or by an individual or Legal Entity authorized to submit
|
||||||
|
on behalf of the copyright owner. For the purposes of this definition,
|
||||||
|
"submitted" means any form of electronic, verbal, or written communication sent
|
||||||
|
to the Licensor or its representatives, including but not limited to
|
||||||
|
communication on electronic mailing lists, source code control systems, and
|
||||||
|
issue tracking systems that are managed by, or on behalf of, the Licensor for
|
||||||
|
the purpose of discussing and improving the Work, but excluding communication
|
||||||
|
that is conspicuously marked or otherwise designated in writing by the copyright
|
||||||
|
owner as "Not a Contribution."
|
||||||
|
|
||||||
|
"Contributor" shall mean Licensor and any individual or Legal Entity on behalf
|
||||||
|
of whom a Contribution has been received by Licensor and subsequently
|
||||||
|
incorporated within the Work.
|
||||||
|
|
||||||
|
2. Grant of Copyright License.
|
||||||
|
|
||||||
|
Subject to the terms and conditions of this License, each Contributor hereby
|
||||||
|
grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free,
|
||||||
|
irrevocable copyright license to reproduce, prepare Derivative Works of,
|
||||||
|
publicly display, publicly perform, sublicense, and distribute the Work and such
|
||||||
|
Derivative Works in Source or Object form.
|
||||||
|
|
||||||
|
3. Grant of Patent License.
|
||||||
|
|
||||||
|
Subject to the terms and conditions of this License, each Contributor hereby
|
||||||
|
grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free,
|
||||||
|
irrevocable (except as stated in this section) patent license to make, have
|
||||||
|
made, use, offer to sell, sell, import, and otherwise transfer the Work, where
|
||||||
|
such license applies only to those patent claims licensable by such Contributor
|
||||||
|
that are necessarily infringed by their Contribution(s) alone or by combination
|
||||||
|
of their Contribution(s) with the Work to which such Contribution(s) was
|
||||||
|
submitted. If You institute patent litigation against any entity (including a
|
||||||
|
cross-claim or counterclaim in a lawsuit) alleging that the Work or a
|
||||||
|
Contribution incorporated within the Work constitutes direct or contributory
|
||||||
|
patent infringement, then any patent licenses granted to You under this License
|
||||||
|
for that Work shall terminate as of the date such litigation is filed.
|
||||||
|
|
||||||
|
4. Redistribution.
|
||||||
|
|
||||||
|
You may reproduce and distribute copies of the Work or Derivative Works thereof
|
||||||
|
in any medium, with or without modifications, and in Source or Object form,
|
||||||
|
provided that You meet the following conditions:
|
||||||
|
|
||||||
|
You must give any other recipients of the Work or Derivative Works a copy of
|
||||||
|
this License; and
|
||||||
|
You must cause any modified files to carry prominent notices stating that You
|
||||||
|
changed the files; and
|
||||||
|
You must retain, in the Source form of any Derivative Works that You distribute,
|
||||||
|
all copyright, patent, trademark, and attribution notices from the Source form
|
||||||
|
of the Work, excluding those notices that do not pertain to any part of the
|
||||||
|
Derivative Works; and
|
||||||
|
If the Work includes a "NOTICE" text file as part of its distribution, then any
|
||||||
|
Derivative Works that You distribute must include a readable copy of the
|
||||||
|
attribution notices contained within such NOTICE file, excluding those notices
|
||||||
|
that do not pertain to any part of the Derivative Works, in at least one of the
|
||||||
|
following places: within a NOTICE text file distributed as part of the
|
||||||
|
Derivative Works; within the Source form or documentation, if provided along
|
||||||
|
with the Derivative Works; or, within a display generated by the Derivative
|
||||||
|
Works, if and wherever such third-party notices normally appear. The contents of
|
||||||
|
the NOTICE file are for informational purposes only and do not modify the
|
||||||
|
License. You may add Your own attribution notices within Derivative Works that
|
||||||
|
You distribute, alongside or as an addendum to the NOTICE text from the Work,
|
||||||
|
provided that such additional attribution notices cannot be construed as
|
||||||
|
modifying the License.
|
||||||
|
You may add Your own copyright statement to Your modifications and may provide
|
||||||
|
additional or different license terms and conditions for use, reproduction, or
|
||||||
|
distribution of Your modifications, or for any such Derivative Works as a whole,
|
||||||
|
provided Your use, reproduction, and distribution of the Work otherwise complies
|
||||||
|
with the conditions stated in this License.
|
||||||
|
|
||||||
|
5. Submission of Contributions.
|
||||||
|
|
||||||
|
Unless You explicitly state otherwise, any Contribution intentionally submitted
|
||||||
|
for inclusion in the Work by You to the Licensor shall be under the terms and
|
||||||
|
conditions of this License, without any additional terms or conditions.
|
||||||
|
Notwithstanding the above, nothing herein shall supersede or modify the terms of
|
||||||
|
any separate license agreement you may have executed with Licensor regarding
|
||||||
|
such Contributions.
|
||||||
|
|
||||||
|
6. Trademarks.
|
||||||
|
|
||||||
|
This License does not grant permission to use the trade names, trademarks,
|
||||||
|
service marks, or product names of the Licensor, except as required for
|
||||||
|
reasonable and customary use in describing the origin of the Work and
|
||||||
|
reproducing the content of the NOTICE file.
|
||||||
|
|
||||||
|
7. Disclaimer of Warranty.
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, Licensor provides the
|
||||||
|
Work (and each Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied,
|
||||||
|
including, without limitation, any warranties or conditions of TITLE,
|
||||||
|
NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are
|
||||||
|
solely responsible for determining the appropriateness of using or
|
||||||
|
redistributing the Work and assume any risks associated with Your exercise of
|
||||||
|
permissions under this License.
|
||||||
|
|
||||||
|
8. Limitation of Liability.
|
||||||
|
|
||||||
|
In no event and under no legal theory, whether in tort (including negligence),
|
||||||
|
contract, or otherwise, unless required by applicable law (such as deliberate
|
||||||
|
and grossly negligent acts) or agreed to in writing, shall any Contributor be
|
||||||
|
liable to You for damages, including any direct, indirect, special, incidental,
|
||||||
|
or consequential damages of any character arising as a result of this License or
|
||||||
|
out of the use or inability to use the Work (including but not limited to
|
||||||
|
damages for loss of goodwill, work stoppage, computer failure or malfunction, or
|
||||||
|
any and all other commercial damages or losses), even if such Contributor has
|
||||||
|
been advised of the possibility of such damages.
|
||||||
|
|
||||||
|
9. Accepting Warranty or Additional Liability.
|
||||||
|
|
||||||
|
While redistributing the Work or Derivative Works thereof, You may choose to
|
||||||
|
offer, and charge a fee for, acceptance of support, warranty, indemnity, or
|
||||||
|
other liability obligations and/or rights consistent with this License. However,
|
||||||
|
in accepting such obligations, You may act only on Your own behalf and on Your
|
||||||
|
sole responsibility, not on behalf of any other Contributor, and only if You
|
||||||
|
agree to indemnify, defend, and hold each Contributor harmless for any liability
|
||||||
|
incurred by, or claims asserted against, such Contributor by reason of your
|
||||||
|
accepting any such warranty or additional liability.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
@ -0,0 +1,28 @@
|
|||||||
|
Copyright (c) 2005, Graph Builder
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions
|
||||||
|
are met:
|
||||||
|
|
||||||
|
-Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
-Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
-Neither the name of Graph Builder nor the names of its contributors may be
|
||||||
|
used to endorse or promote products derived from this software without
|
||||||
|
specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
|
||||||
|
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
||||||
|
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
||||||
|
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
||||||
|
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
@ -0,0 +1,537 @@
|
|||||||
|
|
||||||
|
Apache License
|
||||||
|
Version 2.0, January 2004
|
||||||
|
http://www.apache.org/licenses/
|
||||||
|
|
||||||
|
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||||
|
|
||||||
|
1. Definitions.
|
||||||
|
|
||||||
|
"License" shall mean the terms and conditions for use, reproduction,
|
||||||
|
and distribution as defined by Sections 1 through 9 of this document.
|
||||||
|
|
||||||
|
"Licensor" shall mean the copyright owner or entity authorized by
|
||||||
|
the copyright owner that is granting the License.
|
||||||
|
|
||||||
|
"Legal Entity" shall mean the union of the acting entity and all
|
||||||
|
other entities that control, are controlled by, or are under common
|
||||||
|
control with that entity. For the purposes of this definition,
|
||||||
|
"control" means (i) the power, direct or indirect, to cause the
|
||||||
|
direction or management of such entity, whether by contract or
|
||||||
|
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||||
|
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||||
|
|
||||||
|
"You" (or "Your") shall mean an individual or Legal Entity
|
||||||
|
exercising permissions granted by this License.
|
||||||
|
|
||||||
|
"Source" form shall mean the preferred form for making modifications,
|
||||||
|
including but not limited to software source code, documentation
|
||||||
|
source, and configuration files.
|
||||||
|
|
||||||
|
"Object" form shall mean any form resulting from mechanical
|
||||||
|
transformation or translation of a Source form, including but
|
||||||
|
not limited to compiled object code, generated documentation,
|
||||||
|
and conversions to other media types.
|
||||||
|
|
||||||
|
"Work" shall mean the work of authorship, whether in Source or
|
||||||
|
Object form, made available under the License, as indicated by a
|
||||||
|
copyright notice that is included in or attached to the work
|
||||||
|
(an example is provided in the Appendix below).
|
||||||
|
|
||||||
|
"Derivative Works" shall mean any work, whether in Source or Object
|
||||||
|
form, that is based on (or derived from) the Work and for which the
|
||||||
|
editorial revisions, annotations, elaborations, or other modifications
|
||||||
|
represent, as a whole, an original work of authorship. For the purposes
|
||||||
|
of this License, Derivative Works shall not include works that remain
|
||||||
|
separable from, or merely link (or bind by name) to the interfaces of,
|
||||||
|
the Work and Derivative Works thereof.
|
||||||
|
|
||||||
|
"Contribution" shall mean any work of authorship, including
|
||||||
|
the original version of the Work and any modifications or additions
|
||||||
|
to that Work or Derivative Works thereof, that is intentionally
|
||||||
|
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||||
|
or by an individual or Legal Entity authorized to submit on behalf of
|
||||||
|
the copyright owner. For the purposes of this definition, "submitted"
|
||||||
|
means any form of electronic, verbal, or written communication sent
|
||||||
|
to the Licensor or its representatives, including but not limited to
|
||||||
|
communication on electronic mailing lists, source code control systems,
|
||||||
|
and issue tracking systems that are managed by, or on behalf of, the
|
||||||
|
Licensor for the purpose of discussing and improving the Work, but
|
||||||
|
excluding communication that is conspicuously marked or otherwise
|
||||||
|
designated in writing by the copyright owner as "Not a Contribution."
|
||||||
|
|
||||||
|
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||||
|
on behalf of whom a Contribution has been received by Licensor and
|
||||||
|
subsequently incorporated within the Work.
|
||||||
|
|
||||||
|
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||||
|
this License, each Contributor hereby grants to You a perpetual,
|
||||||
|
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||||
|
copyright license to reproduce, prepare Derivative Works of,
|
||||||
|
publicly display, publicly perform, sublicense, and distribute the
|
||||||
|
Work and such Derivative Works in Source or Object form.
|
||||||
|
|
||||||
|
3. Grant of Patent License. Subject to the terms and conditions of
|
||||||
|
this License, each Contributor hereby grants to You a perpetual,
|
||||||
|
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||||
|
(except as stated in this section) patent license to make, have made,
|
||||||
|
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||||
|
where such license applies only to those patent claims licensable
|
||||||
|
by such Contributor that are necessarily infringed by their
|
||||||
|
Contribution(s) alone or by combination of their Contribution(s)
|
||||||
|
with the Work to which such Contribution(s) was submitted. If You
|
||||||
|
institute patent litigation against any entity (including a
|
||||||
|
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||||
|
or a Contribution incorporated within the Work constitutes direct
|
||||||
|
or contributory patent infringement, then any patent licenses
|
||||||
|
granted to You under this License for that Work shall terminate
|
||||||
|
as of the date such litigation is filed.
|
||||||
|
|
||||||
|
4. Redistribution. You may reproduce and distribute copies of the
|
||||||
|
Work or Derivative Works thereof in any medium, with or without
|
||||||
|
modifications, and in Source or Object form, provided that You
|
||||||
|
meet the following conditions:
|
||||||
|
|
||||||
|
(a) You must give any other recipients of the Work or
|
||||||
|
Derivative Works a copy of this License; and
|
||||||
|
|
||||||
|
(b) You must cause any modified files to carry prominent notices
|
||||||
|
stating that You changed the files; and
|
||||||
|
|
||||||
|
(c) You must retain, in the Source form of any Derivative Works
|
||||||
|
that You distribute, all copyright, patent, trademark, and
|
||||||
|
attribution notices from the Source form of the Work,
|
||||||
|
excluding those notices that do not pertain to any part of
|
||||||
|
the Derivative Works; and
|
||||||
|
|
||||||
|
(d) If the Work includes a "NOTICE" text file as part of its
|
||||||
|
distribution, then any Derivative Works that You distribute must
|
||||||
|
include a readable copy of the attribution notices contained
|
||||||
|
within such NOTICE file, excluding those notices that do not
|
||||||
|
pertain to any part of the Derivative Works, in at least one
|
||||||
|
of the following places: within a NOTICE text file distributed
|
||||||
|
as part of the Derivative Works; within the Source form or
|
||||||
|
documentation, if provided along with the Derivative Works; or,
|
||||||
|
within a display generated by the Derivative Works, if and
|
||||||
|
wherever such third-party notices normally appear. The contents
|
||||||
|
of the NOTICE file are for informational purposes only and
|
||||||
|
do not modify the License. You may add Your own attribution
|
||||||
|
notices within Derivative Works that You distribute, alongside
|
||||||
|
or as an addendum to the NOTICE text from the Work, provided
|
||||||
|
that such additional attribution notices cannot be construed
|
||||||
|
as modifying the License.
|
||||||
|
|
||||||
|
You may add Your own copyright statement to Your modifications and
|
||||||
|
may provide additional or different license terms and conditions
|
||||||
|
for use, reproduction, or distribution of Your modifications, or
|
||||||
|
for any such Derivative Works as a whole, provided Your use,
|
||||||
|
reproduction, and distribution of the Work otherwise complies with
|
||||||
|
the conditions stated in this License.
|
||||||
|
|
||||||
|
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||||
|
any Contribution intentionally submitted for inclusion in the Work
|
||||||
|
by You to the Licensor shall be under the terms and conditions of
|
||||||
|
this License, without any additional terms or conditions.
|
||||||
|
Notwithstanding the above, nothing herein shall supersede or modify
|
||||||
|
the terms of any separate license agreement you may have executed
|
||||||
|
with Licensor regarding such Contributions.
|
||||||
|
|
||||||
|
6. Trademarks. This License does not grant permission to use the trade
|
||||||
|
names, trademarks, service marks, or product names of the Licensor,
|
||||||
|
except as required for reasonable and customary use in describing the
|
||||||
|
origin of the Work and reproducing the content of the NOTICE file.
|
||||||
|
|
||||||
|
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||||
|
agreed to in writing, Licensor provides the Work (and each
|
||||||
|
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
implied, including, without limitation, any warranties or conditions
|
||||||
|
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||||
|
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||||
|
appropriateness of using or redistributing the Work and assume any
|
||||||
|
risks associated with Your exercise of permissions under this License.
|
||||||
|
|
||||||
|
8. Limitation of Liability. In no event and under no legal theory,
|
||||||
|
whether in tort (including negligence), contract, or otherwise,
|
||||||
|
unless required by applicable law (such as deliberate and grossly
|
||||||
|
negligent acts) or agreed to in writing, shall any Contributor be
|
||||||
|
liable to You for damages, including any direct, indirect, special,
|
||||||
|
incidental, or consequential damages of any character arising as a
|
||||||
|
result of this License or out of the use or inability to use the
|
||||||
|
Work (including but not limited to damages for loss of goodwill,
|
||||||
|
work stoppage, computer failure or malfunction, or any and all
|
||||||
|
other commercial damages or losses), even if such Contributor
|
||||||
|
has been advised of the possibility of such damages.
|
||||||
|
|
||||||
|
9. Accepting Warranty or Additional Liability. While redistributing
|
||||||
|
the Work or Derivative Works thereof, You may choose to offer,
|
||||||
|
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||||
|
or other liability obligations and/or rights consistent with this
|
||||||
|
License. However, in accepting such obligations, You may act only
|
||||||
|
on Your own behalf and on Your sole responsibility, not on behalf
|
||||||
|
of any other Contributor, and only if You agree to indemnify,
|
||||||
|
defend, and hold each Contributor harmless for any liability
|
||||||
|
incurred by, or claims asserted against, such Contributor by reason
|
||||||
|
of your accepting any such warranty or additional liability.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
APPENDIX: How to apply the Apache License to your work.
|
||||||
|
|
||||||
|
To apply the Apache License to your work, attach the following
|
||||||
|
boilerplate notice, with the fields enclosed by brackets "[]"
|
||||||
|
replaced with your own identifying information. (Don't include
|
||||||
|
the brackets!) The text should be enclosed in the appropriate
|
||||||
|
comment syntax for the file format. We also recommend that a
|
||||||
|
file or class name and description of purpose be included on the
|
||||||
|
same "printed page" as the copyright notice for easier
|
||||||
|
identification within third-party archives.
|
||||||
|
|
||||||
|
Copyright [yyyy] [name of copyright owner]
|
||||||
|
|
||||||
|
Licensed 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.
|
||||||
|
|
||||||
|
|
||||||
|
APACHE POI SUBCOMPONENTS:
|
||||||
|
|
||||||
|
Apache POI includes subcomponents with separate copyright notices and
|
||||||
|
license terms. Your use of these subcomponents is subject to the terms
|
||||||
|
and conditions of the following licenses:
|
||||||
|
|
||||||
|
|
||||||
|
Office Open XML schemas (ooxml-schemas-1.*.jar)
|
||||||
|
|
||||||
|
The Office Open XML schema definitions used by Apache POI are
|
||||||
|
a part of the Office Open XML ECMA Specification (ECMA-376, [1]).
|
||||||
|
As defined in section 9.4 of the ECMA bylaws [2], this specification
|
||||||
|
is available to all interested parties without restriction:
|
||||||
|
|
||||||
|
9.4 All documents when approved shall be made available to
|
||||||
|
all interested parties without restriction.
|
||||||
|
|
||||||
|
Furthermore, both Microsoft and Adobe have granted patent licenses
|
||||||
|
to this work [3,4,5].
|
||||||
|
|
||||||
|
[1] http://www.ecma-international.org/publications/standards/Ecma-376.htm
|
||||||
|
[2] http://www.ecma-international.org/memento/Ecmabylaws.htm
|
||||||
|
[3] http://www.microsoft.com/openspecifications/en/us/programs/osp/default.aspx
|
||||||
|
[4] http://www.ecma-international.org/publications/files/ECMA-ST/Ecma%20PATENT/
|
||||||
|
Patent%20statements%20ok/ECMA-376%20Edition%202%20Microsoft%20Patent%20Declaration.pdf
|
||||||
|
[5] http://www.ecma-international.org/publications/files/ECMA-ST/Ecma%20PATENT/
|
||||||
|
Patent%20statements%20ok/ECMA-376%20Adobe%20Patent%20Declaration.pdf
|
||||||
|
|
||||||
|
|
||||||
|
Bouncy Castle library (bcprov-*.jar, bcpg-*.jar, bcpkix-*.jar)
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to
|
||||||
|
deal in the Software without restriction, including without limitation the
|
||||||
|
rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
||||||
|
sell copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in
|
||||||
|
all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||||
|
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
||||||
|
IN THE SOFTWARE.
|
||||||
|
|
||||||
|
JUnit test library (junit-4.*.jar) & JaCoCo (*jacoco*)
|
||||||
|
|
||||||
|
Eclipse Public License - v 1.0
|
||||||
|
|
||||||
|
THE ACCOMPANYING PROGRAM IS PROVIDED UNDER THE TERMS OF THIS ECLIPSE PUBLIC
|
||||||
|
LICENSE ("AGREEMENT"). ANY USE, REPRODUCTION OR DISTRIBUTION OF THE PROGRAM
|
||||||
|
CONSTITUTES RECIPIENT'S ACCEPTANCE OF THIS AGREEMENT.
|
||||||
|
|
||||||
|
1. DEFINITIONS
|
||||||
|
|
||||||
|
"Contribution" means:
|
||||||
|
|
||||||
|
a) in the case of the initial Contributor, the initial code and documentation
|
||||||
|
distributed under this Agreement, and
|
||||||
|
b) in the case of each subsequent Contributor:
|
||||||
|
i) changes to the Program, and
|
||||||
|
ii) additions to the Program;
|
||||||
|
where such changes and/or additions to the Program originate from and are
|
||||||
|
distributed by that particular Contributor. A Contribution 'originates' from
|
||||||
|
a Contributor if it was added to the Program by such Contributor itself or
|
||||||
|
anyone acting on such Contributor's behalf. Contributions do not include
|
||||||
|
additions to the Program which: (i) are separate modules of software
|
||||||
|
distributed in conjunction with the Program under their own license agreement,
|
||||||
|
and (ii) are not derivative works of the Program.
|
||||||
|
|
||||||
|
"Contributor" means any person or entity that distributes the Program.
|
||||||
|
|
||||||
|
"Licensed Patents" mean patent claims licensable by a Contributor which are
|
||||||
|
necessarily infringed by the use or sale of its Contribution alone or when
|
||||||
|
combined with the Program.
|
||||||
|
|
||||||
|
"Program" means the Contributions distributed in accordance with this Agreement.
|
||||||
|
|
||||||
|
"Recipient" means anyone who receives the Program under this Agreement,
|
||||||
|
including all Contributors.
|
||||||
|
|
||||||
|
2. GRANT OF RIGHTS
|
||||||
|
|
||||||
|
a) Subject to the terms of this Agreement, each Contributor hereby grants
|
||||||
|
Recipient a non-exclusive, worldwide, royalty-free copyright license to
|
||||||
|
reproduce, prepare derivative works of, publicly display, publicly
|
||||||
|
perform, distribute and sublicense the Contribution of such Contributor,
|
||||||
|
if any, and such derivative works, in source code and object code form.
|
||||||
|
b) Subject to the terms of this Agreement, each Contributor hereby grants
|
||||||
|
Recipient a non-exclusive, worldwide, royalty-free patent license under
|
||||||
|
Licensed Patents to make, use, sell, offer to sell, import and otherwise
|
||||||
|
transfer the Contribution of such Contributor, if any, in source code
|
||||||
|
and object code form. This patent license shall apply to the combination
|
||||||
|
of the Contribution and the Program if, at the time the Contribution is
|
||||||
|
added by the Contributor, such addition of the Contribution causes such
|
||||||
|
combination to be covered by the Licensed Patents. The patent license
|
||||||
|
shall not apply to any other combinations which include the Contribution.
|
||||||
|
No hardware per se is licensed hereunder.
|
||||||
|
c) Recipient understands that although each Contributor grants the licenses
|
||||||
|
to its Contributions set forth herein, no assurances are provided by any
|
||||||
|
Contributor that the Program does not infringe the patent or other
|
||||||
|
intellectual property rights of any other entity. Each Contributor
|
||||||
|
disclaims any liability to Recipient for claims brought by any other
|
||||||
|
entity based on infringement of intellectual property rights or
|
||||||
|
otherwise. As a condition to exercising the rights and licenses granted
|
||||||
|
hereunder, each Recipient hereby assumes sole responsibility to secure
|
||||||
|
any other intellectual property rights needed, if any. For example, if
|
||||||
|
a third party patent license is required to allow Recipient to distribute
|
||||||
|
the Program, it is Recipient's responsibility to acquire that license
|
||||||
|
before distributing the Program.
|
||||||
|
d) Each Contributor represents that to its knowledge it has sufficient
|
||||||
|
copyright rights in its Contribution, if any, to grant the copyright
|
||||||
|
license set forth in this Agreement.
|
||||||
|
|
||||||
|
3. REQUIREMENTS
|
||||||
|
|
||||||
|
A Contributor may choose to distribute the Program in object code form under
|
||||||
|
its own license agreement, provided that:
|
||||||
|
|
||||||
|
a) it complies with the terms and conditions of this Agreement; and
|
||||||
|
b) its license agreement:
|
||||||
|
i) effectively disclaims on behalf of all Contributors all warranties and
|
||||||
|
conditions, express and implied, including warranties or conditions of
|
||||||
|
title and non-infringement, and implied warranties or conditions of
|
||||||
|
merchantability and fitness for a particular purpose;
|
||||||
|
ii) effectively excludes on behalf of all Contributors all liability for
|
||||||
|
damages, including direct, indirect, special, incidental and
|
||||||
|
consequential damages, such as lost profits;
|
||||||
|
iii) states that any provisions which differ from this Agreement are
|
||||||
|
offered by that Contributor alone and not by any other party; and
|
||||||
|
iv) states that source code for the Program is available from such
|
||||||
|
Contributor, and informs licensees how to obtain it in a reasonable
|
||||||
|
manner on or through a medium customarily used for software exchange.
|
||||||
|
|
||||||
|
When the Program is made available in source code form:
|
||||||
|
|
||||||
|
a) it must be made available under this Agreement; and
|
||||||
|
b) a copy of this Agreement must be included with each copy of the Program.
|
||||||
|
Contributors may not remove or alter any copyright notices contained
|
||||||
|
within the Program.
|
||||||
|
|
||||||
|
Each Contributor must identify itself as the originator of its Contribution,
|
||||||
|
if any, in a manner that reasonably allows subsequent Recipients to identify
|
||||||
|
the originator of the Contribution.
|
||||||
|
|
||||||
|
4. COMMERCIAL DISTRIBUTION
|
||||||
|
|
||||||
|
Commercial distributors of software may accept certain responsibilities with
|
||||||
|
respect to end users, business partners and the like. While this license is
|
||||||
|
intended to facilitate the commercial use of the Program, the Contributor
|
||||||
|
who includes the Program in a commercial product offering should do so in a
|
||||||
|
manner which does not create potential liability for other Contributors.
|
||||||
|
Therefore, if a Contributor includes the Program in a commercial product
|
||||||
|
offering, such Contributor ("Commercial Contributor") hereby agrees to
|
||||||
|
defend and indemnify every other Contributor ("Indemnified Contributor")
|
||||||
|
against any losses, damages and costs (collectively "Losses") arising from
|
||||||
|
claims, lawsuits and other legal actions brought by a third party against
|
||||||
|
the Indemnified Contributor to the extent caused by the acts or omissions
|
||||||
|
of such Commercial Contributor in connection with its distribution of the
|
||||||
|
Program in a commercial product offering. The obligations in this section
|
||||||
|
do not apply to any claims or Losses relating to any actual or alleged
|
||||||
|
intellectual property infringement. In order to qualify, an Indemnified
|
||||||
|
Contributor must: a) promptly notify the Commercial Contributor in writing
|
||||||
|
of such claim, and b) allow the Commercial Contributor to control, and
|
||||||
|
cooperate with the Commercial Contributor in, the defense and any related
|
||||||
|
settlement negotiations. The Indemnified Contributor may participate in any
|
||||||
|
such claim at its own expense.
|
||||||
|
|
||||||
|
For example, a Contributor might include the Program in a commercial product
|
||||||
|
offering, Product X. That Contributor is then a Commercial Contributor. If
|
||||||
|
that Commercial Contributor then makes performance claims, or offers
|
||||||
|
warranties related to Product X, those performance claims and warranties are
|
||||||
|
such Commercial Contributor's responsibility alone. Under this section, the
|
||||||
|
Commercial Contributor would have to defend claims against the other
|
||||||
|
Contributors related to those performance claims and warranties, and if a
|
||||||
|
court requires any other Contributor to pay any damages as a result, the
|
||||||
|
Commercial Contributor must pay those damages.
|
||||||
|
|
||||||
|
5. NO WARRANTY
|
||||||
|
|
||||||
|
EXCEPT AS EXPRESSLY SET FORTH IN THIS AGREEMENT, THE PROGRAM IS PROVIDED ON
|
||||||
|
AN "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, EITHER
|
||||||
|
EXPRESS OR IMPLIED INCLUDING, WITHOUT LIMITATION, ANY WARRANTIES OR
|
||||||
|
CONDITIONS OF TITLE, NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A
|
||||||
|
PARTICULAR PURPOSE. Each Recipient is solely responsible for determining the
|
||||||
|
appropriateness of using and distributing the Program and assumes all risks
|
||||||
|
associated with its exercise of rights under this Agreement , including but
|
||||||
|
not limited to the risks and costs of program errors, compliance with
|
||||||
|
applicable laws, damage to or loss of data, programs or equipment, and
|
||||||
|
unavailability or interruption of operations.
|
||||||
|
|
||||||
|
6. DISCLAIMER OF LIABILITY
|
||||||
|
|
||||||
|
EXCEPT AS EXPRESSLY SET FORTH IN THIS AGREEMENT, NEITHER RECIPIENT NOR ANY
|
||||||
|
CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING WITHOUT LIMITATION
|
||||||
|
LOST PROFITS), HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OR DISTRIBUTION OF THE PROGRAM OR THE
|
||||||
|
EXERCISE OF ANY RIGHTS GRANTED HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY
|
||||||
|
OF SUCH DAMAGES.
|
||||||
|
|
||||||
|
7. GENERAL
|
||||||
|
|
||||||
|
If any provision of this Agreement is invalid or unenforceable under
|
||||||
|
applicable law, it shall not affect the validity or enforceability of the
|
||||||
|
remainder of the terms of this Agreement, and without further action by the
|
||||||
|
parties hereto, such provision shall be reformed to the minimum extent
|
||||||
|
necessary to make such provision valid and enforceable.
|
||||||
|
|
||||||
|
If Recipient institutes patent litigation against any entity (including a
|
||||||
|
cross-claim or counterclaim in a lawsuit) alleging that the Program itself
|
||||||
|
(excluding combinations of the Program with other software or hardware)
|
||||||
|
infringes such Recipient's patent(s), then such Recipient's rights granted
|
||||||
|
under Section 2(b) shall terminate as of the date such litigation is filed.
|
||||||
|
|
||||||
|
All Recipient's rights under this Agreement shall terminate if it fails to
|
||||||
|
comply with any of the material terms or conditions of this Agreement and
|
||||||
|
does not cure such failure in a reasonable period of time after becoming
|
||||||
|
aware of such noncompliance. If all Recipient's rights under this Agreement
|
||||||
|
terminate, Recipient agrees to cease use and distribution of the Program as
|
||||||
|
soon as reasonably practicable. However, Recipient's obligations under this
|
||||||
|
Agreement and any licenses granted by Recipient relating to the Program
|
||||||
|
shall continue and survive.
|
||||||
|
|
||||||
|
Everyone is permitted to copy and distribute copies of this Agreement, but
|
||||||
|
in order to avoid inconsistency the Agreement is copyrighted and may only
|
||||||
|
be modified in the following manner. The Agreement Steward reserves the
|
||||||
|
right to publish new versions (including revisions) of this Agreement from
|
||||||
|
time to time. No one other than the Agreement Steward has the right to
|
||||||
|
modify this Agreement. The Eclipse Foundation is the initial Agreement
|
||||||
|
Steward. The Eclipse Foundation may assign the responsibility to serve as
|
||||||
|
the Agreement Steward to a suitable separate entity. Each new version of
|
||||||
|
the Agreement will be given a distinguishing version number. The Program
|
||||||
|
(including Contributions) may always be distributed subject to the version
|
||||||
|
of the Agreement under which it was received. In addition, after a new
|
||||||
|
version of the Agreement is published, Contributor may elect to distribute
|
||||||
|
the Program (including its Contributions) under the new version. Except as
|
||||||
|
expressly stated in Sections 2(a) and 2(b) above, Recipient receives no
|
||||||
|
rights or licenses to the intellectual property of any Contributor under
|
||||||
|
this Agreement, whether expressly, by implication, estoppel or otherwise.
|
||||||
|
All rights in the Program not expressly granted under this Agreement are
|
||||||
|
reserved.
|
||||||
|
|
||||||
|
This Agreement is governed by the laws of the State of New York and the
|
||||||
|
intellectual property laws of the United States of America. No party to this
|
||||||
|
Agreement will bring a legal action under this Agreement more than one year
|
||||||
|
after the cause of action arose. Each party waives its rights to a jury
|
||||||
|
trial in any resulting litigation.
|
||||||
|
|
||||||
|
Hamcrest library (hamcrest-*.jar) & CuvesAPI / Curve API
|
||||||
|
|
||||||
|
BSD License
|
||||||
|
|
||||||
|
Copyright (c) 2000-2006, www.hamcrest.org
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
Redistributions of source code must retain the above copyright notice, this
|
||||||
|
list of conditions and the following disclaimer. Redistributions in binary
|
||||||
|
form must reproduce the above copyright notice, this list of conditions and
|
||||||
|
the following disclaimer in the documentation and/or other materials
|
||||||
|
provided with the distribution.
|
||||||
|
|
||||||
|
Neither the name of Hamcrest nor the names of its contributors may be used
|
||||||
|
to endorse or promote products derived from this software without specific
|
||||||
|
prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
SLF4J library (slf4j-api-*.jar)
|
||||||
|
|
||||||
|
Copyright (c) 2004-2013 QOS.ch
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
a copy of this software and associated documentation files (the
|
||||||
|
"Software"), to deal in the Software without restriction, including
|
||||||
|
without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be
|
||||||
|
included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
|
inbot-utils (https://github.com/Inbot/inbot-utils)
|
||||||
|
|
||||||
|
The MIT License (MIT)
|
||||||
|
|
||||||
|
Copyright (c) 2015 Inbot
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
@ -0,0 +1,537 @@
|
|||||||
|
|
||||||
|
Apache License
|
||||||
|
Version 2.0, January 2004
|
||||||
|
http://www.apache.org/licenses/
|
||||||
|
|
||||||
|
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||||
|
|
||||||
|
1. Definitions.
|
||||||
|
|
||||||
|
"License" shall mean the terms and conditions for use, reproduction,
|
||||||
|
and distribution as defined by Sections 1 through 9 of this document.
|
||||||
|
|
||||||
|
"Licensor" shall mean the copyright owner or entity authorized by
|
||||||
|
the copyright owner that is granting the License.
|
||||||
|
|
||||||
|
"Legal Entity" shall mean the union of the acting entity and all
|
||||||
|
other entities that control, are controlled by, or are under common
|
||||||
|
control with that entity. For the purposes of this definition,
|
||||||
|
"control" means (i) the power, direct or indirect, to cause the
|
||||||
|
direction or management of such entity, whether by contract or
|
||||||
|
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||||
|
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||||
|
|
||||||
|
"You" (or "Your") shall mean an individual or Legal Entity
|
||||||
|
exercising permissions granted by this License.
|
||||||
|
|
||||||
|
"Source" form shall mean the preferred form for making modifications,
|
||||||
|
including but not limited to software source code, documentation
|
||||||
|
source, and configuration files.
|
||||||
|
|
||||||
|
"Object" form shall mean any form resulting from mechanical
|
||||||
|
transformation or translation of a Source form, including but
|
||||||
|
not limited to compiled object code, generated documentation,
|
||||||
|
and conversions to other media types.
|
||||||
|
|
||||||
|
"Work" shall mean the work of authorship, whether in Source or
|
||||||
|
Object form, made available under the License, as indicated by a
|
||||||
|
copyright notice that is included in or attached to the work
|
||||||
|
(an example is provided in the Appendix below).
|
||||||
|
|
||||||
|
"Derivative Works" shall mean any work, whether in Source or Object
|
||||||
|
form, that is based on (or derived from) the Work and for which the
|
||||||
|
editorial revisions, annotations, elaborations, or other modifications
|
||||||
|
represent, as a whole, an original work of authorship. For the purposes
|
||||||
|
of this License, Derivative Works shall not include works that remain
|
||||||
|
separable from, or merely link (or bind by name) to the interfaces of,
|
||||||
|
the Work and Derivative Works thereof.
|
||||||
|
|
||||||
|
"Contribution" shall mean any work of authorship, including
|
||||||
|
the original version of the Work and any modifications or additions
|
||||||
|
to that Work or Derivative Works thereof, that is intentionally
|
||||||
|
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||||
|
or by an individual or Legal Entity authorized to submit on behalf of
|
||||||
|
the copyright owner. For the purposes of this definition, "submitted"
|
||||||
|
means any form of electronic, verbal, or written communication sent
|
||||||
|
to the Licensor or its representatives, including but not limited to
|
||||||
|
communication on electronic mailing lists, source code control systems,
|
||||||
|
and issue tracking systems that are managed by, or on behalf of, the
|
||||||
|
Licensor for the purpose of discussing and improving the Work, but
|
||||||
|
excluding communication that is conspicuously marked or otherwise
|
||||||
|
designated in writing by the copyright owner as "Not a Contribution."
|
||||||
|
|
||||||
|
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||||
|
on behalf of whom a Contribution has been received by Licensor and
|
||||||
|
subsequently incorporated within the Work.
|
||||||
|
|
||||||
|
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||||
|
this License, each Contributor hereby grants to You a perpetual,
|
||||||
|
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||||
|
copyright license to reproduce, prepare Derivative Works of,
|
||||||
|
publicly display, publicly perform, sublicense, and distribute the
|
||||||
|
Work and such Derivative Works in Source or Object form.
|
||||||
|
|
||||||
|
3. Grant of Patent License. Subject to the terms and conditions of
|
||||||
|
this License, each Contributor hereby grants to You a perpetual,
|
||||||
|
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||||
|
(except as stated in this section) patent license to make, have made,
|
||||||
|
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||||
|
where such license applies only to those patent claims licensable
|
||||||
|
by such Contributor that are necessarily infringed by their
|
||||||
|
Contribution(s) alone or by combination of their Contribution(s)
|
||||||
|
with the Work to which such Contribution(s) was submitted. If You
|
||||||
|
institute patent litigation against any entity (including a
|
||||||
|
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||||
|
or a Contribution incorporated within the Work constitutes direct
|
||||||
|
or contributory patent infringement, then any patent licenses
|
||||||
|
granted to You under this License for that Work shall terminate
|
||||||
|
as of the date such litigation is filed.
|
||||||
|
|
||||||
|
4. Redistribution. You may reproduce and distribute copies of the
|
||||||
|
Work or Derivative Works thereof in any medium, with or without
|
||||||
|
modifications, and in Source or Object form, provided that You
|
||||||
|
meet the following conditions:
|
||||||
|
|
||||||
|
(a) You must give any other recipients of the Work or
|
||||||
|
Derivative Works a copy of this License; and
|
||||||
|
|
||||||
|
(b) You must cause any modified files to carry prominent notices
|
||||||
|
stating that You changed the files; and
|
||||||
|
|
||||||
|
(c) You must retain, in the Source form of any Derivative Works
|
||||||
|
that You distribute, all copyright, patent, trademark, and
|
||||||
|
attribution notices from the Source form of the Work,
|
||||||
|
excluding those notices that do not pertain to any part of
|
||||||
|
the Derivative Works; and
|
||||||
|
|
||||||
|
(d) If the Work includes a "NOTICE" text file as part of its
|
||||||
|
distribution, then any Derivative Works that You distribute must
|
||||||
|
include a readable copy of the attribution notices contained
|
||||||
|
within such NOTICE file, excluding those notices that do not
|
||||||
|
pertain to any part of the Derivative Works, in at least one
|
||||||
|
of the following places: within a NOTICE text file distributed
|
||||||
|
as part of the Derivative Works; within the Source form or
|
||||||
|
documentation, if provided along with the Derivative Works; or,
|
||||||
|
within a display generated by the Derivative Works, if and
|
||||||
|
wherever such third-party notices normally appear. The contents
|
||||||
|
of the NOTICE file are for informational purposes only and
|
||||||
|
do not modify the License. You may add Your own attribution
|
||||||
|
notices within Derivative Works that You distribute, alongside
|
||||||
|
or as an addendum to the NOTICE text from the Work, provided
|
||||||
|
that such additional attribution notices cannot be construed
|
||||||
|
as modifying the License.
|
||||||
|
|
||||||
|
You may add Your own copyright statement to Your modifications and
|
||||||
|
may provide additional or different license terms and conditions
|
||||||
|
for use, reproduction, or distribution of Your modifications, or
|
||||||
|
for any such Derivative Works as a whole, provided Your use,
|
||||||
|
reproduction, and distribution of the Work otherwise complies with
|
||||||
|
the conditions stated in this License.
|
||||||
|
|
||||||
|
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||||
|
any Contribution intentionally submitted for inclusion in the Work
|
||||||
|
by You to the Licensor shall be under the terms and conditions of
|
||||||
|
this License, without any additional terms or conditions.
|
||||||
|
Notwithstanding the above, nothing herein shall supersede or modify
|
||||||
|
the terms of any separate license agreement you may have executed
|
||||||
|
with Licensor regarding such Contributions.
|
||||||
|
|
||||||
|
6. Trademarks. This License does not grant permission to use the trade
|
||||||
|
names, trademarks, service marks, or product names of the Licensor,
|
||||||
|
except as required for reasonable and customary use in describing the
|
||||||
|
origin of the Work and reproducing the content of the NOTICE file.
|
||||||
|
|
||||||
|
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||||
|
agreed to in writing, Licensor provides the Work (and each
|
||||||
|
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
implied, including, without limitation, any warranties or conditions
|
||||||
|
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||||
|
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||||
|
appropriateness of using or redistributing the Work and assume any
|
||||||
|
risks associated with Your exercise of permissions under this License.
|
||||||
|
|
||||||
|
8. Limitation of Liability. In no event and under no legal theory,
|
||||||
|
whether in tort (including negligence), contract, or otherwise,
|
||||||
|
unless required by applicable law (such as deliberate and grossly
|
||||||
|
negligent acts) or agreed to in writing, shall any Contributor be
|
||||||
|
liable to You for damages, including any direct, indirect, special,
|
||||||
|
incidental, or consequential damages of any character arising as a
|
||||||
|
result of this License or out of the use or inability to use the
|
||||||
|
Work (including but not limited to damages for loss of goodwill,
|
||||||
|
work stoppage, computer failure or malfunction, or any and all
|
||||||
|
other commercial damages or losses), even if such Contributor
|
||||||
|
has been advised of the possibility of such damages.
|
||||||
|
|
||||||
|
9. Accepting Warranty or Additional Liability. While redistributing
|
||||||
|
the Work or Derivative Works thereof, You may choose to offer,
|
||||||
|
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||||
|
or other liability obligations and/or rights consistent with this
|
||||||
|
License. However, in accepting such obligations, You may act only
|
||||||
|
on Your own behalf and on Your sole responsibility, not on behalf
|
||||||
|
of any other Contributor, and only if You agree to indemnify,
|
||||||
|
defend, and hold each Contributor harmless for any liability
|
||||||
|
incurred by, or claims asserted against, such Contributor by reason
|
||||||
|
of your accepting any such warranty or additional liability.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
APPENDIX: How to apply the Apache License to your work.
|
||||||
|
|
||||||
|
To apply the Apache License to your work, attach the following
|
||||||
|
boilerplate notice, with the fields enclosed by brackets "[]"
|
||||||
|
replaced with your own identifying information. (Don't include
|
||||||
|
the brackets!) The text should be enclosed in the appropriate
|
||||||
|
comment syntax for the file format. We also recommend that a
|
||||||
|
file or class name and description of purpose be included on the
|
||||||
|
same "printed page" as the copyright notice for easier
|
||||||
|
identification within third-party archives.
|
||||||
|
|
||||||
|
Copyright [yyyy] [name of copyright owner]
|
||||||
|
|
||||||
|
Licensed 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.
|
||||||
|
|
||||||
|
|
||||||
|
APACHE POI SUBCOMPONENTS:
|
||||||
|
|
||||||
|
Apache POI includes subcomponents with separate copyright notices and
|
||||||
|
license terms. Your use of these subcomponents is subject to the terms
|
||||||
|
and conditions of the following licenses:
|
||||||
|
|
||||||
|
|
||||||
|
Office Open XML schemas (ooxml-schemas-1.*.jar)
|
||||||
|
|
||||||
|
The Office Open XML schema definitions used by Apache POI are
|
||||||
|
a part of the Office Open XML ECMA Specification (ECMA-376, [1]).
|
||||||
|
As defined in section 9.4 of the ECMA bylaws [2], this specification
|
||||||
|
is available to all interested parties without restriction:
|
||||||
|
|
||||||
|
9.4 All documents when approved shall be made available to
|
||||||
|
all interested parties without restriction.
|
||||||
|
|
||||||
|
Furthermore, both Microsoft and Adobe have granted patent licenses
|
||||||
|
to this work [3,4,5].
|
||||||
|
|
||||||
|
[1] http://www.ecma-international.org/publications/standards/Ecma-376.htm
|
||||||
|
[2] http://www.ecma-international.org/memento/Ecmabylaws.htm
|
||||||
|
[3] http://www.microsoft.com/openspecifications/en/us/programs/osp/default.aspx
|
||||||
|
[4] http://www.ecma-international.org/publications/files/ECMA-ST/Ecma%20PATENT/
|
||||||
|
Patent%20statements%20ok/ECMA-376%20Edition%202%20Microsoft%20Patent%20Declaration.pdf
|
||||||
|
[5] http://www.ecma-international.org/publications/files/ECMA-ST/Ecma%20PATENT/
|
||||||
|
Patent%20statements%20ok/ECMA-376%20Adobe%20Patent%20Declaration.pdf
|
||||||
|
|
||||||
|
|
||||||
|
Bouncy Castle library (bcprov-*.jar, bcpg-*.jar, bcpkix-*.jar)
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to
|
||||||
|
deal in the Software without restriction, including without limitation the
|
||||||
|
rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
||||||
|
sell copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in
|
||||||
|
all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||||
|
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
||||||
|
IN THE SOFTWARE.
|
||||||
|
|
||||||
|
JUnit test library (junit-4.*.jar) & JaCoCo (*jacoco*)
|
||||||
|
|
||||||
|
Eclipse Public License - v 1.0
|
||||||
|
|
||||||
|
THE ACCOMPANYING PROGRAM IS PROVIDED UNDER THE TERMS OF THIS ECLIPSE PUBLIC
|
||||||
|
LICENSE ("AGREEMENT"). ANY USE, REPRODUCTION OR DISTRIBUTION OF THE PROGRAM
|
||||||
|
CONSTITUTES RECIPIENT'S ACCEPTANCE OF THIS AGREEMENT.
|
||||||
|
|
||||||
|
1. DEFINITIONS
|
||||||
|
|
||||||
|
"Contribution" means:
|
||||||
|
|
||||||
|
a) in the case of the initial Contributor, the initial code and documentation
|
||||||
|
distributed under this Agreement, and
|
||||||
|
b) in the case of each subsequent Contributor:
|
||||||
|
i) changes to the Program, and
|
||||||
|
ii) additions to the Program;
|
||||||
|
where such changes and/or additions to the Program originate from and are
|
||||||
|
distributed by that particular Contributor. A Contribution 'originates' from
|
||||||
|
a Contributor if it was added to the Program by such Contributor itself or
|
||||||
|
anyone acting on such Contributor's behalf. Contributions do not include
|
||||||
|
additions to the Program which: (i) are separate modules of software
|
||||||
|
distributed in conjunction with the Program under their own license agreement,
|
||||||
|
and (ii) are not derivative works of the Program.
|
||||||
|
|
||||||
|
"Contributor" means any person or entity that distributes the Program.
|
||||||
|
|
||||||
|
"Licensed Patents" mean patent claims licensable by a Contributor which are
|
||||||
|
necessarily infringed by the use or sale of its Contribution alone or when
|
||||||
|
combined with the Program.
|
||||||
|
|
||||||
|
"Program" means the Contributions distributed in accordance with this Agreement.
|
||||||
|
|
||||||
|
"Recipient" means anyone who receives the Program under this Agreement,
|
||||||
|
including all Contributors.
|
||||||
|
|
||||||
|
2. GRANT OF RIGHTS
|
||||||
|
|
||||||
|
a) Subject to the terms of this Agreement, each Contributor hereby grants
|
||||||
|
Recipient a non-exclusive, worldwide, royalty-free copyright license to
|
||||||
|
reproduce, prepare derivative works of, publicly display, publicly
|
||||||
|
perform, distribute and sublicense the Contribution of such Contributor,
|
||||||
|
if any, and such derivative works, in source code and object code form.
|
||||||
|
b) Subject to the terms of this Agreement, each Contributor hereby grants
|
||||||
|
Recipient a non-exclusive, worldwide, royalty-free patent license under
|
||||||
|
Licensed Patents to make, use, sell, offer to sell, import and otherwise
|
||||||
|
transfer the Contribution of such Contributor, if any, in source code
|
||||||
|
and object code form. This patent license shall apply to the combination
|
||||||
|
of the Contribution and the Program if, at the time the Contribution is
|
||||||
|
added by the Contributor, such addition of the Contribution causes such
|
||||||
|
combination to be covered by the Licensed Patents. The patent license
|
||||||
|
shall not apply to any other combinations which include the Contribution.
|
||||||
|
No hardware per se is licensed hereunder.
|
||||||
|
c) Recipient understands that although each Contributor grants the licenses
|
||||||
|
to its Contributions set forth herein, no assurances are provided by any
|
||||||
|
Contributor that the Program does not infringe the patent or other
|
||||||
|
intellectual property rights of any other entity. Each Contributor
|
||||||
|
disclaims any liability to Recipient for claims brought by any other
|
||||||
|
entity based on infringement of intellectual property rights or
|
||||||
|
otherwise. As a condition to exercising the rights and licenses granted
|
||||||
|
hereunder, each Recipient hereby assumes sole responsibility to secure
|
||||||
|
any other intellectual property rights needed, if any. For example, if
|
||||||
|
a third party patent license is required to allow Recipient to distribute
|
||||||
|
the Program, it is Recipient's responsibility to acquire that license
|
||||||
|
before distributing the Program.
|
||||||
|
d) Each Contributor represents that to its knowledge it has sufficient
|
||||||
|
copyright rights in its Contribution, if any, to grant the copyright
|
||||||
|
license set forth in this Agreement.
|
||||||
|
|
||||||
|
3. REQUIREMENTS
|
||||||
|
|
||||||
|
A Contributor may choose to distribute the Program in object code form under
|
||||||
|
its own license agreement, provided that:
|
||||||
|
|
||||||
|
a) it complies with the terms and conditions of this Agreement; and
|
||||||
|
b) its license agreement:
|
||||||
|
i) effectively disclaims on behalf of all Contributors all warranties and
|
||||||
|
conditions, express and implied, including warranties or conditions of
|
||||||
|
title and non-infringement, and implied warranties or conditions of
|
||||||
|
merchantability and fitness for a particular purpose;
|
||||||
|
ii) effectively excludes on behalf of all Contributors all liability for
|
||||||
|
damages, including direct, indirect, special, incidental and
|
||||||
|
consequential damages, such as lost profits;
|
||||||
|
iii) states that any provisions which differ from this Agreement are
|
||||||
|
offered by that Contributor alone and not by any other party; and
|
||||||
|
iv) states that source code for the Program is available from such
|
||||||
|
Contributor, and informs licensees how to obtain it in a reasonable
|
||||||
|
manner on or through a medium customarily used for software exchange.
|
||||||
|
|
||||||
|
When the Program is made available in source code form:
|
||||||
|
|
||||||
|
a) it must be made available under this Agreement; and
|
||||||
|
b) a copy of this Agreement must be included with each copy of the Program.
|
||||||
|
Contributors may not remove or alter any copyright notices contained
|
||||||
|
within the Program.
|
||||||
|
|
||||||
|
Each Contributor must identify itself as the originator of its Contribution,
|
||||||
|
if any, in a manner that reasonably allows subsequent Recipients to identify
|
||||||
|
the originator of the Contribution.
|
||||||
|
|
||||||
|
4. COMMERCIAL DISTRIBUTION
|
||||||
|
|
||||||
|
Commercial distributors of software may accept certain responsibilities with
|
||||||
|
respect to end users, business partners and the like. While this license is
|
||||||
|
intended to facilitate the commercial use of the Program, the Contributor
|
||||||
|
who includes the Program in a commercial product offering should do so in a
|
||||||
|
manner which does not create potential liability for other Contributors.
|
||||||
|
Therefore, if a Contributor includes the Program in a commercial product
|
||||||
|
offering, such Contributor ("Commercial Contributor") hereby agrees to
|
||||||
|
defend and indemnify every other Contributor ("Indemnified Contributor")
|
||||||
|
against any losses, damages and costs (collectively "Losses") arising from
|
||||||
|
claims, lawsuits and other legal actions brought by a third party against
|
||||||
|
the Indemnified Contributor to the extent caused by the acts or omissions
|
||||||
|
of such Commercial Contributor in connection with its distribution of the
|
||||||
|
Program in a commercial product offering. The obligations in this section
|
||||||
|
do not apply to any claims or Losses relating to any actual or alleged
|
||||||
|
intellectual property infringement. In order to qualify, an Indemnified
|
||||||
|
Contributor must: a) promptly notify the Commercial Contributor in writing
|
||||||
|
of such claim, and b) allow the Commercial Contributor to control, and
|
||||||
|
cooperate with the Commercial Contributor in, the defense and any related
|
||||||
|
settlement negotiations. The Indemnified Contributor may participate in any
|
||||||
|
such claim at its own expense.
|
||||||
|
|
||||||
|
For example, a Contributor might include the Program in a commercial product
|
||||||
|
offering, Product X. That Contributor is then a Commercial Contributor. If
|
||||||
|
that Commercial Contributor then makes performance claims, or offers
|
||||||
|
warranties related to Product X, those performance claims and warranties are
|
||||||
|
such Commercial Contributor's responsibility alone. Under this section, the
|
||||||
|
Commercial Contributor would have to defend claims against the other
|
||||||
|
Contributors related to those performance claims and warranties, and if a
|
||||||
|
court requires any other Contributor to pay any damages as a result, the
|
||||||
|
Commercial Contributor must pay those damages.
|
||||||
|
|
||||||
|
5. NO WARRANTY
|
||||||
|
|
||||||
|
EXCEPT AS EXPRESSLY SET FORTH IN THIS AGREEMENT, THE PROGRAM IS PROVIDED ON
|
||||||
|
AN "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, EITHER
|
||||||
|
EXPRESS OR IMPLIED INCLUDING, WITHOUT LIMITATION, ANY WARRANTIES OR
|
||||||
|
CONDITIONS OF TITLE, NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A
|
||||||
|
PARTICULAR PURPOSE. Each Recipient is solely responsible for determining the
|
||||||
|
appropriateness of using and distributing the Program and assumes all risks
|
||||||
|
associated with its exercise of rights under this Agreement , including but
|
||||||
|
not limited to the risks and costs of program errors, compliance with
|
||||||
|
applicable laws, damage to or loss of data, programs or equipment, and
|
||||||
|
unavailability or interruption of operations.
|
||||||
|
|
||||||
|
6. DISCLAIMER OF LIABILITY
|
||||||
|
|
||||||
|
EXCEPT AS EXPRESSLY SET FORTH IN THIS AGREEMENT, NEITHER RECIPIENT NOR ANY
|
||||||
|
CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING WITHOUT LIMITATION
|
||||||
|
LOST PROFITS), HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OR DISTRIBUTION OF THE PROGRAM OR THE
|
||||||
|
EXERCISE OF ANY RIGHTS GRANTED HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY
|
||||||
|
OF SUCH DAMAGES.
|
||||||
|
|
||||||
|
7. GENERAL
|
||||||
|
|
||||||
|
If any provision of this Agreement is invalid or unenforceable under
|
||||||
|
applicable law, it shall not affect the validity or enforceability of the
|
||||||
|
remainder of the terms of this Agreement, and without further action by the
|
||||||
|
parties hereto, such provision shall be reformed to the minimum extent
|
||||||
|
necessary to make such provision valid and enforceable.
|
||||||
|
|
||||||
|
If Recipient institutes patent litigation against any entity (including a
|
||||||
|
cross-claim or counterclaim in a lawsuit) alleging that the Program itself
|
||||||
|
(excluding combinations of the Program with other software or hardware)
|
||||||
|
infringes such Recipient's patent(s), then such Recipient's rights granted
|
||||||
|
under Section 2(b) shall terminate as of the date such litigation is filed.
|
||||||
|
|
||||||
|
All Recipient's rights under this Agreement shall terminate if it fails to
|
||||||
|
comply with any of the material terms or conditions of this Agreement and
|
||||||
|
does not cure such failure in a reasonable period of time after becoming
|
||||||
|
aware of such noncompliance. If all Recipient's rights under this Agreement
|
||||||
|
terminate, Recipient agrees to cease use and distribution of the Program as
|
||||||
|
soon as reasonably practicable. However, Recipient's obligations under this
|
||||||
|
Agreement and any licenses granted by Recipient relating to the Program
|
||||||
|
shall continue and survive.
|
||||||
|
|
||||||
|
Everyone is permitted to copy and distribute copies of this Agreement, but
|
||||||
|
in order to avoid inconsistency the Agreement is copyrighted and may only
|
||||||
|
be modified in the following manner. The Agreement Steward reserves the
|
||||||
|
right to publish new versions (including revisions) of this Agreement from
|
||||||
|
time to time. No one other than the Agreement Steward has the right to
|
||||||
|
modify this Agreement. The Eclipse Foundation is the initial Agreement
|
||||||
|
Steward. The Eclipse Foundation may assign the responsibility to serve as
|
||||||
|
the Agreement Steward to a suitable separate entity. Each new version of
|
||||||
|
the Agreement will be given a distinguishing version number. The Program
|
||||||
|
(including Contributions) may always be distributed subject to the version
|
||||||
|
of the Agreement under which it was received. In addition, after a new
|
||||||
|
version of the Agreement is published, Contributor may elect to distribute
|
||||||
|
the Program (including its Contributions) under the new version. Except as
|
||||||
|
expressly stated in Sections 2(a) and 2(b) above, Recipient receives no
|
||||||
|
rights or licenses to the intellectual property of any Contributor under
|
||||||
|
this Agreement, whether expressly, by implication, estoppel or otherwise.
|
||||||
|
All rights in the Program not expressly granted under this Agreement are
|
||||||
|
reserved.
|
||||||
|
|
||||||
|
This Agreement is governed by the laws of the State of New York and the
|
||||||
|
intellectual property laws of the United States of America. No party to this
|
||||||
|
Agreement will bring a legal action under this Agreement more than one year
|
||||||
|
after the cause of action arose. Each party waives its rights to a jury
|
||||||
|
trial in any resulting litigation.
|
||||||
|
|
||||||
|
Hamcrest library (hamcrest-*.jar) & CuvesAPI / Curve API
|
||||||
|
|
||||||
|
BSD License
|
||||||
|
|
||||||
|
Copyright (c) 2000-2006, www.hamcrest.org
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
Redistributions of source code must retain the above copyright notice, this
|
||||||
|
list of conditions and the following disclaimer. Redistributions in binary
|
||||||
|
form must reproduce the above copyright notice, this list of conditions and
|
||||||
|
the following disclaimer in the documentation and/or other materials
|
||||||
|
provided with the distribution.
|
||||||
|
|
||||||
|
Neither the name of Hamcrest nor the names of its contributors may be used
|
||||||
|
to endorse or promote products derived from this software without specific
|
||||||
|
prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
SLF4J library (slf4j-api-*.jar)
|
||||||
|
|
||||||
|
Copyright (c) 2004-2013 QOS.ch
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
a copy of this software and associated documentation files (the
|
||||||
|
"Software"), to deal in the Software without restriction, including
|
||||||
|
without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be
|
||||||
|
included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
|
inbot-utils (https://github.com/Inbot/inbot-utils)
|
||||||
|
|
||||||
|
The MIT License (MIT)
|
||||||
|
|
||||||
|
Copyright (c) 2015 Inbot
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
201
dolphinscheduler-dist/release-docs/licenses/LICENSE-xmlbeans.txt
Normal file
201
dolphinscheduler-dist/release-docs/licenses/LICENSE-xmlbeans.txt
Normal file
@ -0,0 +1,201 @@
|
|||||||
|
Apache License
|
||||||
|
Version 2.0, January 2004
|
||||||
|
http://www.apache.org/licenses/
|
||||||
|
|
||||||
|
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||||
|
|
||||||
|
1. Definitions.
|
||||||
|
|
||||||
|
"License" shall mean the terms and conditions for use, reproduction,
|
||||||
|
and distribution as defined by Sections 1 through 9 of this document.
|
||||||
|
|
||||||
|
"Licensor" shall mean the copyright owner or entity authorized by
|
||||||
|
the copyright owner that is granting the License.
|
||||||
|
|
||||||
|
"Legal Entity" shall mean the union of the acting entity and all
|
||||||
|
other entities that control, are controlled by, or are under common
|
||||||
|
control with that entity. For the purposes of this definition,
|
||||||
|
"control" means (i) the power, direct or indirect, to cause the
|
||||||
|
direction or management of such entity, whether by contract or
|
||||||
|
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||||
|
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||||
|
|
||||||
|
"You" (or "Your") shall mean an individual or Legal Entity
|
||||||
|
exercising permissions granted by this License.
|
||||||
|
|
||||||
|
"Source" form shall mean the preferred form for making modifications,
|
||||||
|
including but not limited to software source code, documentation
|
||||||
|
source, and configuration files.
|
||||||
|
|
||||||
|
"Object" form shall mean any form resulting from mechanical
|
||||||
|
transformation or translation of a Source form, including but
|
||||||
|
not limited to compiled object code, generated documentation,
|
||||||
|
and conversions to other media types.
|
||||||
|
|
||||||
|
"Work" shall mean the work of authorship, whether in Source or
|
||||||
|
Object form, made available under the License, as indicated by a
|
||||||
|
copyright notice that is included in or attached to the work
|
||||||
|
(an example is provided in the Appendix below).
|
||||||
|
|
||||||
|
"Derivative Works" shall mean any work, whether in Source or Object
|
||||||
|
form, that is based on (or derived from) the Work and for which the
|
||||||
|
editorial revisions, annotations, elaborations, or other modifications
|
||||||
|
represent, as a whole, an original work of authorship. For the purposes
|
||||||
|
of this License, Derivative Works shall not include works that remain
|
||||||
|
separable from, or merely link (or bind by name) to the interfaces of,
|
||||||
|
the Work and Derivative Works thereof.
|
||||||
|
|
||||||
|
"Contribution" shall mean any work of authorship, including
|
||||||
|
the original version of the Work and any modifications or additions
|
||||||
|
to that Work or Derivative Works thereof, that is intentionally
|
||||||
|
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||||
|
or by an individual or Legal Entity authorized to submit on behalf of
|
||||||
|
the copyright owner. For the purposes of this definition, "submitted"
|
||||||
|
means any form of electronic, verbal, or written communication sent
|
||||||
|
to the Licensor or its representatives, including but not limited to
|
||||||
|
communication on electronic mailing lists, source code control systems,
|
||||||
|
and issue tracking systems that are managed by, or on behalf of, the
|
||||||
|
Licensor for the purpose of discussing and improving the Work, but
|
||||||
|
excluding communication that is conspicuously marked or otherwise
|
||||||
|
designated in writing by the copyright owner as "Not a Contribution."
|
||||||
|
|
||||||
|
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||||
|
on behalf of whom a Contribution has been received by Licensor and
|
||||||
|
subsequently incorporated within the Work.
|
||||||
|
|
||||||
|
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||||
|
this License, each Contributor hereby grants to You a perpetual,
|
||||||
|
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||||
|
copyright license to reproduce, prepare Derivative Works of,
|
||||||
|
publicly display, publicly perform, sublicense, and distribute the
|
||||||
|
Work and such Derivative Works in Source or Object form.
|
||||||
|
|
||||||
|
3. Grant of Patent License. Subject to the terms and conditions of
|
||||||
|
this License, each Contributor hereby grants to You a perpetual,
|
||||||
|
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||||
|
(except as stated in this section) patent license to make, have made,
|
||||||
|
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||||
|
where such license applies only to those patent claims licensable
|
||||||
|
by such Contributor that are necessarily infringed by their
|
||||||
|
Contribution(s) alone or by combination of their Contribution(s)
|
||||||
|
with the Work to which such Contribution(s) was submitted. If You
|
||||||
|
institute patent litigation against any entity (including a
|
||||||
|
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||||
|
or a Contribution incorporated within the Work constitutes direct
|
||||||
|
or contributory patent infringement, then any patent licenses
|
||||||
|
granted to You under this License for that Work shall terminate
|
||||||
|
as of the date such litigation is filed.
|
||||||
|
|
||||||
|
4. Redistribution. You may reproduce and distribute copies of the
|
||||||
|
Work or Derivative Works thereof in any medium, with or without
|
||||||
|
modifications, and in Source or Object form, provided that You
|
||||||
|
meet the following conditions:
|
||||||
|
|
||||||
|
(a) You must give any other recipients of the Work or
|
||||||
|
Derivative Works a copy of this License; and
|
||||||
|
|
||||||
|
(b) You must cause any modified files to carry prominent notices
|
||||||
|
stating that You changed the files; and
|
||||||
|
|
||||||
|
(c) You must retain, in the Source form of any Derivative Works
|
||||||
|
that You distribute, all copyright, patent, trademark, and
|
||||||
|
attribution notices from the Source form of the Work,
|
||||||
|
excluding those notices that do not pertain to any part of
|
||||||
|
the Derivative Works; and
|
||||||
|
|
||||||
|
(d) If the Work includes a "NOTICE" text file as part of its
|
||||||
|
distribution, then any Derivative Works that You distribute must
|
||||||
|
include a readable copy of the attribution notices contained
|
||||||
|
within such NOTICE file, excluding those notices that do not
|
||||||
|
pertain to any part of the Derivative Works, in at least one
|
||||||
|
of the following places: within a NOTICE text file distributed
|
||||||
|
as part of the Derivative Works; within the Source form or
|
||||||
|
documentation, if provided along with the Derivative Works; or,
|
||||||
|
within a display generated by the Derivative Works, if and
|
||||||
|
wherever such third-party notices normally appear. The contents
|
||||||
|
of the NOTICE file are for informational purposes only and
|
||||||
|
do not modify the License. You may add Your own attribution
|
||||||
|
notices within Derivative Works that You distribute, alongside
|
||||||
|
or as an addendum to the NOTICE text from the Work, provided
|
||||||
|
that such additional attribution notices cannot be construed
|
||||||
|
as modifying the License.
|
||||||
|
|
||||||
|
You may add Your own copyright statement to Your modifications and
|
||||||
|
may provide additional or different license terms and conditions
|
||||||
|
for use, reproduction, or distribution of Your modifications, or
|
||||||
|
for any such Derivative Works as a whole, provided Your use,
|
||||||
|
reproduction, and distribution of the Work otherwise complies with
|
||||||
|
the conditions stated in this License.
|
||||||
|
|
||||||
|
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||||
|
any Contribution intentionally submitted for inclusion in the Work
|
||||||
|
by You to the Licensor shall be under the terms and conditions of
|
||||||
|
this License, without any additional terms or conditions.
|
||||||
|
Notwithstanding the above, nothing herein shall supersede or modify
|
||||||
|
the terms of any separate license agreement you may have executed
|
||||||
|
with Licensor regarding such Contributions.
|
||||||
|
|
||||||
|
6. Trademarks. This License does not grant permission to use the trade
|
||||||
|
names, trademarks, service marks, or product names of the Licensor,
|
||||||
|
except as required for reasonable and customary use in describing the
|
||||||
|
origin of the Work and reproducing the content of the NOTICE file.
|
||||||
|
|
||||||
|
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||||
|
agreed to in writing, Licensor provides the Work (and each
|
||||||
|
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
implied, including, without limitation, any warranties or conditions
|
||||||
|
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||||
|
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||||
|
appropriateness of using or redistributing the Work and assume any
|
||||||
|
risks associated with Your exercise of permissions under this License.
|
||||||
|
|
||||||
|
8. Limitation of Liability. In no event and under no legal theory,
|
||||||
|
whether in tort (including negligence), contract, or otherwise,
|
||||||
|
unless required by applicable law (such as deliberate and grossly
|
||||||
|
negligent acts) or agreed to in writing, shall any Contributor be
|
||||||
|
liable to You for damages, including any direct, indirect, special,
|
||||||
|
incidental, or consequential damages of any character arising as a
|
||||||
|
result of this License or out of the use or inability to use the
|
||||||
|
Work (including but not limited to damages for loss of goodwill,
|
||||||
|
work stoppage, computer failure or malfunction, or any and all
|
||||||
|
other commercial damages or losses), even if such Contributor
|
||||||
|
has been advised of the possibility of such damages.
|
||||||
|
|
||||||
|
9. Accepting Warranty or Additional Liability. While redistributing
|
||||||
|
the Work or Derivative Works thereof, You may choose to offer,
|
||||||
|
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||||
|
or other liability obligations and/or rights consistent with this
|
||||||
|
License. However, in accepting such obligations, You may act only
|
||||||
|
on Your own behalf and on Your sole responsibility, not on behalf
|
||||||
|
of any other Contributor, and only if You agree to indemnify,
|
||||||
|
defend, and hold each Contributor harmless for any liability
|
||||||
|
incurred by, or claims asserted against, such Contributor by reason
|
||||||
|
of your accepting any such warranty or additional liability.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
APPENDIX: How to apply the Apache License to your work.
|
||||||
|
|
||||||
|
To apply the Apache License to your work, attach the following
|
||||||
|
boilerplate notice, with the fields enclosed by brackets "[]"
|
||||||
|
replaced with your own identifying information. (Don't include
|
||||||
|
the brackets!) The text should be enclosed in the appropriate
|
||||||
|
comment syntax for the file format. We also recommend that a
|
||||||
|
file or class name and description of purpose be included on the
|
||||||
|
same "printed page" as the copyright notice for easier
|
||||||
|
identification within third-party archives.
|
||||||
|
|
||||||
|
Copyright [yyyy] [name of copyright owner]
|
||||||
|
|
||||||
|
Licensed 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.
|
@ -216,6 +216,7 @@
|
|||||||
<outputDirectory>lib</outputDirectory>
|
<outputDirectory>lib</outputDirectory>
|
||||||
<useProjectArtifact>true</useProjectArtifact>
|
<useProjectArtifact>true</useProjectArtifact>
|
||||||
<excludes>
|
<excludes>
|
||||||
|
<exclude>org.apache.dolphinscheduler:dolphinscheduler-dist</exclude>
|
||||||
<exclude>javax.servlet:servlet-api</exclude>
|
<exclude>javax.servlet:servlet-api</exclude>
|
||||||
<exclude>org.eclipse.jetty.aggregate:jetty-all</exclude>
|
<exclude>org.eclipse.jetty.aggregate:jetty-all</exclude>
|
||||||
<exclude>org.slf4j:slf4j-log4j12</exclude>
|
<exclude>org.slf4j:slf4j-log4j12</exclude>
|
||||||
|
@ -0,0 +1,37 @@
|
|||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.dolphinscheduler.remote.command.log;
|
||||||
|
|
||||||
|
import org.apache.dolphinscheduler.remote.command.Command;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import junit.framework.Assert;
|
||||||
|
|
||||||
|
public class RollViewLogRequestCommandTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testConvert2Command() {
|
||||||
|
RollViewLogRequestCommand rollViewLogRequestCommand = new RollViewLogRequestCommand();
|
||||||
|
rollViewLogRequestCommand.setPath("/opt/test");
|
||||||
|
rollViewLogRequestCommand.setSkipLineNum(1);
|
||||||
|
rollViewLogRequestCommand.setLimit(1);
|
||||||
|
Command command = rollViewLogRequestCommand.convert2Command();
|
||||||
|
Assert.assertNotNull(command);
|
||||||
|
}
|
||||||
|
}
|
@ -55,7 +55,7 @@ import org.apache.dolphinscheduler.dao.entity.TaskInstance;
|
|||||||
import org.apache.dolphinscheduler.dao.utils.DagHelper;
|
import org.apache.dolphinscheduler.dao.utils.DagHelper;
|
||||||
import org.apache.dolphinscheduler.remote.NettyRemotingClient;
|
import org.apache.dolphinscheduler.remote.NettyRemotingClient;
|
||||||
import org.apache.dolphinscheduler.server.master.config.MasterConfig;
|
import org.apache.dolphinscheduler.server.master.config.MasterConfig;
|
||||||
import org.apache.dolphinscheduler.server.utils.AlertManager;
|
import org.apache.dolphinscheduler.service.alert.ProcessAlertManager;
|
||||||
import org.apache.dolphinscheduler.service.process.ProcessService;
|
import org.apache.dolphinscheduler.service.process.ProcessService;
|
||||||
import org.apache.dolphinscheduler.service.quartz.cron.CronUtils;
|
import org.apache.dolphinscheduler.service.quartz.cron.CronUtils;
|
||||||
import org.apache.dolphinscheduler.service.queue.PeerTaskInstancePriorityQueue;
|
import org.apache.dolphinscheduler.service.queue.PeerTaskInstancePriorityQueue;
|
||||||
@ -148,7 +148,7 @@ public class MasterExecThread implements Runnable {
|
|||||||
/**
|
/**
|
||||||
* alert manager
|
* alert manager
|
||||||
*/
|
*/
|
||||||
private AlertManager alertManager;
|
private ProcessAlertManager processAlertManager;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* the object of DAG
|
* the object of DAG
|
||||||
@ -186,7 +186,7 @@ public class MasterExecThread implements Runnable {
|
|||||||
public MasterExecThread(ProcessInstance processInstance
|
public MasterExecThread(ProcessInstance processInstance
|
||||||
, ProcessService processService
|
, ProcessService processService
|
||||||
, NettyRemotingClient nettyRemotingClient
|
, NettyRemotingClient nettyRemotingClient
|
||||||
, AlertManager alertManager
|
, ProcessAlertManager processAlertManager
|
||||||
, MasterConfig masterConfig) {
|
, MasterConfig masterConfig) {
|
||||||
this.processService = processService;
|
this.processService = processService;
|
||||||
|
|
||||||
@ -196,7 +196,7 @@ public class MasterExecThread implements Runnable {
|
|||||||
this.taskExecService = ThreadUtils.newDaemonFixedThreadExecutor("Master-Task-Exec-Thread",
|
this.taskExecService = ThreadUtils.newDaemonFixedThreadExecutor("Master-Task-Exec-Thread",
|
||||||
masterTaskExecNum);
|
masterTaskExecNum);
|
||||||
this.nettyRemotingClient = nettyRemotingClient;
|
this.nettyRemotingClient = nettyRemotingClient;
|
||||||
this.alertManager = alertManager;
|
this.processAlertManager = processAlertManager;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -367,7 +367,7 @@ public class MasterExecThread implements Runnable {
|
|||||||
}
|
}
|
||||||
List<TaskInstance> taskInstances = processService.findValidTaskListByProcessId(processInstance.getId());
|
List<TaskInstance> taskInstances = processService.findValidTaskListByProcessId(processInstance.getId());
|
||||||
ProjectUser projectUser = processService.queryProjectWithUserByProcessInstanceId(processInstance.getId());
|
ProjectUser projectUser = processService.queryProjectWithUserByProcessInstanceId(processInstance.getId());
|
||||||
alertManager.sendAlertProcessInstance(processInstance, taskInstances, projectUser);
|
processAlertManager.sendAlertProcessInstance(processInstance, taskInstances, projectUser);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -928,10 +928,9 @@ public class MasterExecThread implements Runnable {
|
|||||||
|
|
||||||
// send warning email if process time out.
|
// send warning email if process time out.
|
||||||
if (!sendTimeWarning && checkProcessTimeOut(processInstance)) {
|
if (!sendTimeWarning && checkProcessTimeOut(processInstance)) {
|
||||||
alertManager.sendProcessTimeoutAlert(processInstance,
|
processAlertManager.sendProcessTimeoutAlert(processInstance,
|
||||||
processService.findProcessDefinition(processInstance.getProcessDefinitionCode(),
|
processService.findProcessDefinition(processInstance.getProcessDefinitionCode(),
|
||||||
processInstance.getProcessDefinitionVersion()));
|
processInstance.getProcessDefinitionVersion());
|
||||||
|
|
||||||
sendTimeWarning = true;
|
sendTimeWarning = true;
|
||||||
}
|
}
|
||||||
for (Map.Entry<MasterBaseTaskExecThread, Future<Boolean>> entry : activeTaskNode.entrySet()) {
|
for (Map.Entry<MasterBaseTaskExecThread, Future<Boolean>> entry : activeTaskNode.entrySet()) {
|
||||||
@ -993,7 +992,7 @@ public class MasterExecThread implements Runnable {
|
|||||||
}
|
}
|
||||||
// send alert
|
// send alert
|
||||||
if (CollectionUtils.isNotEmpty(this.recoverToleranceFaultTaskList)) {
|
if (CollectionUtils.isNotEmpty(this.recoverToleranceFaultTaskList)) {
|
||||||
alertManager.sendAlertWorkerToleranceFault(processInstance, recoverToleranceFaultTaskList);
|
processAlertManager.sendAlertWorkerToleranceFault(processInstance, recoverToleranceFaultTaskList);
|
||||||
this.recoverToleranceFaultTaskList.clear();
|
this.recoverToleranceFaultTaskList.clear();
|
||||||
}
|
}
|
||||||
// updateProcessInstance completed task status
|
// updateProcessInstance completed task status
|
||||||
|
@ -28,7 +28,7 @@ import org.apache.dolphinscheduler.remote.NettyRemotingClient;
|
|||||||
import org.apache.dolphinscheduler.remote.config.NettyClientConfig;
|
import org.apache.dolphinscheduler.remote.config.NettyClientConfig;
|
||||||
import org.apache.dolphinscheduler.server.master.config.MasterConfig;
|
import org.apache.dolphinscheduler.server.master.config.MasterConfig;
|
||||||
import org.apache.dolphinscheduler.server.master.zk.ZKMasterClient;
|
import org.apache.dolphinscheduler.server.master.zk.ZKMasterClient;
|
||||||
import org.apache.dolphinscheduler.server.utils.AlertManager;
|
import org.apache.dolphinscheduler.service.alert.ProcessAlertManager;
|
||||||
import org.apache.dolphinscheduler.service.process.ProcessService;
|
import org.apache.dolphinscheduler.service.process.ProcessService;
|
||||||
|
|
||||||
import org.apache.curator.framework.imps.CuratorFrameworkState;
|
import org.apache.curator.framework.imps.CuratorFrameworkState;
|
||||||
@ -76,7 +76,8 @@ public class MasterSchedulerService extends Thread {
|
|||||||
/**
|
/**
|
||||||
* alert manager
|
* alert manager
|
||||||
*/
|
*/
|
||||||
private AlertManager alertManager = new AlertManager();
|
@Autowired
|
||||||
|
private ProcessAlertManager processAlertManager;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* netty remoting client
|
* netty remoting client
|
||||||
@ -165,7 +166,7 @@ public class MasterSchedulerService extends Thread {
|
|||||||
processInstance
|
processInstance
|
||||||
, processService
|
, processService
|
||||||
, nettyRemotingClient
|
, nettyRemotingClient
|
||||||
, alertManager
|
, processAlertManager
|
||||||
, masterConfig));
|
, masterConfig));
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
@ -14,6 +14,7 @@
|
|||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.apache.dolphinscheduler.server.utils;
|
package org.apache.dolphinscheduler.server.utils;
|
||||||
|
|
||||||
import org.apache.dolphinscheduler.common.Constants;
|
import org.apache.dolphinscheduler.common.Constants;
|
||||||
@ -22,19 +23,21 @@ import org.apache.dolphinscheduler.common.enums.DependentRelation;
|
|||||||
import org.apache.dolphinscheduler.common.enums.ExecutionStatus;
|
import org.apache.dolphinscheduler.common.enums.ExecutionStatus;
|
||||||
import org.apache.dolphinscheduler.common.model.DateInterval;
|
import org.apache.dolphinscheduler.common.model.DateInterval;
|
||||||
import org.apache.dolphinscheduler.common.model.DependentItem;
|
import org.apache.dolphinscheduler.common.model.DependentItem;
|
||||||
import org.apache.dolphinscheduler.common.model.TaskNode;
|
|
||||||
import org.apache.dolphinscheduler.common.utils.CollectionUtils;
|
|
||||||
import org.apache.dolphinscheduler.common.utils.DependentUtils;
|
import org.apache.dolphinscheduler.common.utils.DependentUtils;
|
||||||
import org.apache.dolphinscheduler.dao.entity.ProcessInstance;
|
import org.apache.dolphinscheduler.dao.entity.ProcessInstance;
|
||||||
import org.apache.dolphinscheduler.dao.entity.TaskInstance;
|
import org.apache.dolphinscheduler.dao.entity.TaskInstance;
|
||||||
import org.apache.dolphinscheduler.dao.utils.DagHelper;
|
|
||||||
import org.apache.dolphinscheduler.service.bean.SpringApplicationContext;
|
import org.apache.dolphinscheduler.service.bean.SpringApplicationContext;
|
||||||
import org.apache.dolphinscheduler.service.process.ProcessService;
|
import org.apache.dolphinscheduler.service.process.ProcessService;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.util.*;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* dependent item execute
|
* dependent item execute
|
||||||
*/
|
*/
|
||||||
@ -74,7 +77,7 @@ public class DependentExecute {
|
|||||||
* @param itemList item list
|
* @param itemList item list
|
||||||
* @param relation relation
|
* @param relation relation
|
||||||
*/
|
*/
|
||||||
public DependentExecute(List<DependentItem> itemList, DependentRelation relation){
|
public DependentExecute(List<DependentItem> itemList, DependentRelation relation) {
|
||||||
this.dependItemList = itemList;
|
this.dependItemList = itemList;
|
||||||
this.relation = relation;
|
this.relation = relation;
|
||||||
}
|
}
|
||||||
@ -85,7 +88,7 @@ public class DependentExecute {
|
|||||||
* @param currentTime current time
|
* @param currentTime current time
|
||||||
* @return DependResult
|
* @return DependResult
|
||||||
*/
|
*/
|
||||||
private DependResult getDependentResultForItem(DependentItem dependentItem, Date currentTime){
|
private DependResult getDependentResultForItem(DependentItem dependentItem, Date currentTime) {
|
||||||
List<DateInterval> dateIntervals = DependentUtils.getDateIntervalList(currentTime, dependentItem.getDateValue());
|
List<DateInterval> dateIntervals = DependentUtils.getDateIntervalList(currentTime, dependentItem.getDateValue());
|
||||||
return calculateResultForTasks(dependentItem, dateIntervals);
|
return calculateResultForTasks(dependentItem, dateIntervals);
|
||||||
}
|
}
|
||||||
@ -107,12 +110,12 @@ public class DependentExecute {
|
|||||||
return DependResult.WAITING;
|
return DependResult.WAITING;
|
||||||
}
|
}
|
||||||
// need to check workflow for updates, so get all task and check the task state
|
// need to check workflow for updates, so get all task and check the task state
|
||||||
if(dependentItem.getDepTasks().equals(Constants.DEPENDENT_ALL)){
|
if (dependentItem.getDepTasks().equals(Constants.DEPENDENT_ALL)) {
|
||||||
result = dependResultByProcessInstance(processInstance);
|
result = dependResultByProcessInstance(processInstance);
|
||||||
}else{
|
} else {
|
||||||
result = getDependTaskResult(dependentItem.getDepTasks(),processInstance);
|
result = getDependTaskResult(dependentItem.getDepTasks(),processInstance);
|
||||||
}
|
}
|
||||||
if(result != DependResult.SUCCESS){
|
if (result != DependResult.SUCCESS) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -123,11 +126,11 @@ public class DependentExecute {
|
|||||||
* depend type = depend_all
|
* depend type = depend_all
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
private DependResult dependResultByProcessInstance(ProcessInstance processInstance){
|
private DependResult dependResultByProcessInstance(ProcessInstance processInstance) {
|
||||||
if(!processInstance.getState().typeIsFinished()){
|
if (!processInstance.getState().typeIsFinished()) {
|
||||||
return DependResult.WAITING;
|
return DependResult.WAITING;
|
||||||
}
|
}
|
||||||
if(processInstance.getState().typeIsSuccess()){
|
if (processInstance.getState().typeIsSuccess()) {
|
||||||
return DependResult.SUCCESS;
|
return DependResult.SUCCESS;
|
||||||
}
|
}
|
||||||
return DependResult.FAILED;
|
return DependResult.FAILED;
|
||||||
@ -144,22 +147,22 @@ public class DependentExecute {
|
|||||||
TaskInstance taskInstance = null;
|
TaskInstance taskInstance = null;
|
||||||
List<TaskInstance> taskInstanceList = processService.findValidTaskListByProcessId(processInstance.getId());
|
List<TaskInstance> taskInstanceList = processService.findValidTaskListByProcessId(processInstance.getId());
|
||||||
|
|
||||||
for(TaskInstance task : taskInstanceList){
|
for (TaskInstance task : taskInstanceList) {
|
||||||
if(task.getName().equals(taskName)){
|
if (task.getName().equals(taskName)) {
|
||||||
taskInstance = task;
|
taskInstance = task;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(taskInstance == null){
|
if (taskInstance == null) {
|
||||||
// cannot find task in the process instance
|
// cannot find task in the process instance
|
||||||
// maybe because process instance is running or failed.
|
// maybe because process instance is running or failed.
|
||||||
if(processInstance.getState().typeIsFinished()){
|
if (processInstance.getState().typeIsFinished()) {
|
||||||
result = DependResult.FAILED;
|
result = DependResult.FAILED;
|
||||||
}else{
|
} else {
|
||||||
return DependResult.WAITING;
|
return DependResult.WAITING;
|
||||||
}
|
}
|
||||||
}else{
|
} else {
|
||||||
result = getDependResultByState(taskInstance.getState());
|
result = getDependResultByState(taskInstance.getState());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -185,15 +188,14 @@ public class DependentExecute {
|
|||||||
|
|
||||||
ProcessInstance lastManualProcess = processService.findLastManualProcessInterval(definitionCode, dateInterval);
|
ProcessInstance lastManualProcess = processService.findLastManualProcessInterval(definitionCode, dateInterval);
|
||||||
|
|
||||||
if(lastManualProcess ==null){
|
if (lastManualProcess == null) {
|
||||||
return lastSchedulerProcess;
|
return lastSchedulerProcess;
|
||||||
}
|
}
|
||||||
if(lastSchedulerProcess == null){
|
if (lastSchedulerProcess == null) {
|
||||||
return lastManualProcess;
|
return lastManualProcess;
|
||||||
}
|
}
|
||||||
|
|
||||||
return (lastManualProcess.getEndTime().after(lastSchedulerProcess.getEndTime()))?
|
return (lastManualProcess.getEndTime().after(lastSchedulerProcess.getEndTime())) ? lastManualProcess : lastSchedulerProcess;
|
||||||
lastManualProcess : lastSchedulerProcess;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -203,11 +205,11 @@ public class DependentExecute {
|
|||||||
*/
|
*/
|
||||||
private DependResult getDependResultByState(ExecutionStatus state) {
|
private DependResult getDependResultByState(ExecutionStatus state) {
|
||||||
|
|
||||||
if(!state.typeIsFinished()){
|
if (!state.typeIsFinished()) {
|
||||||
return DependResult.WAITING;
|
return DependResult.WAITING;
|
||||||
}else if(state.typeIsSuccess()){
|
} else if (state.typeIsSuccess()) {
|
||||||
return DependResult.SUCCESS;
|
return DependResult.SUCCESS;
|
||||||
}else{
|
} else {
|
||||||
return DependResult.FAILED;
|
return DependResult.FAILED;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -219,11 +221,11 @@ public class DependentExecute {
|
|||||||
*/
|
*/
|
||||||
private DependResult getDependResultByProcessStateWhenTaskNull(ExecutionStatus state) {
|
private DependResult getDependResultByProcessStateWhenTaskNull(ExecutionStatus state) {
|
||||||
|
|
||||||
if(state.typeIsRunning()
|
if (state.typeIsRunning()
|
||||||
|| state == ExecutionStatus.SUBMITTED_SUCCESS
|
|| state == ExecutionStatus.SUBMITTED_SUCCESS
|
||||||
|| state == ExecutionStatus.WAITTING_THREAD){
|
|| state == ExecutionStatus.WAITTING_THREAD) {
|
||||||
return DependResult.WAITING;
|
return DependResult.WAITING;
|
||||||
}else{
|
} else {
|
||||||
return DependResult.FAILED;
|
return DependResult.FAILED;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -233,8 +235,8 @@ public class DependentExecute {
|
|||||||
* @param currentTime current time
|
* @param currentTime current time
|
||||||
* @return boolean
|
* @return boolean
|
||||||
*/
|
*/
|
||||||
public boolean finish(Date currentTime){
|
public boolean finish(Date currentTime) {
|
||||||
if(modelDependResult == DependResult.WAITING){
|
if (modelDependResult == DependResult.WAITING) {
|
||||||
modelDependResult = getModelDependResult(currentTime);
|
modelDependResult = getModelDependResult(currentTime);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -246,13 +248,13 @@ public class DependentExecute {
|
|||||||
* @param currentTime current time
|
* @param currentTime current time
|
||||||
* @return DependResult
|
* @return DependResult
|
||||||
*/
|
*/
|
||||||
public DependResult getModelDependResult(Date currentTime){
|
public DependResult getModelDependResult(Date currentTime) {
|
||||||
|
|
||||||
List<DependResult> dependResultList = new ArrayList<>();
|
List<DependResult> dependResultList = new ArrayList<>();
|
||||||
|
|
||||||
for(DependentItem dependentItem : dependItemList){
|
for (DependentItem dependentItem : dependItemList) {
|
||||||
DependResult dependResult = getDependResultForItem(dependentItem, currentTime);
|
DependResult dependResult = getDependResultForItem(dependentItem, currentTime);
|
||||||
if(dependResult != DependResult.WAITING){
|
if (dependResult != DependResult.WAITING) {
|
||||||
dependResultMap.put(dependentItem.getKey(), dependResult);
|
dependResultMap.put(dependentItem.getKey(), dependResult);
|
||||||
}
|
}
|
||||||
dependResultList.add(dependResult);
|
dependResultList.add(dependResult);
|
||||||
@ -267,15 +269,15 @@ public class DependentExecute {
|
|||||||
* @param currentTime current time
|
* @param currentTime current time
|
||||||
* @return DependResult
|
* @return DependResult
|
||||||
*/
|
*/
|
||||||
private DependResult getDependResultForItem(DependentItem item, Date currentTime){
|
private DependResult getDependResultForItem(DependentItem item, Date currentTime) {
|
||||||
String key = item.getKey();
|
String key = item.getKey();
|
||||||
if(dependResultMap.containsKey(key)){
|
if (dependResultMap.containsKey(key)) {
|
||||||
return dependResultMap.get(key);
|
return dependResultMap.get(key);
|
||||||
}
|
}
|
||||||
return getDependentResultForItem(item, currentTime);
|
return getDependentResultForItem(item, currentTime);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Map<String, DependResult> getDependResultMap(){
|
public Map<String, DependResult> getDependResultMap() {
|
||||||
return dependResultMap;
|
return dependResultMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -14,6 +14,7 @@
|
|||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.apache.dolphinscheduler.server.utils;
|
package org.apache.dolphinscheduler.server.utils;
|
||||||
|
|
||||||
import org.apache.dolphinscheduler.common.enums.CommandType;
|
import org.apache.dolphinscheduler.common.enums.CommandType;
|
||||||
@ -47,9 +48,8 @@ public class ParamUtils {
|
|||||||
Map<String,String> globalParamsMap,
|
Map<String,String> globalParamsMap,
|
||||||
Map<String,Property> localParams,
|
Map<String,Property> localParams,
|
||||||
CommandType commandType,
|
CommandType commandType,
|
||||||
Date scheduleTime){
|
Date scheduleTime) {
|
||||||
if (globalParams == null
|
if (globalParams == null && localParams == null) {
|
||||||
&& localParams == null){
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
// if it is a complement,
|
// if it is a complement,
|
||||||
@ -59,22 +59,22 @@ public class ParamUtils {
|
|||||||
.getBusinessTime(commandType,
|
.getBusinessTime(commandType,
|
||||||
scheduleTime);
|
scheduleTime);
|
||||||
|
|
||||||
if (globalParamsMap != null){
|
if (globalParamsMap != null) {
|
||||||
timeParams.putAll(globalParamsMap);
|
timeParams.putAll(globalParamsMap);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (globalParams != null && localParams != null){
|
if (globalParams != null && localParams != null) {
|
||||||
globalParams.putAll(localParams);
|
globalParams.putAll(localParams);
|
||||||
}else if (globalParams == null && localParams != null){
|
} else if (globalParams == null && localParams != null) {
|
||||||
globalParams = localParams;
|
globalParams = localParams;
|
||||||
}
|
}
|
||||||
Iterator<Map.Entry<String, Property>> iter = globalParams.entrySet().iterator();
|
Iterator<Map.Entry<String, Property>> iter = globalParams.entrySet().iterator();
|
||||||
while (iter.hasNext()){
|
while (iter.hasNext()) {
|
||||||
Map.Entry<String, Property> en = iter.next();
|
Map.Entry<String, Property> en = iter.next();
|
||||||
Property property = en.getValue();
|
Property property = en.getValue();
|
||||||
|
|
||||||
if (StringUtils.isNotEmpty(property.getValue())
|
if (StringUtils.isNotEmpty(property.getValue())
|
||||||
&& property.getValue().startsWith("$")){
|
&& property.getValue().startsWith("$")) {
|
||||||
/**
|
/**
|
||||||
* local parameter refers to global parameter with the same name
|
* local parameter refers to global parameter with the same name
|
||||||
* note: the global parameters of the process instance here are solidified parameters,
|
* note: the global parameters of the process instance here are solidified parameters,
|
||||||
@ -94,21 +94,20 @@ public class ParamUtils {
|
|||||||
* @param paramsMap params map
|
* @param paramsMap params map
|
||||||
* @return Map of converted
|
* @return Map of converted
|
||||||
*/
|
*/
|
||||||
public static Map<String,String> convert(Map<String,Property> paramsMap){
|
public static Map<String,String> convert(Map<String,Property> paramsMap) {
|
||||||
if(paramsMap == null){
|
if (paramsMap == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String,String> map = new HashMap<>();
|
Map<String,String> map = new HashMap<>();
|
||||||
Iterator<Map.Entry<String, Property>> iter = paramsMap.entrySet().iterator();
|
Iterator<Map.Entry<String, Property>> iter = paramsMap.entrySet().iterator();
|
||||||
while (iter.hasNext()){
|
while (iter.hasNext()) {
|
||||||
Map.Entry<String, Property> en = iter.next();
|
Map.Entry<String, Property> en = iter.next();
|
||||||
map.put(en.getKey(),en.getValue().getValue());
|
map.put(en.getKey(),en.getValue().getValue());
|
||||||
}
|
}
|
||||||
return map;
|
return map;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* get parameters map
|
* get parameters map
|
||||||
* @param definedParams definedParams
|
* @param definedParams definedParams
|
||||||
@ -118,9 +117,9 @@ public class ParamUtils {
|
|||||||
if (definedParams != null) {
|
if (definedParams != null) {
|
||||||
Map<String,Property> userDefParamsMaps = new HashMap<>();
|
Map<String,Property> userDefParamsMaps = new HashMap<>();
|
||||||
Iterator<Map.Entry<String, String>> iter = definedParams.entrySet().iterator();
|
Iterator<Map.Entry<String, String>> iter = definedParams.entrySet().iterator();
|
||||||
while (iter.hasNext()){
|
while (iter.hasNext()) {
|
||||||
Map.Entry<String, String> en = iter.next();
|
Map.Entry<String, String> en = iter.next();
|
||||||
Property property = new Property(en.getKey(), Direct.IN, DataType.VARCHAR , en.getValue());
|
Property property = new Property(en.getKey(), Direct.IN, DataType.VARCHAR, en.getValue());
|
||||||
userDefParamsMaps.put(property.getProp(),property);
|
userDefParamsMaps.put(property.getProp(),property);
|
||||||
}
|
}
|
||||||
return userDefParamsMaps;
|
return userDefParamsMaps;
|
||||||
|
@ -1,113 +0,0 @@
|
|||||||
/*
|
|
||||||
* 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.
|
|
||||||
*/
|
|
||||||
package org.apache.dolphinscheduler.server.master;
|
|
||||||
|
|
||||||
import org.apache.dolphinscheduler.common.enums.ExecutionStatus;
|
|
||||||
import org.apache.dolphinscheduler.dao.entity.ProcessDefinition;
|
|
||||||
import org.apache.dolphinscheduler.dao.entity.ProcessInstance;
|
|
||||||
import org.apache.dolphinscheduler.dao.entity.ProjectUser;
|
|
||||||
import org.apache.dolphinscheduler.dao.entity.TaskInstance;
|
|
||||||
import org.apache.dolphinscheduler.dao.mapper.ProcessDefinitionMapper;
|
|
||||||
import org.apache.dolphinscheduler.dao.mapper.ProcessInstanceMapper;
|
|
||||||
import org.apache.dolphinscheduler.dao.mapper.ProjectMapper;
|
|
||||||
import org.apache.dolphinscheduler.dao.mapper.TaskInstanceMapper;
|
|
||||||
import org.apache.dolphinscheduler.server.utils.AlertManager;
|
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* alert manager test
|
|
||||||
*/
|
|
||||||
@Ignore
|
|
||||||
public class AlertManagerTest {
|
|
||||||
|
|
||||||
private static final Logger logger = LoggerFactory.getLogger(AlertManagerTest.class);
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
ProcessDefinitionMapper processDefinitionMapper;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
ProcessInstanceMapper processInstanceMapper;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
TaskInstanceMapper taskInstanceMapper;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
ProjectMapper projectMapper;
|
|
||||||
|
|
||||||
AlertManager alertManager;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* send worker alert fault tolerance
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
public void sendWarnningWorkerleranceFaultTest(){
|
|
||||||
// process instance
|
|
||||||
ProcessInstance processInstance = processInstanceMapper.queryDetailById(13028);
|
|
||||||
|
|
||||||
// set process definition
|
|
||||||
ProcessDefinition processDefinition = processDefinitionMapper.selectById(47);
|
|
||||||
processInstance.setProcessDefinition(processDefinition);
|
|
||||||
|
|
||||||
|
|
||||||
// fault task instance
|
|
||||||
TaskInstance toleranceTask1 = taskInstanceMapper.selectById(5038);
|
|
||||||
TaskInstance toleranceTask2 = taskInstanceMapper.selectById(5039);
|
|
||||||
|
|
||||||
List<TaskInstance> toleranceTaskList = new ArrayList<>(2);
|
|
||||||
toleranceTaskList.add(toleranceTask1);
|
|
||||||
toleranceTaskList.add(toleranceTask2);
|
|
||||||
|
|
||||||
alertManager.sendAlertWorkerToleranceFault(processInstance, toleranceTaskList);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* send worker alert fault tolerance
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
public void sendWarnningOfProcessInstanceTest(){
|
|
||||||
// process instance
|
|
||||||
ProcessInstance processInstance = processInstanceMapper.queryDetailById(13028);
|
|
||||||
|
|
||||||
// set process definition
|
|
||||||
ProcessDefinition processDefinition = processDefinitionMapper.selectById(47);
|
|
||||||
processInstance.setProcessDefinition(processDefinition);
|
|
||||||
|
|
||||||
// fault task instance
|
|
||||||
TaskInstance toleranceTask1 = taskInstanceMapper.selectById(5038);
|
|
||||||
toleranceTask1.setState(ExecutionStatus.FAILURE);
|
|
||||||
TaskInstance toleranceTask2 = taskInstanceMapper.selectById(5039);
|
|
||||||
toleranceTask2.setState(ExecutionStatus.FAILURE);
|
|
||||||
|
|
||||||
List<TaskInstance> toleranceTaskList = new ArrayList<>(2);
|
|
||||||
toleranceTaskList.add(toleranceTask1);
|
|
||||||
toleranceTaskList.add(toleranceTask2);
|
|
||||||
|
|
||||||
ProjectUser projectUser = projectMapper.queryProjectWithUserByProcessInstanceId(processInstance.getId());
|
|
||||||
|
|
||||||
alertManager.sendAlertProcessInstance(processInstance, toleranceTaskList, projectUser);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -15,14 +15,13 @@
|
|||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.apache.dolphinscheduler.server.utils;
|
package org.apache.dolphinscheduler.service.alert;
|
||||||
|
|
||||||
import org.apache.dolphinscheduler.common.enums.CommandType;
|
import org.apache.dolphinscheduler.common.enums.CommandType;
|
||||||
import org.apache.dolphinscheduler.common.enums.Flag;
|
import org.apache.dolphinscheduler.common.enums.Flag;
|
||||||
import org.apache.dolphinscheduler.common.enums.WarningType;
|
import org.apache.dolphinscheduler.common.enums.WarningType;
|
||||||
import org.apache.dolphinscheduler.common.utils.JSONUtils;
|
import org.apache.dolphinscheduler.common.utils.JSONUtils;
|
||||||
import org.apache.dolphinscheduler.dao.AlertDao;
|
import org.apache.dolphinscheduler.dao.AlertDao;
|
||||||
import org.apache.dolphinscheduler.dao.DaoFactory;
|
|
||||||
import org.apache.dolphinscheduler.dao.entity.Alert;
|
import org.apache.dolphinscheduler.dao.entity.Alert;
|
||||||
import org.apache.dolphinscheduler.dao.entity.ProcessAlertContent;
|
import org.apache.dolphinscheduler.dao.entity.ProcessAlertContent;
|
||||||
import org.apache.dolphinscheduler.dao.entity.ProcessDefinition;
|
import org.apache.dolphinscheduler.dao.entity.ProcessDefinition;
|
||||||
@ -36,21 +35,25 @@ import java.util.List;
|
|||||||
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* alert manager
|
* process alert manager
|
||||||
*/
|
*/
|
||||||
public class AlertManager {
|
@Component
|
||||||
|
public class ProcessAlertManager {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* logger of AlertManager
|
* logger of AlertManager
|
||||||
*/
|
*/
|
||||||
private static final Logger logger = LoggerFactory.getLogger(AlertManager.class);
|
private static final Logger logger = LoggerFactory.getLogger(ProcessAlertManager.class);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* alert dao
|
* alert dao
|
||||||
*/
|
*/
|
||||||
private final AlertDao alertDao = DaoFactory.getDaoInstance(AlertDao.class);
|
@Autowired
|
||||||
|
private AlertDao alertDao;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* command type convert chinese
|
* command type convert chinese
|
||||||
@ -183,7 +186,7 @@ public class AlertManager {
|
|||||||
alert.setCreateTime(new Date());
|
alert.setCreateTime(new Date());
|
||||||
alert.setAlertGroupId(processInstance.getWarningGroupId() == null ? 1 : processInstance.getWarningGroupId());
|
alert.setAlertGroupId(processInstance.getWarningGroupId() == null ? 1 : processInstance.getWarningGroupId());
|
||||||
alertDao.addAlert(alert);
|
alertDao.addAlert(alert);
|
||||||
logger.info("add alert to db , alert : {}", alert.toString());
|
logger.info("add alert to db , alert : {}", alert);
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
logger.error("send alert failed:{} ", e.getMessage());
|
logger.error("send alert failed:{} ", e.getMessage());
|
||||||
@ -237,7 +240,7 @@ public class AlertManager {
|
|||||||
alert.setAlertGroupId(processInstance.getWarningGroupId());
|
alert.setAlertGroupId(processInstance.getWarningGroupId());
|
||||||
alert.setCreateTime(new Date());
|
alert.setCreateTime(new Date());
|
||||||
alertDao.addAlert(alert);
|
alertDao.addAlert(alert);
|
||||||
logger.info("add alert to db , alert: {}", alert.toString());
|
logger.info("add alert to db , alert: {}", alert);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
@ -0,0 +1,93 @@
|
|||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.dolphinscheduler.service.alert;
|
||||||
|
|
||||||
|
import org.apache.dolphinscheduler.common.enums.CommandType;
|
||||||
|
import org.apache.dolphinscheduler.common.enums.ExecutionStatus;
|
||||||
|
import org.apache.dolphinscheduler.common.enums.WarningType;
|
||||||
|
import org.apache.dolphinscheduler.dao.AlertDao;
|
||||||
|
import org.apache.dolphinscheduler.dao.entity.ProcessInstance;
|
||||||
|
import org.apache.dolphinscheduler.dao.entity.ProjectUser;
|
||||||
|
import org.apache.dolphinscheduler.dao.entity.TaskInstance;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.InjectMocks;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.powermock.modules.junit4.PowerMockRunner;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ProcessAlertManager Test
|
||||||
|
*/
|
||||||
|
@RunWith(PowerMockRunner.class)
|
||||||
|
public class ProcessAlertManagerTest {
|
||||||
|
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(ProcessAlertManagerTest.class);
|
||||||
|
|
||||||
|
@InjectMocks
|
||||||
|
ProcessAlertManager processAlertManager = new ProcessAlertManager();
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private AlertDao alertDao;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* send worker alert fault tolerance
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void sendWarningWorkerToleranceFaultTest() {
|
||||||
|
// process instance
|
||||||
|
ProcessInstance processInstance = new ProcessInstance();
|
||||||
|
processInstance.setName("test");
|
||||||
|
|
||||||
|
TaskInstance taskInstance = new TaskInstance();
|
||||||
|
taskInstance.setName("test-task-1");
|
||||||
|
taskInstance.setHost("127.0.0.1");
|
||||||
|
taskInstance.setRetryTimes(3);
|
||||||
|
List<TaskInstance> taskInstanceList = new ArrayList<>();
|
||||||
|
taskInstanceList.add(taskInstance);
|
||||||
|
|
||||||
|
processAlertManager.sendAlertWorkerToleranceFault(processInstance, taskInstanceList);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* send worker alert fault tolerance
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void sendWarnningOfProcessInstanceTest() {
|
||||||
|
// process instance
|
||||||
|
ProcessInstance processInstance = new ProcessInstance();
|
||||||
|
processInstance.setWarningType(WarningType.SUCCESS);
|
||||||
|
processInstance.setState(ExecutionStatus.SUCCESS);
|
||||||
|
processInstance.setCommandType(CommandType.COMPLEMENT_DATA);
|
||||||
|
processInstance.setWarningGroupId(1);
|
||||||
|
|
||||||
|
ProjectUser projectUser = new ProjectUser();
|
||||||
|
TaskInstance taskInstance = new TaskInstance();
|
||||||
|
List<TaskInstance> taskInstanceList = new ArrayList<>();
|
||||||
|
taskInstanceList.add(taskInstance);
|
||||||
|
|
||||||
|
processAlertManager.sendAlertProcessInstance(processInstance, taskInstanceList, projectUser);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
12
pom.xml
12
pom.xml
@ -85,7 +85,7 @@
|
|||||||
<commons.beanutils.version>1.9.4</commons.beanutils.version>
|
<commons.beanutils.version>1.9.4</commons.beanutils.version>
|
||||||
<commons.configuration.version>1.10</commons.configuration.version>
|
<commons.configuration.version>1.10</commons.configuration.version>
|
||||||
<commons.email.version>1.5</commons.email.version>
|
<commons.email.version>1.5</commons.email.version>
|
||||||
<poi.version>3.17</poi.version>
|
<poi.version>4.1.2</poi.version>
|
||||||
<javax.servlet.api.version>3.1.0</javax.servlet.api.version>
|
<javax.servlet.api.version>3.1.0</javax.servlet.api.version>
|
||||||
<commons.collections4.version>4.1</commons.collections4.version>
|
<commons.collections4.version>4.1</commons.collections4.version>
|
||||||
<guava.version>24.1-jre</guava.version>
|
<guava.version>24.1-jre</guava.version>
|
||||||
@ -449,6 +449,11 @@
|
|||||||
<artifactId>poi</artifactId>
|
<artifactId>poi</artifactId>
|
||||||
<version>${poi.version}</version>
|
<version>${poi.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.apache.poi</groupId>
|
||||||
|
<artifactId>poi-ooxml</artifactId>
|
||||||
|
<version>${poi.version}</version>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
<!-- hadoop -->
|
<!-- hadoop -->
|
||||||
<dependency>
|
<dependency>
|
||||||
@ -916,6 +921,9 @@
|
|||||||
<include>**/remote/command/future/ResponseFutureTest.java</include>
|
<include>**/remote/command/future/ResponseFutureTest.java</include>
|
||||||
<include>**/remote/command/log/RemoveTaskLogRequestCommandTest.java</include>
|
<include>**/remote/command/log/RemoveTaskLogRequestCommandTest.java</include>
|
||||||
<include>**/remote/command/log/RemoveTaskLogResponseCommandTest.java</include>
|
<include>**/remote/command/log/RemoveTaskLogResponseCommandTest.java</include>
|
||||||
|
<include>**/remote/command/log/GetLogBytesRequestCommandTest.java</include>
|
||||||
|
<include>**/remote/command/log/GetLogBytesResponseCommandTest.java</include>
|
||||||
|
<include>**/remote/command/log/ViewLogRequestCommandTest.java</include>
|
||||||
<include>**/remote/utils/HostTest.java</include>
|
<include>**/remote/utils/HostTest.java</include>
|
||||||
<include>**/remote/utils/NettyUtilTest.java</include>
|
<include>**/remote/utils/NettyUtilTest.java</include>
|
||||||
<include>**/remote/NettyRemotingClientTest.java</include>
|
<include>**/remote/NettyRemotingClientTest.java</include>
|
||||||
@ -939,7 +947,6 @@
|
|||||||
<include>**/server/master/register/MasterRegistryTest.java</include>
|
<include>**/server/master/register/MasterRegistryTest.java</include>
|
||||||
<include>**/server/master/registry/ServerNodeManagerTest.java</include>
|
<include>**/server/master/registry/ServerNodeManagerTest.java</include>
|
||||||
<include>**/server/master/dispatch/host/assign/RoundRobinHostManagerTest.java</include>
|
<include>**/server/master/dispatch/host/assign/RoundRobinHostManagerTest.java</include>
|
||||||
<include>**/server/master/AlertManagerTest.java</include>
|
|
||||||
<include>**/server/master/MasterCommandTest.java</include>
|
<include>**/server/master/MasterCommandTest.java</include>
|
||||||
<include>**/server/master/DependentTaskTest.java</include>
|
<include>**/server/master/DependentTaskTest.java</include>
|
||||||
<include>**/server/master/ConditionsTaskTest.java</include>
|
<include>**/server/master/ConditionsTaskTest.java</include>
|
||||||
@ -989,6 +996,7 @@
|
|||||||
<include>**/service/queue/PeerTaskInstancePriorityQueueTest.java</include>
|
<include>**/service/queue/PeerTaskInstancePriorityQueueTest.java</include>
|
||||||
<include>**/service/log/LogClientServiceTest.java</include>
|
<include>**/service/log/LogClientServiceTest.java</include>
|
||||||
<include>**/service/alert/AlertClientServiceTest.java</include>
|
<include>**/service/alert/AlertClientServiceTest.java</include>
|
||||||
|
<include>**/service/alert/ProcessAlertManagerTest.java</include>
|
||||||
<include>**/dao/mapper/DataSourceUserMapperTest.java</include>
|
<include>**/dao/mapper/DataSourceUserMapperTest.java</include>
|
||||||
<!--<iTaskUpdateQueueConsumerThreadnclude>**/dao/mapper/ErrorCommandMapperTest.java</iTaskUpdateQueueConsumerThreadnclude>-->
|
<!--<iTaskUpdateQueueConsumerThreadnclude>**/dao/mapper/ErrorCommandMapperTest.java</iTaskUpdateQueueConsumerThreadnclude>-->
|
||||||
<include>**/dao/mapper/ProcessDefinitionMapperTest.java</include>
|
<include>**/dao/mapper/ProcessDefinitionMapperTest.java</include>
|
||||||
|
@ -30,6 +30,7 @@ commons-cli-1.2.jar
|
|||||||
commons-codec-1.11.jar
|
commons-codec-1.11.jar
|
||||||
commons-collections-3.2.2.jar
|
commons-collections-3.2.2.jar
|
||||||
commons-collections4-4.1.jar
|
commons-collections4-4.1.jar
|
||||||
|
commons-compress-1.19.jar
|
||||||
commons-compress-1.4.1.jar
|
commons-compress-1.4.1.jar
|
||||||
commons-compiler-3.0.16.jar
|
commons-compiler-3.0.16.jar
|
||||||
commons-configuration-1.10.jar
|
commons-configuration-1.10.jar
|
||||||
@ -41,12 +42,14 @@ commons-io-2.4.jar
|
|||||||
commons-lang-2.6.jar
|
commons-lang-2.6.jar
|
||||||
commons-logging-1.1.1.jar
|
commons-logging-1.1.1.jar
|
||||||
commons-math3-3.1.1.jar
|
commons-math3-3.1.1.jar
|
||||||
|
commons-math3-3.6.1.jar
|
||||||
commons-net-3.1.jar
|
commons-net-3.1.jar
|
||||||
commons-pool-1.6.jar
|
commons-pool-1.6.jar
|
||||||
cron-utils-5.0.5.jar
|
cron-utils-5.0.5.jar
|
||||||
curator-client-4.3.0.jar
|
curator-client-4.3.0.jar
|
||||||
curator-framework-4.3.0.jar
|
curator-framework-4.3.0.jar
|
||||||
curator-recipes-4.3.0.jar
|
curator-recipes-4.3.0.jar
|
||||||
|
curvesapi-1.06.jar
|
||||||
datanucleus-api-jdo-4.2.1.jar
|
datanucleus-api-jdo-4.2.1.jar
|
||||||
datanucleus-core-4.1.6.jar
|
datanucleus-core-4.1.6.jar
|
||||||
datanucleus-rdbms-4.1.7.jar
|
datanucleus-rdbms-4.1.7.jar
|
||||||
@ -189,7 +192,9 @@ plexus-container-default-1.5.5.jar
|
|||||||
plexus-interpolation-1.14.jar
|
plexus-interpolation-1.14.jar
|
||||||
plexus-sec-dispatcher-1.3.jar
|
plexus-sec-dispatcher-1.3.jar
|
||||||
plexus-utils-2.0.6.jar
|
plexus-utils-2.0.6.jar
|
||||||
poi-3.17.jar
|
poi-4.1.2.jar
|
||||||
|
poi-ooxml-4.1.2.jar
|
||||||
|
poi-ooxml-schemas-4.1.2.jar
|
||||||
postgresql-42.2.5.jar
|
postgresql-42.2.5.jar
|
||||||
presto-jdbc-0.238.1.jar
|
presto-jdbc-0.238.1.jar
|
||||||
protobuf-java-2.5.0.jar
|
protobuf-java-2.5.0.jar
|
||||||
@ -205,6 +210,7 @@ slf4j-api-1.7.5.jar
|
|||||||
snakeyaml-1.23.jar
|
snakeyaml-1.23.jar
|
||||||
snappy-0.2.jar
|
snappy-0.2.jar
|
||||||
snappy-java-1.0.4.1.jar
|
snappy-java-1.0.4.1.jar
|
||||||
|
SparseBitSet-1.2.jar
|
||||||
spring-aop-5.1.19.RELEASE.jar
|
spring-aop-5.1.19.RELEASE.jar
|
||||||
spring-beans-5.1.19.RELEASE.jar
|
spring-beans-5.1.19.RELEASE.jar
|
||||||
spring-boot-2.1.18.RELEASE.jar
|
spring-boot-2.1.18.RELEASE.jar
|
||||||
@ -243,6 +249,7 @@ wagon-provider-api-2.2.jar
|
|||||||
xbean-reflect-3.4.jar
|
xbean-reflect-3.4.jar
|
||||||
xercesImpl-2.9.1.jar
|
xercesImpl-2.9.1.jar
|
||||||
xml-apis-1.4.01.jar
|
xml-apis-1.4.01.jar
|
||||||
|
xmlbeans-3.1.0.jar
|
||||||
xmlenc-0.52.jar
|
xmlenc-0.52.jar
|
||||||
xz-1.0.jar
|
xz-1.0.jar
|
||||||
zookeeper-3.4.14.jar
|
zookeeper-3.4.14.jar
|
||||||
|
Loading…
Reference in New Issue
Block a user