<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">

    <modelVersion>4.0.0</modelVersion>

    <parent>
        <groupId>io.confluent</groupId>
        <!-- Use confluent-security-plugins as parent to override versions of transitive
             Kafka dependencies to be CE instead of CCS (inherited from `common`) -->
        <artifactId>confluent-security-plugins</artifactId>
        <version>6.2.0</version>
    </parent>

    <groupId>io.confluent.controlcenter</groupId>
    <artifactId>control-center-parent</artifactId>
    <name>control-center-parent</name>
    <version>6.2.0</version>
    <packaging>pom</packaging>
    <organization>
        <name>Confluent, Inc.</name>
        <url>http://confluent.io</url>
    </organization>
    <url>http://confluent.io</url>
    <description>
        Control Center for Kafka.
    </description>

    <scm>
        <connection>scm:git:git://github.com/confluentinc/blueway.git</connection>
        <developerConnection>scm:git:git@github.com:confluentinc/blueway.git</developerConnection>
        <url>https://github.com/confluentinc/blueway</url>
        <tag>HEAD</tag>
    </scm>

    <modules>
        <module>monitoring-interceptors</module>
        <module>control-center</module>
        <module>rock</module>
        <module>license-cli</module>
        <module>confluent-command</module>
        <module>control-center-console-scripts</module>
        <module>acl</module>
        <module>graphql</module>
    </modules>

    <properties>
        <!--TODO: move this to common-->
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.build.resourceEncoding>UTF-8</project.build.resourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>

        <build-helper-maven-plugin.version>1.9.1</build-helper-maven-plugin.version>
        <commons-cli.version>1.3.1</commons-cli.version>
        <commons-email.version>1.5</commons-email.version>
        <commons-csv.version>1.8</commons-csv.version>
        <exec-maven-plugin.version>1.2.1</exec-maven-plugin.version>
        <guice.version>4.2.0</guice.version>
        <joda-time.version>2.9.9</joda-time.version>
        <jose4j.version>0.6.5</jose4j.version>
        <maven-antrun-plugin.version>1.8</maven-antrun-plugin.version>
        <maven-dependency-plugin.version>2.10</maven-dependency-plugin.version>
        <!-- TODO: update maven-shade-plugin -->
        <maven-shade-plugin.version>3.2.4</maven-shade-plugin.version>
        <protobuf.version>3.11.4</protobuf.version>
        <io.confluent.blueway.version>6.2.0</io.confluent.blueway.version>
        <io.confluent.blueway-fe.version>${confluent.version.range}</io.confluent.blueway-fe.version>
        <io.confluent.metadata-service.version>${confluent.version.range}</io.confluent.metadata-service.version>
    </properties>

    <repositories>
        <repository>
            <id>confluent</id>
            <url>${confluent.maven.repo}</url>
        </repository>
    </repositories>

    <profiles>
        <profile>
            <activation>
                <activeByDefault>true</activeByDefault>
            </activation>
            <id>cloud</id>
            <modules>
                <module>kafka-api</module>
                <module>kafka-api-console-scripts</module>
            </modules>
        </profile>
    </profiles>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>io.airlift</groupId>
                <artifactId>airline</artifactId>
                <version>0.7</version>
            </dependency>
            <dependency>
                <groupId>io.confluent</groupId>
                <artifactId>confluent-metrics</artifactId>
                <version>${ce.kafka.version}</version>
            </dependency>
            <dependency>
                <groupId>io.confluent</groupId>
                <artifactId>confluent-licensing-new</artifactId>
                <version>${ce.kafka.version}</version>
            </dependency>
            <dependency>
                <groupId>io.confluent</groupId>
                <artifactId>confluent-command</artifactId>
                <version>${io.confluent.blueway.version}</version>
            </dependency>
            <dependency>
                <groupId>io.confluent.controlcenter</groupId>
                <artifactId>control-center-frontend</artifactId>
                <version>${io.confluent.blueway-fe.version}</version>
            </dependency>
            <dependency>
                <groupId>io.confluent</groupId>
                <artifactId>rbac-api-server</artifactId>
                <version>${io.confluent.metadata-service.version}</version>
            </dependency>
            <dependency>
                <groupId>io.confluent</groupId>
                <artifactId>confluent-connect-security-plugin</artifactId>
                <version>${io.confluent.confluent-security-plugins.version}</version>
            </dependency>
            <dependency>
                <artifactId>confluent-schema-registry-security-plugin</artifactId>
                <groupId>io.confluent</groupId>
                <version>${io.confluent.confluent-security-plugins.version}</version>
            </dependency>
            <dependency>
                <groupId>io.confluent</groupId>
                <artifactId>confluent-serializers-new</artifactId>
                <version>${ce.kafka.version}</version>
            </dependency>
            <dependency>
                <groupId>io.confluent</groupId>
                <artifactId>monitoring-interceptors</artifactId>
                <version>${io.confluent.blueway.version}</version>
            </dependency>
            <dependency>
                <groupId>io.confluent</groupId>
                <artifactId>graphql</artifactId>
                <version>${io.confluent.blueway.version}</version>
            </dependency>
            <dependency>
                <groupId>io.confluent</groupId>
                <artifactId>kafka-client-plugins</artifactId>
                <version>${ce.kafka.version}</version>
            </dependency>
            <dependency>
                <groupId>io.confluent</groupId>
                <artifactId>confluent-security-plugins-common</artifactId>
                <version>${io.confluent.confluent-security-plugins.version}</version>
            </dependency>
            <dependency>
                <groupId>io.confluent</groupId>
                <artifactId>kafka-avro-serializer</artifactId>
                <version>${io.confluent.schema-registry.version}</version>
            </dependency>
            <dependency>
                <groupId>io.confluent</groupId>
                <artifactId>kafka-json-schema-serializer</artifactId>
                <version>${io.confluent.schema-registry.version}</version>
            </dependency>
            <dependency>
                <groupId>io.confluent</groupId>
                <artifactId>kafka-protobuf-serializer</artifactId>
                <version>${io.confluent.schema-registry.version}</version>
            </dependency>
            <dependency>
                <groupId>com.google.guava</groupId>
                <artifactId>guava</artifactId>
                <version>${guava.version}</version>
            </dependency>
            <dependency>
                <groupId>com.google.inject</groupId>
                <artifactId>guice</artifactId>
                <version>${guice.version}</version>
            </dependency>
            <dependency>
                <groupId>com.google.inject.extensions</groupId>
                <artifactId>guice-throwingproviders</artifactId>
                <version>${guice.version}</version>
            </dependency>
            <dependency>
                <groupId>org.bitbucket.b_c</groupId>
                <artifactId>jose4j</artifactId>
                <version>${jose4j.version}</version>
            </dependency>
            <dependency>
                <groupId>joda-time</groupId>
                <artifactId>joda-time</artifactId>
                <version>${joda-time.version}</version>
            </dependency>
            <dependency>
                <groupId>com.google.protobuf</groupId>
                <artifactId>protobuf-java</artifactId>
                <version>${protobuf.version}</version>
            </dependency>
            <dependency>
                <groupId>com.google.protobuf</groupId>
                <artifactId>protobuf-java-util</artifactId>
                <version>${protobuf.version}</version>
            </dependency>
            <!-- Kafka Deps -->
            <dependency>
                <groupId>org.apache.kafka</groupId>
                <artifactId>kafka_${kafka.scala.version}</artifactId>
                <version>${ce.kafka.version}</version>
            </dependency>
            <dependency>
                <groupId>org.apache.kafka</groupId>
                <artifactId>kafka-streams</artifactId>
                <version>${ce.kafka.version}</version>
            </dependency>
            <dependency>
                <groupId>org.apache.kafka</groupId>
                <artifactId>kafka-clients</artifactId>
                <version>${ce.kafka.version}</version>
            </dependency>
            <dependency>
                <groupId>org.apache.kafka</groupId>
                <artifactId>connect-runtime</artifactId>
                <version>${ce.kafka.version}</version>
            </dependency>
            <dependency>
                <groupId>commons-cli</groupId>
                <artifactId>commons-cli</artifactId>
                <version>${commons-cli.version}</version>
            </dependency>
            <dependency>
                <groupId>org.apache.commons</groupId>
                <artifactId>commons-email</artifactId>
                <version>${commons-email.version}</version>
            </dependency>
            <dependency>
                <groupId>org.apache.commons</groupId>
                <artifactId>commons-csv</artifactId>
                <version>${commons-csv.version}</version>
            </dependency>
            <dependency>
                <groupId>org.eclipse.jetty</groupId>
                <artifactId>jetty-proxy</artifactId>
                <version>${jetty.version}</version>
            </dependency>
            <dependency>
                <groupId>io.confluent</groupId>
                <artifactId>rest-utils</artifactId>
                <version>${io.confluent.rest-utils.version}</version>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <pluginManagement>
            <plugins>
                <plugin>
                    <groupId>org.apache.maven.plugins</groupId>
                    <artifactId>maven-shade-plugin</artifactId>
                    <version>${maven-shade-plugin.version}</version>
                </plugin>
            </plugins>
        </pluginManagement>
        <plugins>
            <plugin>
                <artifactId>maven-checkstyle-plugin</artifactId>
                <executions>
                    <execution>
                        <id>validate</id>
                        <phase>validate</phase>
                        <configuration>
                            <suppressionsLocation>checkstyle/suppressions.xml</suppressionsLocation>
                        </configuration>
                        <goals>
                            <goal>check</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
</project>
