<?xml version="1.0" encoding="UTF-8"?>
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <modelVersion>4.0.0</modelVersion>
  <groupId>io.github.interestinglab.waterdrop</groupId>
  <artifactId>waterdop</artifactId>
  <version>2.0.2</version>
  <packaging>pom</packaging>
  <name>Waterdrop</name>
  <description>Production ready big data processing product based on Apache Spark and Apache Flink.</description>
  <url>https://github.com/InterestingLab/waterdrop</url>
  <inceptionYear>2017</inceptionYear>
  <licenses>
    <license>
      <name>The Apache License, Version 2.0</name>
      <url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
    </license>
  </licenses>
  <developers>
    <developer>
      <name>Garyelephant, RickyHuo, Kid-xiong</name>
      <email>garygaowork@gmail.com</email>
      <organization>InterestingLab</organization>
      <organizationUrl>https://github.com/InterestingLab</organizationUrl>
    </developer>
  </developers>
  <modules>
    <module>waterdrop-apis</module>
    <module>waterdrop-core</module>
    <module>waterdrop-common</module>
    <module>waterdrop-flink-api</module>
    <module>waterdrop-spark-api</module>
    <module>plugin-spark-source-kafka</module>
    <module>plugin-spark-source-jdbc</module>
    <module>plugin-spark-source-fake</module>
    <module>plugin-spark-source-elasticsearch</module>
    <module>plugin-spark-transform-sql</module>
    <module>plugin-spark-sink-console</module>
    <module>plugin-spark-sink-clickhouse</module>
    <module>plugin-spark-sink-elasticsearch</module>
    <module>plugin-flink-source-kafka</module>
    <module>plugin-flink-transform-sql</module>
    <module>plugin-flink-sink-console</module>
    <module>plugin-flink-transform-table2datasteam</module>
    <module>plugin-flink-sink-kafka</module>
    <module>plugin-flink-transform-datastream2table</module>
    <module>plugin-flink-source-file</module>
    <module>plugin-flink-sink-jdbc</module>
    <module>plugin-flink-source-fake</module>
    <module>plugin-flink-source-socket</module>
    <module>plugin-flink-source-jdbc</module>
    <module>plugin-flink-sink-file</module>
    <module>plugin-flink-sink-elasticsearch</module>
    <module>plugin-spark-sink-file</module>
    <module>plugin-flink-transform-split</module>
    <module>plugin-spark-transform-json</module>
    <module>waterdrop-dist</module>
    <module>plugin-spark-transform-split</module>
    <module>plugin-spark-source-socket</module>
    <module>plugin-spark-source-phoenix</module>
    <module>plugin-spark-phoenix-core</module>
    <module>plugin-spark-sink-phoenix</module>
    <module>waterdrop-config</module>
  </modules>
  <scm>
    <connection>scm:git:git@github.com:InterestingLab/waterdrop.git</connection>
    <developerConnection>scm:git:git@github.com:InterestingLab/waterdrop.git</developerConnection>
    <url>https://github.com/InterestingLab/waterdrop</url>
  </scm>
  <distributionManagement>
    <repository>
      <id>ossrh</id>
      <url>https://oss.sonatype.org/service/local/staging/deploy/maven2/</url>
    </repository>
    <snapshotRepository>
      <id>ossrh</id>
      <url>https://oss.sonatype.org/content/repositories/snapshots</url>
    </snapshotRepository>
  </distributionManagement>
  <properties>
    <skip.pmd.check>false</skip.pmd.check>
    <lombok.version>1.18.0</lombok.version>
    <flink.version>1.9.0</flink.version>
    <java.version>1.8</java.version>
    <maven.compiler.target>${java.version}</maven.compiler.target>
    <scala.binary.version>2.11</scala.binary.version>
    <maven.javadoc.skip>false</maven.javadoc.skip>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <mysql.version>5.1.46</mysql.version>
    <waterdrop.version>2.0.0</waterdrop.version>
    <hadoop.version>2.7.5</hadoop.version>
    <maven.deploy.skip>false</maven.deploy.skip>
    <scala.version>2.11.8</scala.version>
    <maven.compiler.source>${java.version}</maven.compiler.source>
    <spark.version>2.4.0</spark.version>
    <fastjson.version>1.2.60</fastjson.version>
  </properties>
  <dependencyManagement>
    <dependencies>
      <dependency>
        <groupId>org.apache.spark</groupId>
        <artifactId>spark-streaming_2.11</artifactId>
        <version>${spark.version}</version>
        <scope>provided</scope>
      </dependency>
      <dependency>
        <groupId>org.apache.spark</groupId>
        <artifactId>spark-core_2.11</artifactId>
        <version>${spark.version}</version>
        <scope>provided</scope>
      </dependency>
      <dependency>
        <groupId>org.apache.spark</groupId>
        <artifactId>spark-sql_2.11</artifactId>
        <version>${spark.version}</version>
        <scope>provided</scope>
      </dependency>
      <dependency>
        <groupId>net.jpountz.lz4</groupId>
        <artifactId>lz4</artifactId>
        <version>1.3.0</version>
      </dependency>
      <dependency>
        <groupId>org.apache.flink</groupId>
        <artifactId>flink-core</artifactId>
        <version>${flink.version}</version>
        <scope>provided</scope>
      </dependency>
      <dependency>
        <groupId>org.apache.flink</groupId>
        <artifactId>flink-java</artifactId>
        <version>${flink.version}</version>
        <scope>provided</scope>
      </dependency>
      <dependency>
        <groupId>org.apache.flink</groupId>
        <artifactId>flink-table-planner_${scala.binary.version}</artifactId>
        <version>${flink.version}</version>
        <scope>provided</scope>
      </dependency>
      <dependency>
        <groupId>org.apache.flink</groupId>
        <artifactId>flink-streaming-scala_${scala.binary.version}</artifactId>
        <version>${flink.version}</version>
        <scope>provided</scope>
      </dependency>
      <dependency>
        <groupId>org.apache.flink</groupId>
        <artifactId>flink-streaming-java_${scala.binary.version}</artifactId>
        <version>${flink.version}</version>
        <scope>provided</scope>
      </dependency>
    </dependencies>
  </dependencyManagement>
  <build>
    <finalName>${project.artifactId}-${version}-${scala.version}</finalName>
    <pluginManagement>
      <plugins>
        <plugin>
          <groupId>org.sonatype.plugins</groupId>
          <artifactId>nexus-staging-maven-plugin</artifactId>
          <version>1.6.8</version>
          <extensions>true</extensions>
          <configuration>
            <serverId>ossrh</serverId>
            <nexusUrl>https://oss.sonatype.org/</nexusUrl>
            <autoReleaseAfterClose>true</autoReleaseAfterClose>
          </configuration>
        </plugin>
        <plugin>
          <artifactId>maven-source-plugin</artifactId>
          <version>3.0.1</version>
          <executions>
            <execution>
              <id>attach-sources</id>
              <goals>
                <goal>jar-no-fork</goal>
              </goals>
            </execution>
          </executions>
        </plugin>
        <plugin>
          <artifactId>maven-javadoc-plugin</artifactId>
          <version>2.9.1</version>
          <executions>
            <execution>
              <id>attach-javadocs</id>
              <goals>
                <goal>jar</goal>
              </goals>
            </execution>
          </executions>
          <configuration>
            <skip>${maven.javadoc.skip}</skip>
          </configuration>
        </plugin>
        <plugin>
          <artifactId>maven-gpg-plugin</artifactId>
          <version>1.6</version>
          <executions>
            <execution>
              <id>sign-artifacts</id>
              <phase>verify</phase>
              <goals>
                <goal>sign</goal>
              </goals>
            </execution>
          </executions>
        </plugin>
        <plugin>
          <artifactId>maven-deploy-plugin</artifactId>
          <version>2.8.2</version>
          <executions>
            <execution>
              <id>default-deploy</id>
              <phase>deploy</phase>
              <goals>
                <goal>deploy</goal>
              </goals>
            </execution>
          </executions>
          <configuration>
            <skip>${maven.deploy.skip}</skip>
          </configuration>
        </plugin>
        <plugin>
          <groupId>net.alchim31.maven</groupId>
          <artifactId>scala-maven-plugin</artifactId>
          <version>3.3.1</version>
          <executions>
            <execution>
              <id>scala-compile-first</id>
              <phase>process-resources</phase>
              <goals>
                <goal>compile</goal>
              </goals>
            </execution>
            <execution>
              <id>scala-test-compile</id>
              <phase>process-test-resources</phase>
              <goals>
                <goal>testCompile</goal>
              </goals>
            </execution>
            <execution>
              <id>attach-javadocs</id>
              <goals>
                <goal>doc-jar</goal>
              </goals>
            </execution>
            <execution>
              <id>attach-sources</id>
              <goals>
                <goal>add-source</goal>
              </goals>
            </execution>
          </executions>
        </plugin>
      </plugins>
    </pluginManagement>
    <plugins>
      <plugin>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>2.0.2</version>
        <configuration>
          <source>${maven.compiler.source}</source>
          <target>${maven.compiler.target}</target>
        </configuration>
      </plugin>
      <plugin>
        <artifactId>maven-shade-plugin</artifactId>
        <version>2.4.3</version>
        <executions>
          <execution>
            <phase>package</phase>
            <goals>
              <goal>shade</goal>
            </goals>
            <configuration>
              <transformers>
                <transformer implementation="org.apache.maven.plugins.shade.resource.ServicesResourceTransformer" />
              </transformers>
            </configuration>
          </execution>
        </executions>
        <configuration>
          <filters>
            <filter>
              <artifact>*:*</artifact>
              <excludes>
                <exclude>META-INF/*.SF</exclude>
                <exclude>META-INF/*.DSA</exclude>
                <exclude>META-INF/*.RSA</exclude>
              </excludes>
            </filter>
          </filters>
        </configuration>
      </plugin>
      <plugin>
        <artifactId>maven-pmd-plugin</artifactId>
        <version>3.8</version>
        <executions>
          <execution>
            <id>validate</id>
            <phase>validate</phase>
            <goals>
              <goal>check</goal>
            </goals>
          </execution>
        </executions>
        <dependencies>
          <dependency>
            <groupId>com.alibaba.p3c</groupId>
            <artifactId>p3c-pmd</artifactId>
            <version>1.3.0</version>
          </dependency>
        </dependencies>
        <configuration>
          <rulesets>
            <ruleset>rulesets/java/ali-concurrent.xml</ruleset>
            <ruleset>rulesets/java/ali-exception.xml</ruleset>
            <ruleset>rulesets/java/ali-flowcontrol.xml</ruleset>
            <ruleset>rulesets/java/ali-naming.xml</ruleset>
            <ruleset>rulesets/java/ali-oop.xml</ruleset>
            <ruleset>rulesets/java/ali-orm.xml</ruleset>
            <ruleset>rulesets/java/ali-other.xml</ruleset>
            <ruleset>rulesets/java/ali-set.xml</ruleset>
          </rulesets>
          <printFailingErrors>true</printFailingErrors>
          <skip>${skip.pmd.check}</skip>
        </configuration>
      </plugin>
    </plugins>
  </build>
</project>
