<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/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <parent>
        <groupId>net.sansa-stack</groupId>
        <artifactId>sansa-owl-parent_2.11</artifactId>
        <version>0.3.0</version>
    </parent>

    <artifactId>sansa-owl-spark_2.11</artifactId>
    <version>0.3.0</version>

    <name>SANSA OWL layer - SPARK</name>
    <description>A library to read OWL files into Spark.</description>

    <dependencies>
        <dependency>
            <groupId>net.sansa-stack</groupId>
            <artifactId>sansa-owl-common_${scala.binary.version}</artifactId>
            <version>${project.version}</version>
        </dependency>

        <!-- Scala dependencies -->
        <dependency>
            <groupId>org.scala-lang</groupId>
            <artifactId>scala-library</artifactId>
        </dependency>

        <!-- Spark dependencies -->
        <dependency>
            <groupId>org.apache.spark</groupId>
            <artifactId>spark-core_2.11</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.spark</groupId>
            <artifactId>spark-sql_2.11</artifactId>
        </dependency>
        <dependency>
            <groupId>de.javakaffee</groupId>
            <artifactId>kryo-serializers</artifactId>
        </dependency>

        <!-- Hadoop dependencies (mainly used for InputFormat definitions) -->
        <dependency>
            <groupId>org.apache.hadoop</groupId>
            <artifactId>hadoop-mapreduce-client-core</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.hadoop</groupId>
            <artifactId>hadoop-common</artifactId>
        </dependency>

        <!-- OWL API dependencies -->
        <dependency>
            <groupId>net.sourceforge.owlapi</groupId>
            <artifactId>owlapi-api</artifactId>
        </dependency>
        <dependency>
            <groupId>net.sourceforge.owlapi</groupId>
            <artifactId>owlapi-parsers</artifactId>
        </dependency>
        <dependency>
            <groupId>net.sourceforge.owlapi</groupId>
            <artifactId>owlapi-apibinding</artifactId>
        </dependency>
        <dependency>
            <groupId>com.google.inject</groupId>
            <artifactId>guice</artifactId>
        </dependency>
        <dependency>
            <groupId>com.google.inject.extensions</groupId>
            <artifactId>guice-assistedinject</artifactId>
        </dependency>
        <dependency>
            <groupId>com.google.inject.extensions</groupId>
            <artifactId>guice-multibindings</artifactId>
        </dependency>

        <!-- Testing dependencies -->
        <dependency>
            <groupId>org.scalatest</groupId>
            <artifactId>scalatest_${scala.binary.version}</artifactId>
        </dependency>
        <dependency>
            <groupId>com.holdenkarau</groupId>
            <artifactId>spark-testing-base_${scala.binary.version}</artifactId>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>net.alchim31.maven</groupId>
                <artifactId>scala-maven-plugin</artifactId>
            </plugin>

            <plugin>
                <artifactId>maven-compiler-plugin</artifactId>
            </plugin>

            <plugin>
                <groupId>org.scalatest</groupId>
                <artifactId>scalatest-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

    <profiles>
        <profile>
            <id>build-jar</id>
            <activation>
                <activeByDefault>false</activeByDefault>
            </activation>
            <dependencies>
                <dependency>
                    <groupId>org.apache.spark</groupId>
                    <artifactId>spark-core_2.11</artifactId>
                    <scope>provided</scope>
                </dependency>
                <dependency>
                    <groupId>org.apache.spark</groupId>
                    <artifactId>spark-sql_2.11</artifactId>
                    <scope>provided</scope>
                </dependency>
                <dependency>
                    <groupId>org.apache.hadoop</groupId>
                    <artifactId>hadoop-mapreduce-client-core</artifactId>
                    <scope>provided</scope>
                </dependency>
                <dependency>
                    <groupId>org.apache.hadoop</groupId>
                    <artifactId>hadoop-common</artifactId>
                    <scope>provided</scope>
                </dependency>
            </dependencies>
        </profile>

        <profile>
            <id>dist</id>
            <activation>
                <property>
                    <name>dist</name>
                </property>
            </activation>
            <build>
                <plugins>
                    <plugin>
                        <groupId>org.apache.maven.plugins</groupId>
                        <artifactId>maven-shade-plugin</artifactId>
                        <version>2.4.3</version>
                        <executions>
                            <execution>
                                <phase>package</phase>
                                <goals>
                                    <goal>shade</goal>
                                </goals>
                                <configuration>
                                    <artifactSet>
                                        <excludes>
                                            <exclude>asm:asm</exclude>
                                            <exclude>com.clearspring.analytics:stream</exclude>
                                            <exclude>com.esotericsoftware:kryo*</exclude>
                                            <exclude>com.esotericsoftware:minlog</exclude>
                                            <exclude>com.fasterxml.jackson.core:jackson*</exclude>
                                            <exclude>com.fasterxml.jackson.module:jackson-module*</exclude>
                                            <exclude>com.google.code.findbugs:jsr305</exclude>
                                            <exclude>com.google.code.gson:gson</exclude>
                                            <exclude>com.google.inject.extensions:guice-servlet</exclude>
                                            <exclude>com.google.guava:guava</exclude>
                                            <exclude>com.google.protobuf:protobuf-java</exclude>
                                            <exclude>com.jcraft:jsch</exclude>
                                            <exclude>com.ning:compress-lzf</exclude>
                                            <exclude>com.sun.jersey:jersey-*</exclude>
                                            <exclude>com.sun.jersey.contribs:jersey-guice</exclude>
                                            <exclude>com.sun.xml.bind:jaxb-impl</exclude>
                                            <exclude>com.thoughtworks.paranamer:paranamer</exclude>
                                            <exclude>com.twitter:chill*</exclude>
                                            <exclude>com.univocity:univocity-parsers</exclude>
                                            <exclude>commons-beanutils:commons-beanutils*</exclude>
                                            <exclude>commons-cli:commons-cli</exclude>
                                            <exclude>commons-codec:commons-codec</exclude>
                                            <exclude>commons-collections:commons-collections</exclude>
                                            <exclude>commons-configuration:commons-configuration</exclude>
                                            <exclude>commons-digester:commons-digester</exclude>
                                            <exclude>commons-httpclient:commons-httpclient</exclude>
                                            <exclude>commons-io:commons-io</exclude>
                                            <exclude>commons-lang:commons-lang</exclude>
                                            <exclude>commons-logging:commons-logging</exclude>
                                            <exclude>commons-net:commons-net</exclude>
                                            <exclude>io.dropwizard.metrics:metrics*</exclude>
                                            <exckude>io.netty:netty*</exckude>
                                            <exclude>javax.activation:activation</exclude>
                                            <exclude>javax.annotation:javax.annotation-api</exclude>
                                            <exclude>javax.servlet:javax.servlet-api</exclude>
                                            <exclude>javax.servlet.jsp:jsp-api</exclude>
                                            <exclude>javax.servlet:servlet-api</exclude>
                                            <exclude>javax.validation:validation-api</exclude>
                                            <exclude>javax.ws.rs:javax.ws.rs-api</exclude>
                                            <exclude>javax.xml.bind:jaxb-api</exclude>
                                            <exclude>javax.xml.stream:stax-api</exclude>
                                            <exclude>jdk.tools:jdk.tools</exclude>
                                            <exclude>net.java.dev.jets3t:jets3t</exclude>
                                            <exclude>net.jpountz.lz4:lz4</exclude>
                                            <exclude>net.razorvine:pyrolite</exclude>
                                            <exclude>net.sf.py4j:py4j</exclude>
                                            <exclude>org.antlr:antlr4-runtime</exclude>
                                            <exclude>org.apache.avro:avro*</exclude>
                                            <exclude>org.apache.commons:commons-lang3</exclude>
                                            <exclude>org.apache.commons:commons-math3</exclude>
                                            <exclude>org.apache.commons:commons-compress</exclude>
                                            <exclude>org.apache.commons:commons-crypto</exclude>
                                            <exclude>org.apache.curator:curator*</exclude>
                                            <exclude>org.apache.directory.api:*</exclude>
                                            <exclude>org.apache.directory.server:*</exclude>
                                            <exclude>org.apache.hadoop:*</exclude>
                                            <exclude>org.apache.htrace:htrace-core</exclude>
                                            <exclude>org.apache.httpcomponents:*</exclude>
                                            <exclude>org.apache.ivy:ivy</exclude>
                                            <exclude>org.apache.parquet:parquet*</exclude>
                                            <exclude>org.apache.spark:*</exclude>
                                            <exclude>org.apache.xbean:xbean-asm5-shaded</exclude>
                                            <exclude>org.apache.zookeeper:zookeeper</exclude>
                                            <exclude>org.codehaus.jackson:jackson-*</exclude>
                                            <exclude>org.codehaus.janino:*</exclude>
                                            <exclude>org.codehaus.jettison:jettison</exclude>
                                            <exclude>org.fusesource.leveldbjni:leveldbjni-all</exclude>
                                            <exclude>org.glassfish.hk2*</exclude>
                                            <exclude>org.glassfish.jersey*</exclude>
                                            <exclude>org.javassist:javassist</exclude>
                                            <exclude>org.json4s:json4s*</exclude>
                                            <exclude>org.mortbay.jetty:jetty*</exclude>
                                            <exclude>org.objenesis:objenesis</exclude>
                                            <exclude>org.roaringbitmap:RoaringBitmap</exclude>
                                            <exclude>org.scala-lang:*</exclude>
                                            <exclude>org.slf4j:jul-to-slf4j</exclude>
                                            <exclude>org.slf4j:jcl-over-slf4j</exclude>
                                            <exclude>org.spark-project.spark:unused</exclude>
                                            <exclude>org.xerial.snappy:snappy-java</exclude>
                                            <exclude>oro:oro</exclude>
                                            <exclude>xmlenc:xmlenc</exclude>
                                        </excludes>
                                    </artifactSet>
                                    <filters>
                                        <filter>
                                            <artifact>*:*</artifact>
                                            <excludes>
                                                <exclude>META-INF/*.SF</exclude>
                                                <exclude>META-INF/*.DSA</exclude>
                                                <exclude>META-INF/*.RSA</exclude>
                                            </excludes>
                                        </filter>
                                    </filters>
                                    <createDependencyReducedPom>false</createDependencyReducedPom>
                                </configuration>
                            </execution>
                        </executions>
                    </plugin>
                </plugins>
            </build>
        </profile>
    </profiles>
</project>
