<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>net.sansa-stack</groupId>
		<artifactId>sansa-examples-parent_2.12</artifactId>
		<version>0.8.0-RC1</version>
	</parent>

	<artifactId>sansa-examples-spark_2.12</artifactId>
	<name>SANSA Examples - Apache Spark</name>
	<description>SANSA Examples for Apache Spark</description>

	<dependencies>
		<!-- Apache Spark -->
		<dependency>
			<groupId>org.apache.spark</groupId>
			<artifactId>spark-core_${scala.binary.version}</artifactId>
			<!-- <exclusions> <exclusion> <groupId>org.mortbay.jetty</groupId> <artifactId>jetty</artifactId>
				</exclusion> <exclusion> <groupId>org.mortbay.jetty</groupId> <artifactId>jetty-util</artifactId> 
				</exclusion> </exclusions> -->
		</dependency>
		<dependency>
			<groupId>org.apache.spark</groupId>
			<artifactId>spark-sql_${scala.binary.version}</artifactId>
		</dependency>
		<dependency>
			<groupId>org.apache.spark</groupId>
			<artifactId>spark-graphx_${scala.binary.version}</artifactId>
		</dependency>

		<!-- Apache JENA 3.x -->
		<dependency>
			<groupId>org.apache.jena</groupId>
			<artifactId>jena-core</artifactId>
		</dependency>
		<dependency>
			<groupId>org.apache.jena</groupId>
			<artifactId>jena-arq</artifactId>
		</dependency>

<!--
		<dependency>
			<groupId>org.aksw.jena-sparql-api</groupId>
			<artifactId>jena-sparql-api-server-standalone</artifactId>
		</dependency>

		<dependency>
			<groupId>org.eclipse.jetty</groupId>
			<artifactId>jetty-server</artifactId>
			<version>9.4.35.v20201120</version>
		</dependency>
-->

		<!-- SANSA RDF -->
		<dependency>
			<groupId>${project.groupId}</groupId>
			<artifactId>sansa-rdf-spark_${scala.binary.version}</artifactId>
		</dependency>

		<!-- SANSA OWL -->
		<dependency>
			<groupId>${project.groupId}</groupId>
			<artifactId>sansa-owl-spark_${scala.binary.version}</artifactId>
			<!-- <exclusions> <exclusion> <groupId>org.mortbay.jetty</groupId> <artifactId>jetty</artifactId> 
				</exclusion> <exclusion> <groupId>org.mortbay.jetty</groupId> <artifactId>jetty-util</artifactId> 
				</exclusion> </exclusions> -->
		</dependency>

		<!-- SANSA Inference -->
		<dependency>
			<groupId>${project.groupId}</groupId>
			<artifactId>sansa-inference-spark_${scala.binary.version}</artifactId>
		</dependency>

		<!-- SANSA Querying -->
		<dependency>
			<groupId>${project.groupId}</groupId>
			<artifactId>sansa-query-spark_${scala.binary.version}</artifactId>
		</dependency>

		<!-- SANSA Datalake -->
		<dependency>
			<groupId>${project.groupId}</groupId>
			<artifactId>sansa-datalake-spark_${scala.binary.version}</artifactId>
		</dependency>

		<!-- SANSA ML -->
		<dependency>
			<groupId>${project.groupId}</groupId>
			<artifactId>sansa-ml-spark_${scala.binary.version}</artifactId>
			<exclusions>
				<exclusion>
					<groupId>com.github.scopt</groupId>
					<artifactId>scopt_2.11</artifactId>
				</exclusion>
			</exclusions>
		</dependency>

		<!-- Logging -->
		<dependency>
			<groupId>com.typesafe.scala-logging</groupId>
			<artifactId>scala-logging_${scala.binary.version}</artifactId>
		</dependency>

		<!-- Scopt -->
		<dependency>
			<groupId>com.github.scopt</groupId>
			<artifactId>scopt_${scala.binary.version}</artifactId>
		</dependency>

		<!-- BigDL Library -->
		<!--<dependency>
			<groupId>com.intel.analytics.bigdl</groupId>
			<artifactId>bigdl-SPARK_2.2</artifactId>
			<version>0.10.0</version>
			<scope>provided</scope>
		</dependency>-->

	</dependencies>

	<profiles>
		<profile>
			<id>dist</id>
			<properties>
				<spark.deps.scope>provided</spark.deps.scope>
			</properties>
			<build>
				<plugins>
					<plugin>
						<groupId>org.apache.maven.plugins</groupId>
						<artifactId>maven-shade-plugin</artifactId>
						<executions>
							<execution>
								<phase>package</phase>
								<goals>
									<goal>shade</goal>
								</goals>
								<configuration>
									<artifactSet>
										<excludes>
											<exclude>org.apache.spark:spark-core_${scala.binary.version}</exclude>
											<exclude>org.apache.spark:spark-sql_${scala.binary.version}</exclude>
											<exclude>org.apache.spark:spark-graphx_${scala.binary.version}</exclude>
											<exclude>org.apache.spark:*</exclude>
											<!-- <exclude>org.eclipse.jetty:jetty-server</exclude> -->
											<!-- <exclude>org.eclipse.jetty:jetty-continuation</exclude> -->
											<!-- <exclude>org.eclipse.jetty:jetty-http</exclude> -->
											<!-- <exclude>org.eclipse.jetty:jetty-io</exclude> -->
											<!-- <exclude>org.eclipse.jetty:jetty-util</exclude> -->
											<!-- <exclude>org.eclipse.jetty:jetty-security</exclude> -->
											<!-- <exclude>org.eclipse.jetty:jetty-servlet</exclude> -->
											<!-- <exclude>org.eclipse.jetty:*</exclude> -->
											<!-- <exclude>org.glassfish.*:*</exclude> -->
											<exclude>org.netbeans.api:*</exclude>
											<exclude>org.netbeans:*</exclude>
											<exclude>org.scala-lang:scala-library</exclude>
											<exclude>org.scala-lang:scala-compiler</exclude>
											<exclude>org.scala-lang:scala-reflect</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>
											<exclude>io.netty:netty*</exclude>
<!--
											<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.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.mesos:mesos</exclude>
											<exclude>org.apache.parquet:parquet*</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> no longer used-->
											<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>
											<exclude>org.gephi:*</exclude>
											<exclude>org.jfree:*</exclude>
											<exclude>com.itextpdf:*</exclude>
											<exclude>org.apache.poi:*</exclude>
											<exclude>org.apache.batik:*</exclude>
											<exclude>org.apache.xmlgraphics:*</exclude>
											<exclude>com.intel.analytics.bigdl:*</exclude>
										</excludes>
									</artifactSet>
									<filters>
										<filter>
											<artifact>*:*</artifact>
											<excludes>
												<!-- Avoid a Spark error: Invalid signature file digest for Manifest main attributes-->
												<exclude>META-INF/*.SF</exclude>
												<exclude>META-INF/*.DSA</exclude>
												<exclude>META-INF/*.RSA</exclude>
												<exclude>META-INF/maven/**</exclude>
											</excludes>
										</filter>
										<filter>
											<artifact>org.apache.jena:*</artifact>
											<includes>
												<include>**</include>
											</includes>
										</filter>
										<filter>
											<artifact>org.apache.httpcomponents:*</artifact>
											<includes>
												<include>**</include>
											</includes>
										</filter>
										<filter>
											<artifact>xerces:xercesImpl</artifact>
											<includes>
												<include>**</include>
											</includes>
										</filter>
										<filter>
											<artifact>org.aksw.jena-sparql-api:*</artifact>
											<includes>
												<include>**</include>
											</includes>
										</filter>
										<filter>
											<artifact>org.aksw.jena-sparql-api:*</artifact>
											<excludes>
												<exclude>META-INF/services/org.apache.jena.sys.JenaSubsystemLifecycle</exclude>
											</excludes>
										</filter>
									</filters>
									<!--                                    <finalName>${project.artifactId}.jar</finalName>-->
									<transformers>
										<transformer implementation="org.apache.maven.plugins.shade.resource.ServicesResourceTransformer"/>
									</transformers>
									<createDependencyReducedPom>false</createDependencyReducedPom>

									<relocations>
										<relocation>
											<pattern>com.google</pattern>
											<shadedPattern>net.sansa_stack.ext.com.google</shadedPattern>
										</relocation>
									</relocations>
								</configuration>
							</execution>
						</executions>
					</plugin>
				</plugins>
			</build>
		</profile>
	</profiles>

</project>
