<?xml version="1.0" encoding="UTF-8"?>
<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xmlns="http://maven.apache.org/POM/4.0.0"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<modules>
		<module>ververica-connector-common</module>
		<module>ververica-connector-random</module>
		<module>ververica-connector-datahub</module>
		<module>ververica-connector-tt</module>
		<module>ververica-connector-ttnew</module>
		<module>ververica-connector-ttlegacy</module>
		<module>ververica-connector-odps</module>
		<module>ververica-connector-cloudhbase</module>
		<module>ververica-connector-phoenix</module>
		<module>ververica-connector-redis</module>
		<module>ververica-connector-sls</module>
		<module>ververica-connector-elasticsearch</module>
		<module>ververica-connector-mongodb</module>
		<module>ververica-connector-hologres</module>
		<module>ververica-connector-jdbc</module>
		<module>ververica-connector-ads</module>
		<module>ververica-connector-adb-3.0</module>
		<module>ververica-connector-rds</module>
		<module>ververica-connector-ots</module>
		<module>ververica-connector-metaq</module>
		<module>ververica-connector-mq</module>
		<module>ververica-connector-elasticsearch6</module>
		<module>ververica-connector-elasticsearch7</module>
		<module>ververica-connector-kafka</module>
		<module>ververica-connector-hadoop-shaded</module>
		<module>ververica-connector-cloudhbase-shaded</module>
		<module>ververica-connector-sqlserver</module>
		<module>ververica-connector-mysql</module>
        <module>ververica-connector-tddl</module>
		<module>ververica-connector-postgres</module>
		<module>ververica-connector-continuous-odps</module>
		<module>ververica-connector-hive-2.2.0</module>
		<module>ververica-connector-hive-2.3.6</module>
		<module>ververica-connector-hive-3.1.2</module>
        <module>ververica-connector-phoenix-4.14.2-HBase-1.4</module>
        <module>ververica-connector-preview</module>
		<module>ververica-connector-influxdb</module>
        <module>ververica-connector-db2</module>
        <module>ververica-connector-iceberg</module>
		<module>ververica-connector-lindorm</module>
        <module>ververica-connector-alihbase094</module>
		<module>ververica-connector-adbpg</module>
		<module>ververica-connector-clickhouse</module>
		<module>ververica-connector-vvp</module>
	</modules>

	<parent>
		<groupId>org.apache.flink</groupId>
		<artifactId>flink-parent</artifactId>
		<version>1.13.2</version>
	</parent>

	<groupId>com.alibaba.ververica</groupId>
	<artifactId>ververica-connectors</artifactId>
	<version>1.13-vvr-4.0.7</version>
	<packaging>pom</packaging>

	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
		<flink.version>1.13-vvr-4.0.7-SNAPSHOT</flink.version>
		<flink.cdc.connectors.version>2.0-vvr-4.0.7-SNAPSHOT</flink.cdc.connectors.version>
		<debezium.version>1.5.2.Final</debezium.version>
		<testcontainers.version>1.14.3</testcontainers.version>
		<java.version>1.8</java.version>
		<scala.binary.version>2.11</scala.binary.version>
		<maven.compiler.source>${java.version}</maven.compiler.source>
		<maven.compiler.target>${java.version}</maven.compiler.target>

		<diamond.version>3.8.11</diamond.version>
		<log4j.version>2.13.3</log4j.version>
		<arch_classifier></arch_classifier>
	</properties>

	<distributionManagement>
		<repository>
			<id>oss</id>
			<url>https://oss.sonatype.org/service/local/staging/deploy/maven2/</url>
		</repository>
		<snapshotRepository>
			<id>oss</id>
			<url>https://oss.sonatype.org/content/repositories/snapshots/</url>
		</snapshotRepository>
	</distributionManagement>

	<dependencies>
		<!-- Apache Flink dependencies -->
		<!-- These dependencies are provided, because they should not be packaged into the JAR file. -->
		<dependency>
			<groupId>org.apache.flink</groupId>
			<artifactId>flink-table-common</artifactId>
			<version>${flink.version}</version>
			<scope>provided</scope>
		</dependency>
		<dependency>
			<groupId>org.apache.flink</groupId>
			<artifactId>flink-table-api-java-bridge_${scala.binary.version}</artifactId>
			<version>${flink.version}</version>
			<scope>provided</scope>
		</dependency>
		<dependency>
			<groupId>org.apache.flink</groupId>
			<artifactId>flink-table-runtime-blink_2.11</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-streaming-java_${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-clients_${scala.binary.version}</artifactId>
			<version>${flink.version}</version>
			<scope>test</scope>
		</dependency>

		<dependency>
			<groupId>org.apache.flink</groupId>
			<artifactId>flink-table-planner-blink_${scala.binary.version}</artifactId>
			<version>${flink.version}</version>
			<scope>test</scope>
		</dependency>

		<dependency>
			<groupId>org.apache.flink</groupId>
			<artifactId>flink-table-planner-blink_${scala.binary.version}</artifactId>
			<version>${flink.version}</version>
			<type>test-jar</type>
			<scope>test</scope>
		</dependency>

		<dependency>
			<groupId>org.apache.flink</groupId>
			<artifactId>flink-test-utils-junit</artifactId>
			<version>${flink.version}</version>
			<scope>test</scope>
		</dependency>

		<dependency>
			<groupId>org.apache.flink</groupId>
			<artifactId>force-shading</artifactId>
			<version>${flink.version}</version>
			<scope>provided</scope>
		</dependency>

	</dependencies>

	<build>
		<pluginManagement>
			<!-- Use version 3.2.4 to avoid shading error on mysql connector -->
			<plugins>
				<plugin>
					<groupId>org.apache.maven.plugins</groupId>
					<artifactId>maven-shade-plugin</artifactId>
					<version>3.2.4</version>
				</plugin>
			</plugins>
		</pluginManagement>
		<plugins>
			<plugin>
				<artifactId>maven-surefire-plugin</artifactId>
				<version>2.22.0</version>
				<executions>
					<execution>
						<id>default-test</id>
						<phase>test</phase>
						<goals>
							<goal>test</goal>
						</goals>
						<configuration>
							<includes>
								<include>**/*Test.java</include>
								<include>**/*Test.scala</include>
							</includes>
						</configuration>
					</execution>
					<execution>
						<id>integration-tests</id>
						<phase>integration-test</phase>
						<goals>
							<goal>test</goal>
						</goals>
						<configuration>
							<includes>
								<include>**/*ITCase.java</include>
								<include>**/*ITCase.scala</include>
							</includes>
							<reuseForks>false</reuseForks>
						</configuration>
					</execution>
				</executions>
				<configuration>
					<forkCount>${flink.forkCount}</forkCount>
					<reuseForks>${flink.reuseForks}</reuseForks>
					<systemPropertyVariables>
						<forkNumber>0${surefire.forkNumber}</forkNumber>
					</systemPropertyVariables>
					<argLine>-Xms256m -Xmx2048m -Dmvn.forkNumber=${surefire.forkNumber}
						-XX:+UseG1GC
					</argLine>
				</configuration>
			</plugin>
			<plugin>
				<groupId>org.apache.maven.plugins</groupId>
				<artifactId>maven-enforcer-plugin</artifactId>
				<executions>
					<execution>
						<id>dependency-convergence</id>
						<goals>
							<goal>enforce</goal>
						</goals>
						<configuration>
							<skip>true</skip>
						</configuration>
					</execution>
				</executions>
			</plugin>
			<plugin>
				<groupId>org.apache.maven.plugins</groupId>
				<artifactId>maven-shade-plugin</artifactId>
				<executions>
					<execution>
						<id>shade-flink</id>
						<configuration>
							<shadeTestJar>false</shadeTestJar>
							<shadedArtifactAttached>true</shadedArtifactAttached>
							<shadedClassifierName>jar-with-dependencies</shadedClassifierName>
							<filters>
								<filter>
									<artifact>*:*</artifact>
									<excludes>
										<exclude>META-INF/*.SF</exclude>
										<exclude>META-INF/*.DSA</exclude>
										<exclude>META-INF/*.RSA</exclude>
									</excludes>
								</filter>
							</filters>
							<artifactSet combine.self="override">
								<excludes>
									<!-- log4j -->
									<exclude>org.slf4j:slf4j-log4j12</exclude>
									<exclude>log4j:log4j</exclude>
									<!-- jars imported by parent -->
									<exclude>org.slf4j:slf4j-api</exclude>
									<exclude>com.google.code.findbugs:jsr305</exclude>
									<!-- flink shaded jars -->
									<exclude>org.apache.flink:flink-shaded-*</exclude>
									<exclude>com.alibaba.blink:flink-shaded-*</exclude>
									<exclude>tv.cntt:*</exclude>
									<exclude>io.netty:*</exclude>
									<exclude>org.ow2.asm:*</exclude>
									<!-- flink dependencies are provided -->
									<exclude>org.apache.flink:*</exclude>
									<exclude>com.alibaba.blink:force-shading</exclude>
								</excludes>
							</artifactSet>
							<relocations>
								<relocation>
									<pattern>io.netty</pattern>
									<shadedPattern>org.apache.flink.shaded.netty4.io.netty
									</shadedPattern>
								</relocation>
								<relocation>
									<pattern>jauter</pattern>
									<shadedPattern>org.apache.flink.shaded.netty4.jauter
									</shadedPattern>
								</relocation>
								<relocation>
									<pattern>org.objectweb</pattern>
									<shadedPattern>org.apache.flink.shaded.asm5.org.objectweb
									</shadedPattern>
								</relocation>
							</relocations>
						</configuration>
					</execution>
				</executions>
			</plugin>
		</plugins>
	</build>

	<profiles>
		<profile>
			<id>maven-central-release</id>
			<distributionManagement>
				<repository>
					<id>oss</id>
					<url>https://oss.sonatype.org/service/local/staging/deploy/maven2/</url>
				</repository>
				<snapshotRepository>
					<id>oss</id>
					<url>https://oss.sonatype.org/content/repositories/snapshots/</url>
				</snapshotRepository>
			</distributionManagement>
			<properties>
				<maven.test.skip>true</maven.test.skip>
			</properties>
			<build>
				<plugins>
					<plugin>
						<groupId>org.codehaus.mojo</groupId>
						<artifactId>exec-maven-plugin</artifactId>
						<version>3.0.0</version>
						<inherited>false</inherited>
						<executions>
							<execution>
								<id>create-release-placeholders</id>
								<phase>initialize</phase>
								<goals>
									<goal>exec</goal>
								</goals>
								<configuration>
									<executable>tools/create-release-placeholders.sh</executable>
								</configuration>
							</execution>
						</executions>
					</plugin>
					<plugin>
						<groupId>org.apache.maven.plugins</groupId>
						<artifactId>maven-shade-plugin</artifactId>
						<executions>
							<execution>
								<id>shade-flink</id>
								<configuration>
									<shadedArtifactAttached>false</shadedArtifactAttached>
								</configuration>
							</execution>
						</executions>
					</plugin>
					<plugin>
						<groupId>org.apache.maven.plugins</groupId>
						<artifactId>maven-source-plugin</artifactId>
						<configuration>
							<includes>
								<include>**/placeholder.txt</include>
							</includes>
						</configuration>
						<executions>
							<execution>
								<id>attach-sources</id>
								<goals>
									<goal>jar-no-fork</goal>
								</goals>
							</execution>
						</executions>
					</plugin>
					<plugin>
						<groupId>org.apache.maven.plugins</groupId>
						<artifactId>maven-javadoc-plugin</artifactId>
						<executions>
							<execution>
								<id>attach-javadocs</id>
								<goals>
									<goal>jar</goal>
								</goals>
							</execution>
						</executions>
					</plugin>
				</plugins>
			</build>
		</profile>
	</profiles>
</project>
