Merge branch 'master' of https://github.com/eugenp/tutorials into BAEL-3860
This commit is contained in:
commit
0c4dd2c8f0
|
@ -13,6 +13,5 @@ This module contains articles about algorithms. Some classes of algorithms, e.g.
|
||||||
- [Checking if a Java Graph has a Cycle](https://www.baeldung.com/java-graph-has-a-cycle)
|
- [Checking if a Java Graph has a Cycle](https://www.baeldung.com/java-graph-has-a-cycle)
|
||||||
- [A Guide to the Folding Technique in Java](https://www.baeldung.com/folding-hashing-technique)
|
- [A Guide to the Folding Technique in Java](https://www.baeldung.com/folding-hashing-technique)
|
||||||
- [Creating a Triangle with for Loops in Java](https://www.baeldung.com/java-print-triangle)
|
- [Creating a Triangle with for Loops in Java](https://www.baeldung.com/java-print-triangle)
|
||||||
- [Efficient Word Frequency Calculator in Java](https://www.baeldung.com/java-word-frequency)
|
|
||||||
- [The K-Means Clustering Algorithm in Java](https://www.baeldung.com/java-k-means-clustering-algorithm)
|
- [The K-Means Clustering Algorithm in Java](https://www.baeldung.com/java-k-means-clustering-algorithm)
|
||||||
- More articles: [[<-- prev]](/algorithms-miscellaneous-2) [[next -->]](/algorithms-miscellaneous-4)
|
- More articles: [[<-- prev]](/algorithms-miscellaneous-2) [[next -->]](/algorithms-miscellaneous-4)
|
||||||
|
|
|
@ -0,0 +1,4 @@
|
||||||
|
### Relevant Articles:
|
||||||
|
|
||||||
|
- [Boruvka’s Algorithm for Minimum Spanning Trees](https://www.baeldung.com/java-boruvka-algorithm)
|
||||||
|
- [Gradient Descent in Java](https://www.baeldung.com/java-gradient-descent)
|
|
@ -1,3 +0,0 @@
|
||||||
### Relevant Articles:
|
|
||||||
|
|
||||||
- [Intro to OData with Olingo](https://www.baeldung.com/olingo)
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
## Atomikos
|
||||||
|
|
||||||
|
This module contains articles about Atomikos
|
||||||
|
|
||||||
|
### Relevant Articles:
|
||||||
|
|
||||||
|
- [Guide Transactions Using Atomikos]()
|
|
@ -0,0 +1,119 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<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>
|
||||||
|
<artifactId>atomikos</artifactId>
|
||||||
|
<name>atomikos</name>
|
||||||
|
|
||||||
|
<parent>
|
||||||
|
<groupId>com.baeldung</groupId>
|
||||||
|
<artifactId>parent-modules</artifactId>
|
||||||
|
<version>1.0.0-SNAPSHOT</version>
|
||||||
|
</parent>
|
||||||
|
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.atomikos</groupId>
|
||||||
|
<artifactId>transactions-jdbc</artifactId>
|
||||||
|
<version>${atomikos-version}</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.atomikos</groupId>
|
||||||
|
<artifactId>transactions-jms</artifactId>
|
||||||
|
<version>${atomikos-version}</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.atomikos</groupId>
|
||||||
|
<artifactId>transactions-hibernate4</artifactId>
|
||||||
|
<version>${atomikos-version}</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework</groupId>
|
||||||
|
<artifactId>spring-context</artifactId>
|
||||||
|
<version>${spring-version}</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework</groupId>
|
||||||
|
<artifactId>spring-tx</artifactId>
|
||||||
|
<version>${spring-version}</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.data</groupId>
|
||||||
|
<artifactId>spring-data-jpa</artifactId>
|
||||||
|
<version>1.11.23.RELEASE</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework</groupId>
|
||||||
|
<artifactId>spring-test</artifactId>
|
||||||
|
<version>${spring-version}</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.hibernate</groupId>
|
||||||
|
<artifactId>hibernate-entitymanager</artifactId>
|
||||||
|
<version>${hibernate.version}</version>
|
||||||
|
<scope>provided</scope>
|
||||||
|
<exclusions>
|
||||||
|
<exclusion>
|
||||||
|
<groupId>javax.transaction</groupId>
|
||||||
|
<artifactId>jta</artifactId>
|
||||||
|
</exclusion>
|
||||||
|
</exclusions>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.apache.activemq</groupId>
|
||||||
|
<artifactId>activemq-core</artifactId>
|
||||||
|
<version>5.7.0</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.apache.derby</groupId>
|
||||||
|
<artifactId>derby</artifactId>
|
||||||
|
<version>10.8.1.2</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>junit</groupId>
|
||||||
|
<artifactId>junit</artifactId>
|
||||||
|
<version>4.12</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
<!-- the JTA API -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>javax.transaction</groupId>
|
||||||
|
<artifactId>jta</artifactId>
|
||||||
|
<version>1.1</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.apache.geronimo.specs</groupId>
|
||||||
|
<artifactId>geronimo-jta_1.0.1B_spec</artifactId>
|
||||||
|
<version>1.0</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>javax.validation</groupId>
|
||||||
|
<artifactId>validation-api</artifactId>
|
||||||
|
<version>2.0.1.Final</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.hibernate.validator</groupId>
|
||||||
|
<artifactId>hibernate-validator</artifactId>
|
||||||
|
<version>6.1.2.Final</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>javax.el</groupId>
|
||||||
|
<artifactId>javax.el-api</artifactId>
|
||||||
|
<version>3.0.0</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.glassfish.web</groupId>
|
||||||
|
<artifactId>javax.el</artifactId>
|
||||||
|
<version>2.2.4</version>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
|
||||||
|
<properties>
|
||||||
|
<atomikos-version>5.0.6</atomikos-version>
|
||||||
|
<spring-version>5.1.6.RELEASE</spring-version>
|
||||||
|
<hibernate.version>5.4.3.Final</hibernate.version>
|
||||||
|
</properties>
|
||||||
|
|
||||||
|
</project>
|
|
@ -0,0 +1,53 @@
|
||||||
|
package com.baeldung.atomikos.direct;
|
||||||
|
|
||||||
|
import java.sql.Connection;
|
||||||
|
import java.sql.Statement;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import javax.sql.DataSource;
|
||||||
|
|
||||||
|
import com.atomikos.icatch.jta.UserTransactionImp;
|
||||||
|
|
||||||
|
public class Application {
|
||||||
|
|
||||||
|
private DataSource inventoryDataSource;
|
||||||
|
private DataSource orderDataSource;
|
||||||
|
|
||||||
|
public Application(DataSource inventoryDataSource, DataSource orderDataSource) {
|
||||||
|
this.inventoryDataSource = inventoryDataSource;
|
||||||
|
this.orderDataSource = orderDataSource;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void placeOrder(String productId, int amount) throws Exception {
|
||||||
|
|
||||||
|
UserTransactionImp utx = new UserTransactionImp();
|
||||||
|
String orderId = UUID.randomUUID()
|
||||||
|
.toString();
|
||||||
|
boolean rollback = false;
|
||||||
|
try {
|
||||||
|
utx.begin();
|
||||||
|
Connection inventoryConnection = inventoryDataSource.getConnection();
|
||||||
|
Connection orderConnection = orderDataSource.getConnection();
|
||||||
|
Statement s1 = inventoryConnection.createStatement();
|
||||||
|
String q1 = "update Inventory set balance = balance - " + amount + " where productId ='" + productId + "'";
|
||||||
|
s1.executeUpdate(q1);
|
||||||
|
s1.close();
|
||||||
|
Statement s2 = orderConnection.createStatement();
|
||||||
|
String q2 = "insert into Orders values ( '" + orderId + "', '" + productId + "', " + amount + " )";
|
||||||
|
s2.executeUpdate(q2);
|
||||||
|
s2.close();
|
||||||
|
inventoryConnection.close();
|
||||||
|
orderConnection.close();
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println(e.getMessage());
|
||||||
|
rollback = true;
|
||||||
|
} finally {
|
||||||
|
if (!rollback)
|
||||||
|
utx.commit();
|
||||||
|
else
|
||||||
|
utx.rollback();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,41 @@
|
||||||
|
package com.baeldung.atomikos.spring;
|
||||||
|
|
||||||
|
import java.sql.Connection;
|
||||||
|
import java.sql.Statement;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import javax.sql.DataSource;
|
||||||
|
|
||||||
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
|
public class Application {
|
||||||
|
|
||||||
|
private DataSource inventoryDataSource;
|
||||||
|
private DataSource orderDataSource;
|
||||||
|
|
||||||
|
public Application(DataSource inventoryDataSource, DataSource orderDataSource) {
|
||||||
|
this.inventoryDataSource = inventoryDataSource;
|
||||||
|
this.orderDataSource = orderDataSource;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
public void placeOrder(String productId, int amount) throws Exception {
|
||||||
|
|
||||||
|
String orderId = UUID.randomUUID()
|
||||||
|
.toString();
|
||||||
|
Connection inventoryConnection = inventoryDataSource.getConnection();
|
||||||
|
Connection orderConnection = orderDataSource.getConnection();
|
||||||
|
Statement s1 = inventoryConnection.createStatement();
|
||||||
|
String q1 = "update Inventory set balance = balance - " + amount + " where productId ='" + productId + "'";
|
||||||
|
s1.executeUpdate(q1);
|
||||||
|
s1.close();
|
||||||
|
Statement s2 = orderConnection.createStatement();
|
||||||
|
String q2 = "insert into Orders values ( '" + orderId + "', '" + productId + "', " + amount + " )";
|
||||||
|
s2.executeUpdate(q2);
|
||||||
|
s2.close();
|
||||||
|
inventoryConnection.close();
|
||||||
|
orderConnection.close();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,68 @@
|
||||||
|
package com.baeldung.atomikos.spring.config;
|
||||||
|
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
import javax.transaction.SystemException;
|
||||||
|
|
||||||
|
import org.springframework.context.annotation.Bean;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.transaction.annotation.EnableTransactionManagement;
|
||||||
|
import org.springframework.transaction.jta.JtaTransactionManager;
|
||||||
|
|
||||||
|
import com.atomikos.icatch.jta.UserTransactionManager;
|
||||||
|
import com.atomikos.jdbc.AtomikosDataSourceBean;
|
||||||
|
import com.baeldung.atomikos.spring.Application;
|
||||||
|
|
||||||
|
@Configuration
|
||||||
|
@EnableTransactionManagement
|
||||||
|
public class Config {
|
||||||
|
|
||||||
|
@Bean(initMethod = "init", destroyMethod = "close")
|
||||||
|
public AtomikosDataSourceBean inventoryDataSource() {
|
||||||
|
AtomikosDataSourceBean dataSource = new AtomikosDataSourceBean();
|
||||||
|
dataSource.setLocalTransactionMode(true);
|
||||||
|
dataSource.setUniqueResourceName("db1");
|
||||||
|
dataSource.setXaDataSourceClassName("org.apache.derby.jdbc.EmbeddedXADataSource");
|
||||||
|
Properties xaProperties = new Properties();
|
||||||
|
xaProperties.put("databaseName", "db1");
|
||||||
|
xaProperties.put("createDatabase", "create");
|
||||||
|
dataSource.setXaProperties(xaProperties);
|
||||||
|
dataSource.setPoolSize(10);
|
||||||
|
return dataSource;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean(initMethod = "init", destroyMethod = "close")
|
||||||
|
public AtomikosDataSourceBean orderDataSource() {
|
||||||
|
AtomikosDataSourceBean dataSource = new AtomikosDataSourceBean();
|
||||||
|
dataSource.setLocalTransactionMode(true);
|
||||||
|
dataSource.setUniqueResourceName("db2");
|
||||||
|
dataSource.setXaDataSourceClassName("org.apache.derby.jdbc.EmbeddedXADataSource");
|
||||||
|
Properties xaProperties = new Properties();
|
||||||
|
xaProperties.put("databaseName", "db2");
|
||||||
|
xaProperties.put("createDatabase", "create");
|
||||||
|
dataSource.setXaProperties(xaProperties);
|
||||||
|
dataSource.setPoolSize(10);
|
||||||
|
return dataSource;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean(initMethod = "init", destroyMethod = "close")
|
||||||
|
public UserTransactionManager userTransactionManager() throws SystemException {
|
||||||
|
UserTransactionManager userTransactionManager = new UserTransactionManager();
|
||||||
|
userTransactionManager.setTransactionTimeout(300);
|
||||||
|
userTransactionManager.setForceShutdown(true);
|
||||||
|
return userTransactionManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public JtaTransactionManager jtaTransactionManager() throws SystemException {
|
||||||
|
JtaTransactionManager jtaTransactionManager = new JtaTransactionManager();
|
||||||
|
jtaTransactionManager.setTransactionManager(userTransactionManager());
|
||||||
|
jtaTransactionManager.setUserTransaction(userTransactionManager());
|
||||||
|
return jtaTransactionManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public Application application() {
|
||||||
|
return new Application(inventoryDataSource(), orderDataSource());
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,48 @@
|
||||||
|
package com.baeldung.atomikos.spring.jpa;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import javax.validation.ConstraintViolation;
|
||||||
|
import javax.validation.Validation;
|
||||||
|
import javax.validation.Validator;
|
||||||
|
import javax.validation.ValidatorFactory;
|
||||||
|
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
|
import com.baeldung.atomikos.spring.jpa.inventory.Inventory;
|
||||||
|
import com.baeldung.atomikos.spring.jpa.inventory.InventoryRepository;
|
||||||
|
import com.baeldung.atomikos.spring.jpa.order.Order;
|
||||||
|
import com.baeldung.atomikos.spring.jpa.order.OrderRepository;
|
||||||
|
|
||||||
|
public class Application {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private InventoryRepository inventoryRepository;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private OrderRepository orderRepository;
|
||||||
|
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
public void placeOrder(String productId, int amount) throws Exception {
|
||||||
|
|
||||||
|
String orderId = UUID.randomUUID()
|
||||||
|
.toString();
|
||||||
|
Inventory inventory = inventoryRepository.findOne(productId);
|
||||||
|
inventory.setBalance(inventory.getBalance() - amount);
|
||||||
|
inventoryRepository.save(inventory);
|
||||||
|
Order order = new Order();
|
||||||
|
order.setOrderId(orderId);
|
||||||
|
order.setProductId(productId);
|
||||||
|
order.setAmount(new Long(amount));
|
||||||
|
ValidatorFactory factory = Validation.buildDefaultValidatorFactory();
|
||||||
|
Validator validator = factory.getValidator();
|
||||||
|
Set<ConstraintViolation<Order>> violations = validator.validate(order);
|
||||||
|
if (violations.size() > 0)
|
||||||
|
throw new Exception("Invalid instance of an order.");
|
||||||
|
orderRepository.save(order);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,38 @@
|
||||||
|
package com.baeldung.atomikos.spring.jpa.config;
|
||||||
|
|
||||||
|
import javax.transaction.SystemException;
|
||||||
|
|
||||||
|
import org.springframework.context.annotation.Bean;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.transaction.annotation.EnableTransactionManagement;
|
||||||
|
import org.springframework.transaction.jta.JtaTransactionManager;
|
||||||
|
|
||||||
|
import com.atomikos.icatch.jta.UserTransactionManager;
|
||||||
|
import com.baeldung.atomikos.spring.jpa.Application;
|
||||||
|
|
||||||
|
@Configuration
|
||||||
|
@EnableTransactionManagement
|
||||||
|
public class Config {
|
||||||
|
|
||||||
|
@Bean(initMethod = "init", destroyMethod = "close")
|
||||||
|
public UserTransactionManager userTransactionManager() throws SystemException {
|
||||||
|
UserTransactionManager userTransactionManager = new UserTransactionManager();
|
||||||
|
userTransactionManager.setTransactionTimeout(300);
|
||||||
|
userTransactionManager.setForceShutdown(true);
|
||||||
|
return userTransactionManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public JtaTransactionManager transactionManager() throws SystemException {
|
||||||
|
JtaTransactionManager jtaTransactionManager = new JtaTransactionManager();
|
||||||
|
jtaTransactionManager.setTransactionManager(userTransactionManager());
|
||||||
|
jtaTransactionManager.setUserTransaction(userTransactionManager());
|
||||||
|
return jtaTransactionManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public Application application() {
|
||||||
|
return new Application();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,31 @@
|
||||||
|
package com.baeldung.atomikos.spring.jpa.inventory;
|
||||||
|
|
||||||
|
import javax.persistence.Entity;
|
||||||
|
import javax.persistence.Id;
|
||||||
|
import javax.persistence.Table;
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@Table(name = "INVENTORY")
|
||||||
|
public class Inventory {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
private String productId;
|
||||||
|
private Long balance;
|
||||||
|
|
||||||
|
public String getProductId() {
|
||||||
|
return productId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setProductId(String productId) {
|
||||||
|
this.productId = productId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getBalance() {
|
||||||
|
return balance;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setBalance(Long balance) {
|
||||||
|
this.balance = balance;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,53 @@
|
||||||
|
package com.baeldung.atomikos.spring.jpa.inventory;
|
||||||
|
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
import javax.persistence.EntityManagerFactory;
|
||||||
|
|
||||||
|
import org.springframework.context.annotation.Bean;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
|
||||||
|
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
|
||||||
|
import org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter;
|
||||||
|
|
||||||
|
import com.atomikos.jdbc.AtomikosDataSourceBean;
|
||||||
|
|
||||||
|
@Configuration
|
||||||
|
@EnableJpaRepositories(basePackages = "com.baeldung.atomikos.spring.jpa.inventory", entityManagerFactoryRef = "inventoryEntityManager", transactionManagerRef = "transactionManager")
|
||||||
|
public class InventoryConfig {
|
||||||
|
|
||||||
|
@Bean(initMethod = "init", destroyMethod = "close")
|
||||||
|
public AtomikosDataSourceBean inventoryDataSource() {
|
||||||
|
AtomikosDataSourceBean dataSource = new AtomikosDataSourceBean();
|
||||||
|
dataSource.setLocalTransactionMode(true);
|
||||||
|
dataSource.setUniqueResourceName("db1");
|
||||||
|
dataSource.setXaDataSourceClassName("org.apache.derby.jdbc.EmbeddedXADataSource");
|
||||||
|
Properties xaProperties = new Properties();
|
||||||
|
xaProperties.put("databaseName", "db1");
|
||||||
|
xaProperties.put("createDatabase", "create");
|
||||||
|
dataSource.setXaProperties(xaProperties);
|
||||||
|
dataSource.setPoolSize(10);
|
||||||
|
return dataSource;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public EntityManagerFactory inventoryEntityManager() {
|
||||||
|
HibernateJpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();
|
||||||
|
LocalContainerEntityManagerFactoryBean factory = new LocalContainerEntityManagerFactoryBean();
|
||||||
|
factory.setJpaVendorAdapter(vendorAdapter);
|
||||||
|
factory.setPackagesToScan("com.baeldung.atomikos.spring.jpa.inventory");
|
||||||
|
factory.setDataSource(inventoryDataSource());
|
||||||
|
Properties jpaProperties = new Properties();
|
||||||
|
//jpaProperties.put("hibernate.show_sql", "true");
|
||||||
|
//jpaProperties.put("hibernate.format_sql", "true");
|
||||||
|
jpaProperties.put("hibernate.dialect", "org.hibernate.dialect.DerbyDialect");
|
||||||
|
jpaProperties.put("hibernate.current_session_context_class", "jta");
|
||||||
|
jpaProperties.put("javax.persistence.transactionType", "jta");
|
||||||
|
jpaProperties.put("hibernate.transaction.manager_lookup_class", "com.atomikos.icatch.jta.hibernate3.TransactionManagerLookup");
|
||||||
|
jpaProperties.put("hibernate.hbm2ddl.auto", "create-drop");
|
||||||
|
factory.setJpaProperties(jpaProperties);
|
||||||
|
factory.afterPropertiesSet();
|
||||||
|
return factory.getObject();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,9 @@
|
||||||
|
package com.baeldung.atomikos.spring.jpa.inventory;
|
||||||
|
|
||||||
|
import org.springframework.data.jpa.repository.JpaRepository;
|
||||||
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
|
@Repository
|
||||||
|
public interface InventoryRepository extends JpaRepository<Inventory, String> {
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,42 @@
|
||||||
|
package com.baeldung.atomikos.spring.jpa.order;
|
||||||
|
|
||||||
|
import javax.persistence.Entity;
|
||||||
|
import javax.persistence.Id;
|
||||||
|
import javax.persistence.Table;
|
||||||
|
import javax.validation.constraints.Max;
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@Table(name = "ORDERS")
|
||||||
|
public class Order {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
private String orderId;
|
||||||
|
private String productId;
|
||||||
|
@Max(5)
|
||||||
|
private Long amount;
|
||||||
|
|
||||||
|
public String getOrderId() {
|
||||||
|
return orderId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setOrderId(String orderId) {
|
||||||
|
this.orderId = orderId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getProductId() {
|
||||||
|
return productId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setProductId(String productId) {
|
||||||
|
this.productId = productId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getAmount() {
|
||||||
|
return amount;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setAmount(Long amount) {
|
||||||
|
this.amount = amount;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,53 @@
|
||||||
|
package com.baeldung.atomikos.spring.jpa.order;
|
||||||
|
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
import javax.persistence.EntityManagerFactory;
|
||||||
|
|
||||||
|
import org.springframework.context.annotation.Bean;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
|
||||||
|
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
|
||||||
|
import org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter;
|
||||||
|
|
||||||
|
import com.atomikos.jdbc.AtomikosDataSourceBean;
|
||||||
|
|
||||||
|
@Configuration
|
||||||
|
@EnableJpaRepositories(basePackages = "com.baeldung.atomikos.spring.jpa.order", entityManagerFactoryRef = "orderEntityManager", transactionManagerRef = "transactionManager")
|
||||||
|
public class OrderConfig {
|
||||||
|
|
||||||
|
@Bean(initMethod = "init", destroyMethod = "close")
|
||||||
|
public AtomikosDataSourceBean orderDataSource() {
|
||||||
|
AtomikosDataSourceBean dataSource = new AtomikosDataSourceBean();
|
||||||
|
dataSource.setLocalTransactionMode(true);
|
||||||
|
dataSource.setUniqueResourceName("db2");
|
||||||
|
dataSource.setXaDataSourceClassName("org.apache.derby.jdbc.EmbeddedXADataSource");
|
||||||
|
Properties xaProperties = new Properties();
|
||||||
|
xaProperties.put("databaseName", "db2");
|
||||||
|
xaProperties.put("createDatabase", "create");
|
||||||
|
dataSource.setXaProperties(xaProperties);
|
||||||
|
dataSource.setPoolSize(10);
|
||||||
|
return dataSource;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public EntityManagerFactory orderEntityManager() {
|
||||||
|
HibernateJpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();
|
||||||
|
LocalContainerEntityManagerFactoryBean factory = new LocalContainerEntityManagerFactoryBean();
|
||||||
|
factory.setJpaVendorAdapter(vendorAdapter);
|
||||||
|
factory.setPackagesToScan("com.baeldung.atomikos.spring.jpa.order");
|
||||||
|
factory.setDataSource(orderDataSource());
|
||||||
|
Properties jpaProperties = new Properties();
|
||||||
|
//jpaProperties.put("hibernate.show_sql", "true");
|
||||||
|
//jpaProperties.put("hibernate.format_sql", "true");
|
||||||
|
jpaProperties.put("hibernate.dialect", "org.hibernate.dialect.DerbyDialect");
|
||||||
|
jpaProperties.put("hibernate.current_session_context_class", "jta");
|
||||||
|
jpaProperties.put("javax.persistence.transactionType", "jta");
|
||||||
|
jpaProperties.put("hibernate.transaction.manager_lookup_class", "com.atomikos.icatch.jta.hibernate3.TransactionManagerLookup");
|
||||||
|
jpaProperties.put("hibernate.hbm2ddl.auto", "create-drop");
|
||||||
|
factory.setJpaProperties(jpaProperties);
|
||||||
|
factory.afterPropertiesSet();
|
||||||
|
return factory.getObject();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,9 @@
|
||||||
|
package com.baeldung.atomikos.spring.jpa.order;
|
||||||
|
|
||||||
|
import org.springframework.data.jpa.repository.JpaRepository;
|
||||||
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
|
@Repository
|
||||||
|
public interface OrderRepository extends JpaRepository<Order, String> {
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,10 @@
|
||||||
|
CREATE TABLE INVENTORY (
|
||||||
|
productId VARCHAR PRIMARY KEY,
|
||||||
|
balance INT
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE TABLE ORDERS (
|
||||||
|
orderId VARCHAR PRIMARY KEY,
|
||||||
|
productId VARCHAR,
|
||||||
|
amount INT NOT NULL CHECK (amount <= 5)
|
||||||
|
);
|
|
@ -0,0 +1 @@
|
||||||
|
com.atomikos.icatch.file=logs
|
|
@ -0,0 +1,118 @@
|
||||||
|
package com.baeldung.atomikos.direct;
|
||||||
|
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||||
|
|
||||||
|
import java.sql.Connection;
|
||||||
|
import java.sql.ResultSet;
|
||||||
|
import java.sql.SQLException;
|
||||||
|
import java.sql.Statement;
|
||||||
|
import java.util.Properties;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import javax.sql.DataSource;
|
||||||
|
|
||||||
|
import org.junit.BeforeClass;
|
||||||
|
import org.junit.Ignore;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import com.atomikos.icatch.jta.UserTransactionImp;
|
||||||
|
import com.atomikos.jdbc.AtomikosDataSourceBean;
|
||||||
|
|
||||||
|
public class ApplicationUnitTest {
|
||||||
|
|
||||||
|
private static DataSource inventoryDataSource;
|
||||||
|
private static DataSource orderDataSource;
|
||||||
|
|
||||||
|
private static String productId = UUID.randomUUID()
|
||||||
|
.toString();
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Ignore
|
||||||
|
public void testPlaceOrderSuccess() throws Exception {
|
||||||
|
int amount = 1;
|
||||||
|
long initialBalance = getBalance(inventoryDataSource, productId);
|
||||||
|
Application application = new Application(inventoryDataSource, orderDataSource);
|
||||||
|
application.placeOrder(productId, amount);
|
||||||
|
long finalBalance = getBalance(inventoryDataSource, productId);
|
||||||
|
assertEquals(initialBalance - amount, finalBalance);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Ignore
|
||||||
|
public void testPlaceOrderFailure() throws Exception {
|
||||||
|
int amount = 10;
|
||||||
|
long initialBalance = getBalance(inventoryDataSource, productId);
|
||||||
|
Application application = new Application(inventoryDataSource, orderDataSource);
|
||||||
|
application.placeOrder(productId, amount);
|
||||||
|
long finalBalance = getBalance(inventoryDataSource, productId);
|
||||||
|
assertEquals(initialBalance, finalBalance);
|
||||||
|
}
|
||||||
|
|
||||||
|
@BeforeClass
|
||||||
|
public static void setUp() throws SQLException {
|
||||||
|
|
||||||
|
inventoryDataSource = getDataSource("db1");
|
||||||
|
orderDataSource = getDataSource("db2");
|
||||||
|
Connection inventoryConnection = inventoryDataSource.getConnection();
|
||||||
|
Connection orderConnection = orderDataSource.getConnection();
|
||||||
|
String createInventoryTable = "create table Inventory ( " + " productId VARCHAR ( 100 ) PRIMARY KEY, balance INT )";
|
||||||
|
String createInventoryRow = "insert into Inventory values ( '" + productId + "', 10000 )";
|
||||||
|
Statement s1 = inventoryConnection.createStatement();
|
||||||
|
try {
|
||||||
|
s1.executeUpdate(createInventoryTable);
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println("Inventory table exists");
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
s1.executeUpdate(createInventoryRow);
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println("Product row exists");
|
||||||
|
}
|
||||||
|
s1.close();
|
||||||
|
String createOrderTable = "create table Orders ( orderId VARCHAR ( 100 ) PRIMARY KEY, productId VARCHAR ( 100 ), amount INT NOT NULL CHECK (amount <= 5) )";
|
||||||
|
Statement s2 = orderConnection.createStatement();
|
||||||
|
try {
|
||||||
|
s2.executeUpdate(createOrderTable);
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println("Orders table exists");
|
||||||
|
}
|
||||||
|
s2.close();
|
||||||
|
inventoryConnection.close();
|
||||||
|
orderConnection.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
private static DataSource getDataSource(String db) {
|
||||||
|
|
||||||
|
DataSource ds;
|
||||||
|
AtomikosDataSourceBean ads = new AtomikosDataSourceBean();
|
||||||
|
ads.setXaDataSourceClassName("org.apache.derby.jdbc.EmbeddedXADataSource");
|
||||||
|
Properties properties = new Properties();
|
||||||
|
properties.put("databaseName", db);
|
||||||
|
properties.put("createDatabase", "create");
|
||||||
|
ads.setXaProperties(properties);
|
||||||
|
ads.setUniqueResourceName(db);
|
||||||
|
ads.setPoolSize(10); // optional
|
||||||
|
ads.setBorrowConnectionTimeout(10); // optional
|
||||||
|
ds = ads;
|
||||||
|
return ds;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private static long getBalance(DataSource inventoryDataSource, String productId) throws Exception {
|
||||||
|
|
||||||
|
UserTransactionImp utx = new UserTransactionImp();
|
||||||
|
utx.begin();
|
||||||
|
Connection inventoryConnection = inventoryDataSource.getConnection();
|
||||||
|
Statement s1 = inventoryConnection.createStatement();
|
||||||
|
String q1 = "select balance from Inventory where productId='" + productId + "'";
|
||||||
|
ResultSet rs1 = s1.executeQuery(q1);
|
||||||
|
if (rs1 == null || !rs1.next())
|
||||||
|
throw new Exception("Product not found: " + productId);
|
||||||
|
long balance = rs1.getLong(1);
|
||||||
|
inventoryConnection.close();
|
||||||
|
utx.commit();
|
||||||
|
return balance;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,108 @@
|
||||||
|
package com.baeldung.atomikos.spring;
|
||||||
|
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||||
|
|
||||||
|
import java.sql.Connection;
|
||||||
|
import java.sql.ResultSet;
|
||||||
|
import java.sql.SQLException;
|
||||||
|
import java.sql.Statement;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import javax.sql.DataSource;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Ignore;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.test.context.ContextConfiguration;
|
||||||
|
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
||||||
|
|
||||||
|
import com.baeldung.atomikos.spring.config.Config;
|
||||||
|
|
||||||
|
@RunWith(SpringJUnit4ClassRunner.class)
|
||||||
|
@ContextConfiguration(classes = { Config.class })
|
||||||
|
public class ApplicationUnitTest {
|
||||||
|
|
||||||
|
private static String productId = UUID.randomUUID()
|
||||||
|
.toString();
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
Application application;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
DataSource inventoryDataSource;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
DataSource orderDataSource;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Ignore
|
||||||
|
public void testPlaceOrderSuccess() throws Exception {
|
||||||
|
int amount = 1;
|
||||||
|
long initialBalance = getBalance(inventoryDataSource, productId);
|
||||||
|
application.placeOrder(productId, amount);
|
||||||
|
long finalBalance = getBalance(inventoryDataSource, productId);
|
||||||
|
assertEquals(initialBalance - amount, finalBalance);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Ignore
|
||||||
|
public void testPlaceOrderFailure() throws Exception {
|
||||||
|
int amount = 10;
|
||||||
|
long initialBalance = getBalance(inventoryDataSource, productId);
|
||||||
|
try {
|
||||||
|
application.placeOrder(productId, amount);
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println(e.getMessage());
|
||||||
|
}
|
||||||
|
long finalBalance = getBalance(inventoryDataSource, productId);
|
||||||
|
assertEquals(initialBalance, finalBalance);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() throws SQLException {
|
||||||
|
|
||||||
|
Connection inventoryConnection = inventoryDataSource.getConnection();
|
||||||
|
Connection orderConnection = orderDataSource.getConnection();
|
||||||
|
String createInventoryTable = "create table Inventory ( " + " productId VARCHAR ( 100 ) PRIMARY KEY, balance INT )";
|
||||||
|
String createInventoryRow = "insert into Inventory values ( '" + productId + "', 10000 )";
|
||||||
|
Statement s1 = inventoryConnection.createStatement();
|
||||||
|
try {
|
||||||
|
s1.executeUpdate(createInventoryTable);
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println("Inventory table exists");
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
s1.executeUpdate(createInventoryRow);
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println("Product row exists");
|
||||||
|
}
|
||||||
|
s1.close();
|
||||||
|
String createOrderTable = "create table Orders ( orderId VARCHAR ( 100 ) PRIMARY KEY, productId VARCHAR ( 100 ), amount INT NOT NULL CHECK (amount <= 5) )";
|
||||||
|
Statement s2 = orderConnection.createStatement();
|
||||||
|
try {
|
||||||
|
s2.executeUpdate(createOrderTable);
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println("Orders table exists");
|
||||||
|
}
|
||||||
|
s2.close();
|
||||||
|
inventoryConnection.close();
|
||||||
|
orderConnection.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
private static long getBalance(DataSource inventoryDataSource, String productId) throws Exception {
|
||||||
|
|
||||||
|
Connection inventoryConnection = inventoryDataSource.getConnection();
|
||||||
|
Statement s1 = inventoryConnection.createStatement();
|
||||||
|
String q1 = "select balance from Inventory where productId='" + productId + "'";
|
||||||
|
ResultSet rs1 = s1.executeQuery(q1);
|
||||||
|
if (rs1 == null || !rs1.next())
|
||||||
|
throw new Exception("Product not found: " + productId);
|
||||||
|
long balance = rs1.getLong(1);
|
||||||
|
inventoryConnection.close();
|
||||||
|
return balance;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,80 @@
|
||||||
|
package com.baeldung.atomikos.spring.jpa;
|
||||||
|
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||||
|
|
||||||
|
import java.sql.SQLException;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Ignore;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.test.context.ContextConfiguration;
|
||||||
|
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
||||||
|
|
||||||
|
import com.baeldung.atomikos.spring.jpa.config.Config;
|
||||||
|
import com.baeldung.atomikos.spring.jpa.inventory.Inventory;
|
||||||
|
import com.baeldung.atomikos.spring.jpa.inventory.InventoryConfig;
|
||||||
|
import com.baeldung.atomikos.spring.jpa.inventory.InventoryRepository;
|
||||||
|
import com.baeldung.atomikos.spring.jpa.order.OrderConfig;
|
||||||
|
import com.baeldung.atomikos.spring.jpa.order.OrderRepository;
|
||||||
|
|
||||||
|
@RunWith(SpringJUnit4ClassRunner.class)
|
||||||
|
@ContextConfiguration(classes = { Config.class, InventoryConfig.class, OrderConfig.class })
|
||||||
|
public class ApplicationUnitTest {
|
||||||
|
|
||||||
|
private static String productId = UUID.randomUUID()
|
||||||
|
.toString();
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
Application application;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
InventoryRepository inventoryRepository;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
OrderRepository orderRepository;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Ignore
|
||||||
|
public void testPlaceOrderSuccess() throws Exception {
|
||||||
|
int amount = 1;
|
||||||
|
long initialBalance = getBalance(inventoryRepository, productId);
|
||||||
|
application.placeOrder(productId, amount);
|
||||||
|
long finalBalance = getBalance(inventoryRepository, productId);
|
||||||
|
assertEquals(initialBalance - amount, finalBalance);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Ignore
|
||||||
|
public void testPlaceOrderFailure() throws Exception {
|
||||||
|
int amount = 10;
|
||||||
|
long initialBalance = getBalance(inventoryRepository, productId);
|
||||||
|
try {
|
||||||
|
application.placeOrder(productId, amount);
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println(e.getMessage());
|
||||||
|
}
|
||||||
|
long finalBalance = getBalance(inventoryRepository, productId);
|
||||||
|
assertEquals(initialBalance, finalBalance);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() throws SQLException {
|
||||||
|
|
||||||
|
Inventory inventory = new Inventory();
|
||||||
|
inventory.setProductId(productId);
|
||||||
|
inventory.setBalance(new Long(10000));
|
||||||
|
inventoryRepository.save(inventory);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private static long getBalance(InventoryRepository inventoryRepository, String productId) throws Exception {
|
||||||
|
|
||||||
|
return inventoryRepository.findOne(productId)
|
||||||
|
.getBalance();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,13 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<configuration>
|
||||||
|
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
|
||||||
|
<encoder>
|
||||||
|
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
|
||||||
|
</pattern>
|
||||||
|
</encoder>
|
||||||
|
</appender>
|
||||||
|
|
||||||
|
<root level="INFO">
|
||||||
|
<appender-ref ref="STDOUT" />
|
||||||
|
</root>
|
||||||
|
</configuration>
|
|
@ -0,0 +1 @@
|
||||||
|
com.atomikos.icatch.file=logs
|
|
@ -11,11 +11,15 @@
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
<artifactId>parent-boot-1</artifactId>
|
<artifactId>parent-boot-2</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<relativePath>../../parent-boot-1</relativePath>
|
<relativePath>../../parent-boot-2</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
<properties>
|
||||||
|
<spring-boot.version>2.2.6.RELEASE</spring-boot.version>
|
||||||
|
</properties>
|
||||||
|
|
||||||
<dependencies>
|
<dependencies>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.springframework.boot</groupId>
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
|
|
@ -1,91 +0,0 @@
|
||||||
package com.baeldung.cassecuredapp;
|
|
||||||
|
|
||||||
import org.jasig.cas.client.session.SingleSignOutFilter;
|
|
||||||
import org.jasig.cas.client.session.SingleSignOutHttpSessionListener;
|
|
||||||
import org.jasig.cas.client.validation.Cas30ServiceTicketValidator;
|
|
||||||
import org.jasig.cas.client.validation.TicketValidator;
|
|
||||||
import org.springframework.boot.SpringApplication;
|
|
||||||
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
|
||||||
import org.springframework.context.annotation.Bean;
|
|
||||||
import org.springframework.context.annotation.Primary;
|
|
||||||
import org.springframework.context.event.EventListener;
|
|
||||||
import org.springframework.security.cas.ServiceProperties;
|
|
||||||
import org.springframework.security.cas.authentication.CasAuthenticationProvider;
|
|
||||||
import org.springframework.security.cas.web.CasAuthenticationEntryPoint;
|
|
||||||
import org.springframework.security.core.authority.AuthorityUtils;
|
|
||||||
import org.springframework.security.core.context.SecurityContextHolder;
|
|
||||||
import org.springframework.security.core.userdetails.User;
|
|
||||||
import org.springframework.security.web.AuthenticationEntryPoint;
|
|
||||||
import org.springframework.security.web.authentication.logout.LogoutFilter;
|
|
||||||
import org.springframework.security.web.authentication.logout.SecurityContextLogoutHandler;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpSessionEvent;
|
|
||||||
|
|
||||||
@SpringBootApplication
|
|
||||||
public class CasSecuredAppApplication {
|
|
||||||
|
|
||||||
public static void main(String[] args) {
|
|
||||||
SpringApplication.run(CasSecuredAppApplication.class, args);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public ServiceProperties serviceProperties() {
|
|
||||||
ServiceProperties serviceProperties = new ServiceProperties();
|
|
||||||
serviceProperties.setService("http://localhost:9000/login/cas");
|
|
||||||
serviceProperties.setSendRenew(false);
|
|
||||||
return serviceProperties;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
@Primary
|
|
||||||
public AuthenticationEntryPoint authenticationEntryPoint(ServiceProperties sP) {
|
|
||||||
CasAuthenticationEntryPoint entryPoint = new CasAuthenticationEntryPoint();
|
|
||||||
entryPoint.setLoginUrl("https://localhost:6443/cas/login");
|
|
||||||
entryPoint.setServiceProperties(sP);
|
|
||||||
return entryPoint;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public TicketValidator ticketValidator() {
|
|
||||||
return new Cas30ServiceTicketValidator("https://localhost:6443/cas");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public CasAuthenticationProvider casAuthenticationProvider() {
|
|
||||||
CasAuthenticationProvider provider = new CasAuthenticationProvider();
|
|
||||||
provider.setServiceProperties(serviceProperties());
|
|
||||||
provider.setTicketValidator(ticketValidator());
|
|
||||||
provider.setUserDetailsService((s) -> new User("test@test.com", "smatt",
|
|
||||||
true, true, true, true,
|
|
||||||
AuthorityUtils.createAuthorityList("ROLE_ADMIN")));
|
|
||||||
provider.setKey("CAS_PROVIDER_LOCALHOST_9000");
|
|
||||||
return provider;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public SecurityContextLogoutHandler securityContextLogoutHandler() {
|
|
||||||
return new SecurityContextLogoutHandler();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public LogoutFilter logoutFilter() {
|
|
||||||
LogoutFilter logoutFilter = new LogoutFilter(
|
|
||||||
"https://localhost:6443/cas/logout", securityContextLogoutHandler());
|
|
||||||
logoutFilter.setFilterProcessesUrl("/logout/cas");
|
|
||||||
return logoutFilter;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public SingleSignOutFilter singleSignOutFilter() {
|
|
||||||
SingleSignOutFilter singleSignOutFilter = new SingleSignOutFilter();
|
|
||||||
singleSignOutFilter.setCasServerUrlPrefix("https://localhost:6443/cas");
|
|
||||||
singleSignOutFilter.setIgnoreInitConfiguration(true);
|
|
||||||
return singleSignOutFilter;
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventListener
|
|
||||||
public SingleSignOutHttpSessionListener singleSignOutHttpSessionListener(HttpSessionEvent event) {
|
|
||||||
return new SingleSignOutHttpSessionListener();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -0,0 +1,97 @@
|
||||||
|
package com.baeldung.cassecuredapp;
|
||||||
|
|
||||||
|
import org.jasig.cas.client.session.SingleSignOutFilter;
|
||||||
|
import org.jasig.cas.client.session.SingleSignOutHttpSessionListener;
|
||||||
|
import org.jasig.cas.client.validation.Cas30ServiceTicketValidator;
|
||||||
|
import org.jasig.cas.client.validation.TicketValidator;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
import org.springframework.boot.SpringApplication;
|
||||||
|
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||||
|
import org.springframework.context.annotation.Bean;
|
||||||
|
import org.springframework.context.annotation.Primary;
|
||||||
|
import org.springframework.context.event.EventListener;
|
||||||
|
import org.springframework.security.authentication.AuthenticationManager;
|
||||||
|
import org.springframework.security.cas.ServiceProperties;
|
||||||
|
import org.springframework.security.cas.authentication.CasAuthenticationProvider;
|
||||||
|
import org.springframework.security.cas.web.CasAuthenticationEntryPoint;
|
||||||
|
import org.springframework.security.cas.web.CasAuthenticationFilter;
|
||||||
|
import org.springframework.security.core.authority.AuthorityUtils;
|
||||||
|
import org.springframework.security.core.userdetails.User;
|
||||||
|
import org.springframework.security.web.AuthenticationEntryPoint;
|
||||||
|
import org.springframework.security.web.authentication.SavedRequestAwareAuthenticationSuccessHandler;
|
||||||
|
import org.springframework.security.web.authentication.logout.LogoutFilter;
|
||||||
|
import org.springframework.security.web.authentication.logout.SecurityContextLogoutHandler;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpSessionEvent;
|
||||||
|
|
||||||
|
@SpringBootApplication
|
||||||
|
public class CasSecuredApplication {
|
||||||
|
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(CasSecuredApplication.class);
|
||||||
|
|
||||||
|
public static void main(String... args) {
|
||||||
|
SpringApplication.run(CasSecuredApplication.class, args);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public CasAuthenticationFilter casAuthenticationFilter(
|
||||||
|
AuthenticationManager authenticationManager,
|
||||||
|
ServiceProperties serviceProperties) throws Exception {
|
||||||
|
CasAuthenticationFilter filter = new CasAuthenticationFilter();
|
||||||
|
filter.setAuthenticationManager(authenticationManager);
|
||||||
|
filter.setServiceProperties(serviceProperties);
|
||||||
|
return filter;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public ServiceProperties serviceProperties() {
|
||||||
|
logger.info("service properties");
|
||||||
|
ServiceProperties serviceProperties = new ServiceProperties();
|
||||||
|
serviceProperties.setService("http://cas-client:8900/login/cas");
|
||||||
|
serviceProperties.setSendRenew(false);
|
||||||
|
return serviceProperties;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public TicketValidator ticketValidator() {
|
||||||
|
return new Cas30ServiceTicketValidator("https://localhost:8443");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public CasAuthenticationProvider casAuthenticationProvider(
|
||||||
|
TicketValidator ticketValidator,
|
||||||
|
ServiceProperties serviceProperties) {
|
||||||
|
CasAuthenticationProvider provider = new CasAuthenticationProvider();
|
||||||
|
provider.setServiceProperties(serviceProperties);
|
||||||
|
provider.setTicketValidator(ticketValidator);
|
||||||
|
provider.setUserDetailsService(
|
||||||
|
s -> new User("test@test.com", "Mellon", true, true, true, true,
|
||||||
|
AuthorityUtils.createAuthorityList("ROLE_ADMIN")));
|
||||||
|
provider.setKey("CAS_PROVIDER_LOCALHOST_8900");
|
||||||
|
return provider;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public SecurityContextLogoutHandler securityContextLogoutHandler() {
|
||||||
|
return new SecurityContextLogoutHandler();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public LogoutFilter logoutFilter() {
|
||||||
|
LogoutFilter logoutFilter = new LogoutFilter("https://localhost:8443/logout", securityContextLogoutHandler());
|
||||||
|
logoutFilter.setFilterProcessesUrl("/logout/cas");
|
||||||
|
return logoutFilter;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public SingleSignOutFilter singleSignOutFilter() {
|
||||||
|
SingleSignOutFilter singleSignOutFilter = new SingleSignOutFilter();
|
||||||
|
singleSignOutFilter.setCasServerUrlPrefix("https://localhost:8443");
|
||||||
|
singleSignOutFilter.setLogoutCallbackPath("/exit/cas");
|
||||||
|
singleSignOutFilter.setIgnoreInitConfiguration(true);
|
||||||
|
return singleSignOutFilter;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -1,83 +0,0 @@
|
||||||
package com.baeldung.cassecuredapp.config;
|
|
||||||
|
|
||||||
import org.jasig.cas.client.session.SingleSignOutFilter;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.context.annotation.Bean;
|
|
||||||
import org.springframework.context.annotation.Configuration;
|
|
||||||
import org.springframework.security.authentication.AuthenticationManager;
|
|
||||||
import org.springframework.security.authentication.AuthenticationProvider;
|
|
||||||
import org.springframework.security.authentication.ProviderManager;
|
|
||||||
import org.springframework.security.cas.ServiceProperties;
|
|
||||||
import org.springframework.security.cas.authentication.CasAuthenticationProvider;
|
|
||||||
import org.springframework.security.cas.web.CasAuthenticationFilter;
|
|
||||||
import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder;
|
|
||||||
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
|
|
||||||
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
|
|
||||||
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
|
|
||||||
import org.springframework.security.web.AuthenticationEntryPoint;
|
|
||||||
import org.springframework.security.web.authentication.logout.LogoutFilter;
|
|
||||||
|
|
||||||
import java.util.Arrays;
|
|
||||||
|
|
||||||
@EnableWebSecurity
|
|
||||||
@Configuration
|
|
||||||
public class SecurityConfig extends WebSecurityConfigurerAdapter {
|
|
||||||
|
|
||||||
private AuthenticationProvider authenticationProvider;
|
|
||||||
private AuthenticationEntryPoint authenticationEntryPoint;
|
|
||||||
private SingleSignOutFilter singleSignOutFilter;
|
|
||||||
private LogoutFilter logoutFilter;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
public SecurityConfig(CasAuthenticationProvider casAuthenticationProvider, AuthenticationEntryPoint eP,
|
|
||||||
LogoutFilter lF
|
|
||||||
, SingleSignOutFilter ssF
|
|
||||||
) {
|
|
||||||
this.authenticationProvider = casAuthenticationProvider;
|
|
||||||
this.authenticationEntryPoint = eP;
|
|
||||||
|
|
||||||
this.logoutFilter = lF;
|
|
||||||
this.singleSignOutFilter = ssF;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void configure(HttpSecurity http) throws Exception {
|
|
||||||
http
|
|
||||||
.authorizeRequests()
|
|
||||||
.regexMatchers("/secured.*", "/login")
|
|
||||||
.authenticated()
|
|
||||||
.and()
|
|
||||||
.authorizeRequests()
|
|
||||||
.regexMatchers("/")
|
|
||||||
.permitAll()
|
|
||||||
.and()
|
|
||||||
.httpBasic()
|
|
||||||
.authenticationEntryPoint(authenticationEntryPoint)
|
|
||||||
.and()
|
|
||||||
.logout().logoutSuccessUrl("/logout")
|
|
||||||
.and()
|
|
||||||
.addFilterBefore(singleSignOutFilter, CasAuthenticationFilter.class)
|
|
||||||
.addFilterBefore(logoutFilter, LogoutFilter.class);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void configure(AuthenticationManagerBuilder auth) throws Exception {
|
|
||||||
auth.authenticationProvider(authenticationProvider);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected AuthenticationManager authenticationManager() throws Exception {
|
|
||||||
return new ProviderManager(Arrays.asList(authenticationProvider));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public CasAuthenticationFilter casAuthenticationFilter(ServiceProperties sP) throws Exception {
|
|
||||||
CasAuthenticationFilter filter = new CasAuthenticationFilter();
|
|
||||||
filter.setServiceProperties(sP);
|
|
||||||
filter.setAuthenticationManager(authenticationManager());
|
|
||||||
return filter;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -0,0 +1,79 @@
|
||||||
|
package com.baeldung.cassecuredapp.config;
|
||||||
|
|
||||||
|
import org.jasig.cas.client.session.SingleSignOutFilter;
|
||||||
|
import org.jasig.cas.client.validation.Cas30ServiceTicketValidator;
|
||||||
|
import org.jasig.cas.client.validation.TicketValidator;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.context.annotation.Bean;
|
||||||
|
import org.springframework.context.annotation.Primary;
|
||||||
|
import org.springframework.security.authentication.AuthenticationManager;
|
||||||
|
import org.springframework.security.authentication.ProviderManager;
|
||||||
|
import org.springframework.security.cas.ServiceProperties;
|
||||||
|
import org.springframework.security.cas.authentication.CasAuthenticationProvider;
|
||||||
|
import org.springframework.security.cas.web.CasAuthenticationEntryPoint;
|
||||||
|
import org.springframework.security.cas.web.CasAuthenticationFilter;
|
||||||
|
import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder;
|
||||||
|
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
|
||||||
|
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
|
||||||
|
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
|
||||||
|
import org.springframework.security.core.authority.AuthorityUtils;
|
||||||
|
import org.springframework.security.core.userdetails.User;
|
||||||
|
import org.springframework.security.web.AuthenticationEntryPoint;
|
||||||
|
import org.springframework.security.web.authentication.logout.LogoutFilter;
|
||||||
|
|
||||||
|
import java.util.Collections;
|
||||||
|
|
||||||
|
@EnableWebSecurity
|
||||||
|
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {
|
||||||
|
|
||||||
|
private Logger logger = LoggerFactory.getLogger(WebSecurityConfig.class);
|
||||||
|
private SingleSignOutFilter singleSignOutFilter;
|
||||||
|
private LogoutFilter logoutFilter;
|
||||||
|
private CasAuthenticationProvider casAuthenticationProvider;
|
||||||
|
private ServiceProperties serviceProperties;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
public WebSecurityConfig(SingleSignOutFilter singleSignOutFilter, LogoutFilter logoutFilter,
|
||||||
|
CasAuthenticationProvider casAuthenticationProvider,
|
||||||
|
ServiceProperties serviceProperties) {
|
||||||
|
this.logoutFilter = logoutFilter;
|
||||||
|
this.singleSignOutFilter = singleSignOutFilter;
|
||||||
|
this.serviceProperties = serviceProperties;
|
||||||
|
this.casAuthenticationProvider = casAuthenticationProvider;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void configure(HttpSecurity http) throws Exception {
|
||||||
|
http.authorizeRequests().antMatchers( "/secured", "/login").authenticated()
|
||||||
|
.and()
|
||||||
|
.exceptionHandling().authenticationEntryPoint(authenticationEntryPoint())
|
||||||
|
.and()
|
||||||
|
.addFilterBefore(singleSignOutFilter, CasAuthenticationFilter.class)
|
||||||
|
.addFilterBefore(logoutFilter, LogoutFilter.class)
|
||||||
|
.csrf().ignoringAntMatchers("/exit/cas");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void configure(AuthenticationManagerBuilder auth) throws Exception {
|
||||||
|
auth.authenticationProvider(casAuthenticationProvider);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
@Override
|
||||||
|
protected AuthenticationManager authenticationManager() throws Exception {
|
||||||
|
return new ProviderManager(Collections.singletonList(casAuthenticationProvider));
|
||||||
|
}
|
||||||
|
|
||||||
|
public AuthenticationEntryPoint authenticationEntryPoint() {
|
||||||
|
CasAuthenticationEntryPoint entryPoint = new CasAuthenticationEntryPoint();
|
||||||
|
entryPoint.setLoginUrl("https://localhost:8443/login");
|
||||||
|
entryPoint.setServiceProperties(serviceProperties);
|
||||||
|
return entryPoint;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -1,7 +1,7 @@
|
||||||
package com.baeldung.cassecuredapp.controllers;
|
package com.baeldung.cassecuredapp.controllers;
|
||||||
|
|
||||||
import org.apache.log4j.LogManager;
|
import org.slf4j.Logger;
|
||||||
import org.apache.log4j.Logger;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.springframework.security.core.Authentication;
|
import org.springframework.security.core.Authentication;
|
||||||
import org.springframework.security.core.context.SecurityContextHolder;
|
import org.springframework.security.core.context.SecurityContextHolder;
|
||||||
import org.springframework.security.web.authentication.logout.CookieClearingLogoutHandler;
|
import org.springframework.security.web.authentication.logout.CookieClearingLogoutHandler;
|
||||||
|
@ -13,24 +13,27 @@ import org.springframework.web.bind.annotation.GetMapping;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
|
import static org.springframework.security.web.authentication.rememberme.AbstractRememberMeServices.SPRING_SECURITY_REMEMBER_ME_COOKIE_KEY;
|
||||||
|
|
||||||
@Controller
|
@Controller
|
||||||
public class AuthController {
|
public class AuthController {
|
||||||
|
|
||||||
private Logger logger = LogManager.getLogger(AuthController.class);
|
private Logger logger = LoggerFactory.getLogger(AuthController.class);
|
||||||
|
|
||||||
@GetMapping("/logout")
|
|
||||||
public String logout(
|
|
||||||
HttpServletRequest request, HttpServletResponse response, SecurityContextLogoutHandler logoutHandler) {
|
|
||||||
Authentication auth = SecurityContextHolder.getContext().getAuthentication();
|
|
||||||
logoutHandler.logout(request, response, auth );
|
|
||||||
new CookieClearingLogoutHandler(AbstractRememberMeServices.SPRING_SECURITY_REMEMBER_ME_COOKIE_KEY).logout(request, response, auth);
|
|
||||||
return "auth/logout";
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@GetMapping("/login")
|
@GetMapping("/login")
|
||||||
public String login() {
|
public String login() {
|
||||||
|
logger.info("/login called");
|
||||||
return "redirect:/secured";
|
return "redirect:/secured";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@GetMapping("/logout")
|
||||||
|
public String logout(HttpServletRequest request, HttpServletResponse response, SecurityContextLogoutHandler logoutHandler) {
|
||||||
|
Authentication auth = SecurityContextHolder.getContext().getAuthentication();
|
||||||
|
CookieClearingLogoutHandler cookieClearingLogoutHandler = new CookieClearingLogoutHandler(SPRING_SECURITY_REMEMBER_ME_COOKIE_KEY);
|
||||||
|
cookieClearingLogoutHandler.logout(request, response, auth);
|
||||||
|
logoutHandler.logout(request, response, auth);
|
||||||
|
return "auth/logout";
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,15 +1,19 @@
|
||||||
package com.baeldung.cassecuredapp.controllers;
|
package com.baeldung.cassecuredapp.controllers;
|
||||||
|
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
import org.springframework.stereotype.Controller;
|
import org.springframework.stereotype.Controller;
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
import org.springframework.web.bind.annotation.GetMapping;
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
|
|
||||||
|
|
||||||
@Controller
|
@Controller
|
||||||
public class IndexController {
|
public class IndexController {
|
||||||
|
|
||||||
|
private Logger logger = LoggerFactory.getLogger(IndexController.class);
|
||||||
|
|
||||||
@GetMapping("/")
|
@GetMapping("/")
|
||||||
public String index() {
|
public String index() {
|
||||||
|
logger.info("Index controller called");
|
||||||
return "index";
|
return "index";
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,30 @@
|
||||||
|
package com.baeldung.cassecuredapp.controllers;
|
||||||
|
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
import org.springframework.security.core.Authentication;
|
||||||
|
import org.springframework.security.core.context.SecurityContextHolder;
|
||||||
|
import org.springframework.security.core.userdetails.UserDetails;
|
||||||
|
import org.springframework.stereotype.Controller;
|
||||||
|
import org.springframework.ui.ModelMap;
|
||||||
|
import org.springframework.web.bind.annotation.GetMapping;
|
||||||
|
|
||||||
|
@Controller
|
||||||
|
public class SecuredController {
|
||||||
|
|
||||||
|
private Logger logger = LoggerFactory.getLogger(SecuredController.class);
|
||||||
|
|
||||||
|
@GetMapping("/secured")
|
||||||
|
public String securedIndex(ModelMap modelMap) {
|
||||||
|
|
||||||
|
logger.info("/secured called");
|
||||||
|
|
||||||
|
Authentication auth = SecurityContextHolder.getContext()
|
||||||
|
.getAuthentication();
|
||||||
|
|
||||||
|
if(auth.getPrincipal() instanceof UserDetails)
|
||||||
|
modelMap.put("username", ((UserDetails) auth.getPrincipal()).getUsername());
|
||||||
|
|
||||||
|
return "secure/index";
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,24 +0,0 @@
|
||||||
package com.baeldung.cassecuredapp.controllers;
|
|
||||||
|
|
||||||
import org.springframework.security.core.Authentication;
|
|
||||||
import org.springframework.security.core.context.SecurityContextHolder;
|
|
||||||
import org.springframework.security.core.userdetails.UserDetails;
|
|
||||||
import org.springframework.stereotype.Controller;
|
|
||||||
import org.springframework.ui.ModelMap;
|
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
|
|
||||||
@Controller
|
|
||||||
@RequestMapping(value = "/secured")
|
|
||||||
public class SecuredPageController {
|
|
||||||
|
|
||||||
@GetMapping
|
|
||||||
public String index(ModelMap modelMap) {
|
|
||||||
Authentication auth = SecurityContextHolder.getContext().getAuthentication();
|
|
||||||
if( auth != null && auth.getPrincipal() != null
|
|
||||||
&& auth.getPrincipal() instanceof UserDetails) {
|
|
||||||
modelMap.put("username", ((UserDetails) auth.getPrincipal()).getUsername());
|
|
||||||
}
|
|
||||||
return "secure/index";
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1 +1,2 @@
|
||||||
server.port=9000
|
server.port=8900
|
||||||
|
spring.freemarker.suffix=.ftl
|
|
@ -7,7 +7,7 @@ import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringRunner.class)
|
||||||
@SpringBootTest
|
@SpringBootTest
|
||||||
public class CasSecuredAppApplicationIntegrationTest {
|
public class CasSecuredApplicationIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void contextLoads() {
|
public void contextLoads() {
|
|
@ -1,228 +0,0 @@
|
||||||
<factorypath>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-support-json-service-registry/5.3.0-SNAPSHOT/cas-server-support-json-service-registry-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/logging/log4j/log4j-api/2.11.0/log4j-api-2.11.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/logging/log4j/log4j-core/2.11.0/log4j-core-2.11.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/logging/log4j/log4j-jcl/2.11.0/log4j-jcl-2.11.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/logging/log4j/log4j-slf4j-impl/2.11.0/log4j-slf4j-impl-2.11.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/logging/log4j/log4j-web/2.11.0/log4j-web-2.11.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/slf4j/slf4j-api/1.7.25/slf4j-api-1.7.25.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/slf4j/jul-to-slf4j/1.7.25/jul-to-slf4j-1.7.25.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/lmax/disruptor/3.4.2/disruptor-3.4.2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/google/guava/guava/25.0-jre/guava-25.0-jre.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/google/code/findbugs/jsr305/1.3.9/jsr305-1.3.9.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/checkerframework/checker-compat-qual/2.0.0/checker-compat-qual-2.0.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/google/errorprone/error_prone_annotations/2.1.3/error_prone_annotations-2.1.3.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/google/j2objc/j2objc-annotations/1.1/j2objc-annotations-1.1.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/codehaus/mojo/animal-sniffer-annotations/1.14/animal-sniffer-annotations-1.14.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/reflections/reflections/0.9.11/reflections-0.9.11.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/javassist/javassist/3.22.0-GA/javassist-3.22.0-GA.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springmodules/spring-modules-cache/0.8/spring-modules-cache-0.8.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/commons-attributes/commons-attributes-api/2.1/commons-attributes-api-2.1.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/qdox/qdox/1.5/qdox-1.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/commons-attributes/commons-attributes-compiler/2.1/commons-attributes-compiler-2.1.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/concurrent/concurrent/1.3.4/concurrent-1.3.4.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/cglib/cglib-nodep/2.1_3/cglib-nodep-2.1_3.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/geronimo-spec/geronimo-spec-jta/1.0.1B-rc4/geronimo-spec-jta-1.0.1B-rc4.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/opensymphony/oscache/2.1.1/oscache-2.1.1.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/oro/oro/2.0.8/oro-2.0.8.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/commons-io/commons-io/2.6/commons-io-2.6.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/commons/commons-text/1.3/commons-text-1.3.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/commons/commons-pool2/2.5.0/commons-pool2-2.5.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/commons-cli/commons-cli/1.4/commons-cli-1.4.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/commons-beanutils/commons-beanutils/1.9.3/commons-beanutils-1.9.3.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/commons-logging/commons-logging/1.2/commons-logging-1.2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/commons/commons-configuration2/2.2/commons-configuration2-2.2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/commons-validator/commons-validator/1.6/commons-validator-1.6.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/commons-codec/commons-codec/1.11/commons-codec-1.11.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/commons-jexl/commons-jexl/1.1/commons-jexl-1.1.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/commons/commons-lang3/3.7/commons-lang3-3.7.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/commons-lang/commons-lang/2.6/commons-lang-2.6.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/jooq/jool/0.9.12/jool-0.9.12.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/github/lalyos/jfiglet/0.0.8/jfiglet-0.0.8.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/commons-collections/commons-collections/3.2.2/commons-collections-3.2.2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/commons/commons-collections4/4.1/commons-collections4-4.1.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/joda-time/joda-time/2.9.9/joda-time-2.9.9.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/inspektr/inspektr-audit/1.8.2.GA/inspektr-audit-1.8.2.GA.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/inspektr/inspektr-common/1.8.2.GA/inspektr-common-1.8.2.GA.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/fasterxml/jackson/core/jackson-core/2.9.3/jackson-core-2.9.3.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/inspektr/inspektr-support-spring/1.8.2.GA/inspektr-support-spring-1.8.2.GA.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/inspektr/inspektr-error/1.8.2.GA/inspektr-error-1.8.2.GA.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/service/persondir/person-directory-impl/1.8.6/person-directory-impl-1.8.6.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/aopalliance/aopalliance/1.0/aopalliance-1.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/service/persondir/person-directory-api/1.8.6/person-directory-api-1.8.6.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/shell/spring-shell/1.2.0.RELEASE/spring-shell-1.2.0.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/spring-aop/4.3.17.RELEASE/spring-aop-4.3.17.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/spring-beans/4.3.17.RELEASE/spring-beans-4.3.17.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/webflow/spring-binding/2.5.0.RELEASE/spring-binding-2.5.0.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/spring-context/4.3.17.RELEASE/spring-context-4.3.17.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/spring-context-support/4.3.17.RELEASE/spring-context-support-4.3.17.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/spring-core/4.3.17.RELEASE/spring-core-4.3.17.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/data/spring-data-mongodb/1.10.7.RELEASE/spring-data-mongodb-1.10.7.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/data/spring-data-commons/1.13.7.RELEASE/spring-data-commons-1.13.7.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/spring-jms/4.3.17.RELEASE/spring-jms-4.3.17.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/spring-messaging/4.3.17.RELEASE/spring-messaging-4.3.17.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/spring-expression/4.3.17.RELEASE/spring-expression-4.3.17.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/spring-jdbc/4.3.17.RELEASE/spring-jdbc-4.3.17.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/spring-orm/4.3.17.RELEASE/spring-orm-4.3.17.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/spring-tx/4.3.17.RELEASE/spring-tx-4.3.17.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/spring-web/4.3.17.RELEASE/spring-web-4.3.17.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/webflow/spring-webflow/2.5.0.RELEASE/spring-webflow-2.5.0.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/spring-webflow-client-repo/1.0.3/spring-webflow-client-repo-1.0.3.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/spring-webmvc/4.3.17.RELEASE/spring-webmvc-4.3.17.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/fasterxml/jackson/core/jackson-databind/2.9.5/jackson-databind-2.9.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/fasterxml/jackson/datatype/jackson-datatype-guava/2.9.5/jackson-datatype-guava-2.9.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/fasterxml/jackson/core/jackson-annotations/2.9.5/jackson-annotations-2.9.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/fasterxml/jackson/jaxrs/jackson-jaxrs-json-provider/2.9.5/jackson-jaxrs-json-provider-2.9.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/fasterxml/jackson/jaxrs/jackson-jaxrs-base/2.9.5/jackson-jaxrs-base-2.9.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/fasterxml/jackson/module/jackson-module-jaxb-annotations/2.9.5/jackson-module-jaxb-annotations-2.9.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/fasterxml/jackson/datatype/jackson-datatype-jsr310/2.9.5/jackson-datatype-jsr310-2.9.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/hjson/hjson/3.0.0/hjson-3.0.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/fasterxml/jackson/dataformat/jackson-dataformat-yaml/2.9.5/jackson-dataformat-yaml-2.9.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/httpcomponents/httpclient/4.5.5/httpclient-4.5.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/httpcomponents/httpcore/4.4.9/httpcore-4.4.9.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/github/axet/wget/1.4.9/wget-1.4.9.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/github/axet/threads/0.0.14/threads-0.0.14.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/jsoup/jsoup/1.10.1/jsoup-1.10.1.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/quartz-scheduler/quartz/2.3.0/quartz-2.3.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/mchange/mchange-commons-java/0.2.11/mchange-commons-java-0.2.11.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/hibernate/hibernate-core/5.2.16.Final/hibernate-core-5.2.16.Final.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/hibernate/javax/persistence/hibernate-jpa-2.1-api/1.0.0.Final/hibernate-jpa-2.1-api-1.0.0.Final.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/antlr/antlr/2.7.7/antlr-2.7.7.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/jboss/spec/javax/transaction/jboss-transaction-api_1.2_spec/1.0.1.Final/jboss-transaction-api_1.2_spec-1.0.1.Final.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/jboss/jandex/2.0.3.Final/jandex-2.0.3.Final.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/hibernate/common/hibernate-commons-annotations/5.0.1.Final/hibernate-commons-annotations-5.0.1.Final.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/dom4j/dom4j/1.6.1/dom4j-1.6.1.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/hibernate/hibernate-hikaricp/5.2.16.Final/hibernate-hikaricp-5.2.16.Final.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/hibernate/hibernate-entitymanager/5.2.16.Final/hibernate-entitymanager-5.2.16.Final.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/jboss/logging/jboss-logging/3.3.1.Final/jboss-logging-3.3.1.Final.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/net/bytebuddy/byte-buddy/1.6.14/byte-buddy-1.6.14.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/hibernate/hibernate-validator/5.4.1.Final/hibernate-validator-5.4.1.Final.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/zaxxer/HikariCP/3.1.0/HikariCP-3.1.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/javax/el/javax.el-api/3.0.0/javax.el-api-3.0.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/glassfish/web/el-impl/2.2/el-impl-2.2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/javax/el/el-api/2.2/el-api-2.2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/cloud/spring-cloud-commons/1.3.0.RELEASE/spring-cloud-commons-1.3.0.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/security/spring-security-crypto/4.2.3.RELEASE/spring-security-crypto-4.2.3.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/cloud/spring-cloud-context/1.3.0.RELEASE/spring-cloud-context-1.3.0.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/boot/spring-boot-starter-websocket/1.5.13.RELEASE/spring-boot-starter-websocket-1.5.13.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/boot/spring-boot-starter/1.5.13.RELEASE/spring-boot-starter-1.5.13.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/yaml/snakeyaml/1.17/snakeyaml-1.17.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/spring-websocket/4.3.17.RELEASE/spring-websocket-4.3.17.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/boot/spring-boot-starter-mail/1.5.13.RELEASE/spring-boot-starter-mail-1.5.13.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/sun/mail/javax.mail/1.5.6/javax.mail-1.5.6.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/javax/activation/activation/1.1/activation-1.1.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/boot/spring-boot-starter-web/1.5.13.RELEASE/spring-boot-starter-web-1.5.13.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/boot/spring-boot-autoconfigure/1.5.13.RELEASE/spring-boot-autoconfigure-1.5.13.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/boot/spring-boot/1.5.13.RELEASE/spring-boot-1.5.13.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/boot/spring-boot-devtools/1.5.13.RELEASE/spring-boot-devtools-1.5.13.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/boot/spring-boot-starter-actuator/1.5.13.RELEASE/spring-boot-starter-actuator-1.5.13.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/boot/spring-boot-actuator/1.5.13.RELEASE/spring-boot-actuator-1.5.13.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-api-services/5.3.0-SNAPSHOT/cas-server-core-api-services-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-api-authentication/5.3.0-SNAPSHOT/cas-server-core-api-authentication-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-api-protocol/5.3.0-SNAPSHOT/cas-server-core-api-protocol-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-api-util/5.3.0-SNAPSHOT/cas-server-core-api-util-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/aspectj/aspectjrt/1.9.1/aspectjrt-1.9.1.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/aspectj/aspectjweaver/1.9.1/aspectjweaver-1.9.1.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/javax/validation/validation-api/1.1.0.Final/validation-api-1.1.0.Final.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-services/5.3.0-SNAPSHOT/cas-server-core-services-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-api-audit/5.3.0-SNAPSHOT/cas-server-core-api-audit-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-api/5.3.0-SNAPSHOT/cas-server-core-api-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-services-api/5.3.0-SNAPSHOT/cas-server-core-services-api-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-services-authentication/5.3.0-SNAPSHOT/cas-server-core-services-authentication-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-web-api/5.3.0-SNAPSHOT/cas-server-core-web-api-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-api-logout/5.3.0-SNAPSHOT/cas-server-core-api-logout-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/thymeleaf/thymeleaf-spring4/3.0.9.RELEASE/thymeleaf-spring4-3.0.9.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/thymeleaf/thymeleaf/3.0.9.RELEASE/thymeleaf-3.0.9.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/attoparser/attoparser/2.0.4.RELEASE/attoparser-2.0.4.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/unbescape/unbescape/1.1.5.RELEASE/unbescape-1.1.5.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/boot/spring-boot-starter-thymeleaf/1.5.13.RELEASE/spring-boot-starter-thymeleaf-1.5.13.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-security-filter/2.0.10.2/cas-server-security-filter-2.0.10.2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-authentication-attributes/5.3.0-SNAPSHOT/cas-server-core-authentication-attributes-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/codehaus/groovy/groovy-jsr223/2.4.15/groovy-jsr223-2.4.15.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/codehaus/groovy/groovy/2.4.15/groovy-2.4.15.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/codehaus/groovy/groovy-console/2.4.15/groovy-console-2.4.15.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/codehaus/groovy/groovy-swing/2.4.15/groovy-swing-2.4.15.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/codehaus/groovy/groovy-templates/2.4.15/groovy-templates-2.4.15.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/codehaus/groovy/groovy-xml/2.4.15/groovy-xml-2.4.15.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/codehaus/groovy/groovy-groovysh/2.4.15/groovy-groovysh-2.4.15.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/jline/jline/2.12/jline-2.12.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-util-api/5.3.0-SNAPSHOT/cas-server-core-util-api-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/bitbucket/b_c/jose4j/0.6.3/jose4j-0.6.3.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-api-ticket/5.3.0-SNAPSHOT/cas-server-core-api-ticket-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-api-web/5.3.0-SNAPSHOT/cas-server-core-api-web-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/pac4j/pac4j-cas/3.0.0-RC2/pac4j-cas-3.0.0-RC2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/jasig/cas/client/cas-client-core/3.5.0/cas-client-core-3.5.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/jasig/cas/client/cas-client-support-saml/3.5.0/cas-client-support-saml-3.5.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/pac4j/pac4j-config/3.0.0-RC2/pac4j-config-3.0.0-RC2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/pac4j/pac4j-core/3.0.0-RC2/pac4j-core-3.0.0-RC2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/pac4j/pac4j-http/3.0.0-RC2/pac4j-http-3.0.0-RC2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/pac4j/pac4j-jwt/3.0.0-RC2/pac4j-jwt-3.0.0-RC2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/pac4j/pac4j-oidc/3.0.0-RC2/pac4j-oidc-3.0.0-RC2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/pac4j/pac4j-mongo/3.0.0-RC2/pac4j-mongo-3.0.0-RC2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/pac4j/pac4j-oauth/3.0.0-RC2/pac4j-oauth-3.0.0-RC2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/github/scribejava/scribejava-apis/5.3.0/scribejava-apis-5.3.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/github/scribejava/scribejava-core/5.3.0/scribejava-core-5.3.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/pac4j/pac4j-saml/3.0.0-RC2/pac4j-saml-3.0.0-RC2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/xalan/xalan/2.7.2/xalan-2.7.2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/xalan/serializer/2.7.2/serializer-2.7.2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/pac4j/spring-webmvc-pac4j/3.0.0-RC2/spring-webmvc-pac4j-3.0.0-RC2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/nimbusds/nimbus-jose-jwt/5.10/nimbus-jose-jwt-5.10.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/github/stephenc/jcip/jcip-annotations/1.0-1/jcip-annotations-1.0-1.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/nimbusds/oauth2-oidc-sdk/5.62/oauth2-oidc-sdk-5.62.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/javax/mail/mail/1.4.7/mail-1.4.7.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/nimbusds/lang-tag/1.4.3/lang-tag-1.4.3.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/net/minidev/json-smart/1.3.1/json-smart-1.3.1.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/google/zxing/core/3.3.2/core-3.3.2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/bouncycastle/bcpkix-jdk15on/1.59/bcpkix-jdk15on-1.59.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/cryptacular/cryptacular/1.2.2/cryptacular-1.2.2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/bouncycastle/bcprov-jdk15on/1.59/bcprov-jdk15on-1.59.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/vdurmont/semver4j/2.2.0/semver4j-2.2.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/github/oshi/oshi-core/3.5.0/oshi-core-3.5.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/threeten/threetenbp/1.3.6/threetenbp-1.3.6.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-configuration-api/5.3.0-SNAPSHOT/cas-server-core-configuration-api-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-api-configuration/5.3.0-SNAPSHOT/cas-server-core-api-configuration-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-api-configuration-model/5.3.0-SNAPSHOT/cas-server-core-api-configuration-model-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/boot/spring-boot-configuration-processor/1.5.13.RELEASE/spring-boot-configuration-processor-1.5.13.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/json/json/20160810/json-20160810.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/boot/spring-boot-configuration-metadata/1.5.13.RELEASE/spring-boot-configuration-metadata-1.5.13.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/github/javaparser/javaparser-core/3.6.5/javaparser-core-3.6.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-api-webflow/5.3.0-SNAPSHOT/cas-server-core-api-webflow-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/springframework/security/spring-security-core/4.2.6.RELEASE/spring-security-core-4.2.6.RELEASE.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/mongodb/mongo-java-driver/3.6.3/mongo-java-driver-3.6.3.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/jasypt/jasypt/1.9.2/jasypt-1.9.2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-services-registry/5.3.0-SNAPSHOT/cas-server-core-services-registry-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-api-events/5.3.0-SNAPSHOT/cas-server-core-api-events-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-api-validation/5.3.0-SNAPSHOT/cas-server-core-api-validation-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-support-jdbc/5.3.0-SNAPSHOT/cas-server-support-jdbc-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-authentication-api/5.3.0-SNAPSHOT/cas-server-core-authentication-api-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-core-authentication-mfa/5.3.0-SNAPSHOT/cas-server-core-authentication-mfa-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/github/ben-manes/caffeine/caffeine/2.6.2/caffeine-2.6.2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/github/ben-manes/caffeine/guava/2.6.2/guava-2.6.2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/timgroup/java-statsd-client/3.1.0/java-statsd-client-3.1.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/io/dropwizard/metrics/metrics-annotation/3.2.5/metrics-annotation-3.2.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/io/dropwizard/metrics/metrics-core/3.2.5/metrics-core-3.2.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/io/dropwizard/metrics/metrics-jvm/3.2.5/metrics-jvm-3.2.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/io/dropwizard/metrics/metrics-healthchecks/3.2.5/metrics-healthchecks-3.2.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/io/dropwizard/metrics/metrics-servlets/3.2.5/metrics-servlets-3.2.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/io/dropwizard/metrics/metrics-json/3.2.5/metrics-json-3.2.5.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/papertrail/profiler/1.0.2/profiler-1.0.2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/ryantenney/metrics/metrics-spring/3.1.3/metrics-spring-3.1.3.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-support-jdbc-authentication/5.3.0-SNAPSHOT/cas-server-support-jdbc-authentication-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/shiro/shiro-core/1.4.0/shiro-core-1.4.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/shiro/shiro-lang/1.4.0/shiro-lang-1.4.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/shiro/shiro-cache/1.4.0/shiro-cache-1.4.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/shiro/shiro-crypto-hash/1.4.0/shiro-crypto-hash-1.4.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/shiro/shiro-crypto-core/1.4.0/shiro-crypto-core-1.4.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/shiro/shiro-crypto-cipher/1.4.0/shiro-crypto-cipher-1.4.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/shiro/shiro-config-core/1.4.0/shiro-config-core-1.4.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/shiro/shiro-config-ogdl/1.4.0/shiro-config-ogdl-1.4.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apache/shiro/shiro-event/1.4.0/shiro-event-1.4.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/apereo/cas/cas-server-support-jdbc-drivers/5.3.0-SNAPSHOT/cas-server-support-jdbc-drivers-5.3.0-SNAPSHOT.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/hsqldb/hsqldb/2.4.0/hsqldb-2.4.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/postgresql/postgresql/42.2.2/postgresql-42.2.2.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/mysql/mysql-connector-java/8.0.11/mysql-connector-java-8.0.11.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/com/google/protobuf/protobuf-java/2.6.0/protobuf-java-2.6.0.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/org/mariadb/jdbc/mariadb-java-client/2.2.4/mariadb-java-client-2.2.4.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="VARJAR" id="M2_REPO/net/sourceforge/jtds/jtds/1.3.1/jtds-1.3.1.jar" enabled="true" runInBatchMode="false"/>
|
|
||||||
<factorypathentry kind="PLUGIN" id="org.eclipse.jst.ws.annotations.core" enabled="true" runInBatchMode="false"/>
|
|
||||||
</factorypath>
|
|
|
@ -2,6 +2,8 @@
|
||||||
!/.project
|
!/.project
|
||||||
.project
|
.project
|
||||||
.settings
|
.settings
|
||||||
|
.history
|
||||||
|
.vscode
|
||||||
target/
|
target/
|
||||||
.idea/
|
.idea/
|
||||||
.DS_Store
|
.DS_Store
|
||||||
|
@ -9,6 +11,11 @@ target/
|
||||||
overlays/
|
overlays/
|
||||||
.gradle/
|
.gradle/
|
||||||
build/
|
build/
|
||||||
|
log/
|
||||||
bin/
|
bin/
|
||||||
|
*.war
|
||||||
*.iml
|
*.iml
|
||||||
*.log
|
*.log
|
||||||
|
tmp/
|
||||||
|
./apache-tomcat
|
||||||
|
apache-tomcat.zip
|
|
@ -0,0 +1,32 @@
|
||||||
|
#
|
||||||
|
# Licensed to Apereo under one or more contributor license
|
||||||
|
# agreements. See the NOTICE file distributed with this work
|
||||||
|
# for additional information regarding copyright ownership.
|
||||||
|
# Apereo licenses this file to you under the Apache License,
|
||||||
|
# Version 2.0 (the "License"); you may not use this file
|
||||||
|
# except in compliance with the License. You may obtain a
|
||||||
|
# copy of the License at the following location:
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing,
|
||||||
|
# software distributed under the License is distributed on an
|
||||||
|
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
# KIND, either express or implied. See the License for the
|
||||||
|
# specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
pull_request_rules:
|
||||||
|
- name: automatic merge by dependabot
|
||||||
|
conditions:
|
||||||
|
- status-success=continuous-integration/travis-ci/pr
|
||||||
|
- status-success=WIP
|
||||||
|
- "#changes-requested-reviews-by=0"
|
||||||
|
- base=master
|
||||||
|
- label=dependencies
|
||||||
|
actions:
|
||||||
|
merge:
|
||||||
|
method: merge
|
||||||
|
strict: true
|
||||||
|
delete_head_branch:
|
|
@ -0,0 +1,62 @@
|
||||||
|
language: java
|
||||||
|
sudo: required
|
||||||
|
dist: trusty
|
||||||
|
services:
|
||||||
|
- docker
|
||||||
|
branches:
|
||||||
|
only:
|
||||||
|
- master
|
||||||
|
before_cache:
|
||||||
|
- rm -rf $HOME/.gradle/caches/5.*/
|
||||||
|
- rm -rf $HOME/.gradle/caches/4.*/
|
||||||
|
- rm -fr $HOME/.gradle/caches/*/plugin-resolution/
|
||||||
|
- find ~/.gradle/caches/ -name "*.lock" -type f -delete
|
||||||
|
cache:
|
||||||
|
bundler: false
|
||||||
|
cargo: false
|
||||||
|
directories:
|
||||||
|
- $HOME/.m2
|
||||||
|
- $HOME/.npm/
|
||||||
|
- $HOME/.gradle/caches/
|
||||||
|
- $HOME/.gradle/wrapper/
|
||||||
|
env:
|
||||||
|
global:
|
||||||
|
- JAVA_OPTS="-Xms512m -Xmx4048m -Xss128m -XX:ReservedCodeCacheSize=512m -XX:+UseG1GC -Xverify:none -server"
|
||||||
|
- GRADLE_OPTS="-Xms512m -Xmx1024m -Xss128m -XX:ReservedCodeCacheSize=512m -XX:+UseG1GC -Xverify:none -server"
|
||||||
|
jdk:
|
||||||
|
- openjdk11
|
||||||
|
before_install:
|
||||||
|
- echo -e "Configuring Gradle wrapper...\n"
|
||||||
|
- mkdir -p ~/.gradle && echo "org.gradle.daemon=false" >> ~/.gradle/gradle.properties
|
||||||
|
- chmod -R 777 ./gradlew
|
||||||
|
- chmod -R 777 *.sh
|
||||||
|
install: true
|
||||||
|
stages:
|
||||||
|
- build
|
||||||
|
- validate
|
||||||
|
- docker
|
||||||
|
jobs:
|
||||||
|
include:
|
||||||
|
- stage: build
|
||||||
|
script: ./gradlew clean build --stacktrace --no-daemon --refresh-dependencies -Dorg.gradle.internal.http.socketTimeout=600000 -Dorg.gradle.internal.http.connectionTimeout=600000
|
||||||
|
name: "Build CAS"
|
||||||
|
############################################
|
||||||
|
- stage: validate
|
||||||
|
script: ./gradlew downloadShell
|
||||||
|
name: "Download CAS Shell"
|
||||||
|
- stage: validate
|
||||||
|
script: ./gradlew listTemplateViews
|
||||||
|
name: "List CAS Template Views"
|
||||||
|
- stage: validate
|
||||||
|
script: ./gradlew explodeWar
|
||||||
|
name: "Unzip CAS Web Application"
|
||||||
|
############################################
|
||||||
|
- stage: docker
|
||||||
|
script: ./gradlew build jibDockerBuild --stacktrace --no-daemon --refresh-dependencies
|
||||||
|
name: "Build Docker Image via Jib"
|
||||||
|
- stage: docker
|
||||||
|
script: docker-compose build
|
||||||
|
name: "Build Docker Image via Docker Compose"
|
||||||
|
- stage: docker
|
||||||
|
script: ./docker-build.sh
|
||||||
|
name: "Build Docker Image"
|
|
@ -0,0 +1,40 @@
|
||||||
|
FROM adoptopenjdk/openjdk11:alpine-slim AS overlay
|
||||||
|
|
||||||
|
RUN mkdir -p cas-overlay
|
||||||
|
COPY ./src cas-overlay/src/
|
||||||
|
COPY ./gradle/ cas-overlay/gradle/
|
||||||
|
COPY ./gradlew ./settings.gradle ./build.gradle ./gradle.properties /cas-overlay/
|
||||||
|
|
||||||
|
RUN mkdir -p ~/.gradle \
|
||||||
|
&& echo "org.gradle.daemon=false" >> ~/.gradle/gradle.properties \
|
||||||
|
&& echo "org.gradle.configureondemand=true" >> ~/.gradle/gradle.properties \
|
||||||
|
&& cd cas-overlay \
|
||||||
|
&& chmod 750 ./gradlew \
|
||||||
|
&& ./gradlew --version;
|
||||||
|
|
||||||
|
RUN cd cas-overlay \
|
||||||
|
&& ./gradlew clean build --parallel;
|
||||||
|
|
||||||
|
FROM adoptopenjdk/openjdk11:alpine-jre AS cas
|
||||||
|
|
||||||
|
LABEL "Organization"="Apereo"
|
||||||
|
LABEL "Description"="Apereo CAS"
|
||||||
|
|
||||||
|
RUN cd / \
|
||||||
|
&& mkdir -p /etc/cas/config \
|
||||||
|
&& mkdir -p /etc/cas/services \
|
||||||
|
&& mkdir -p /etc/cas/saml \
|
||||||
|
&& mkdir -p cas-overlay;
|
||||||
|
|
||||||
|
COPY etc/cas/ /etc/cas/
|
||||||
|
COPY etc/cas/config/ /etc/cas/config/
|
||||||
|
COPY etc/cas/services/ /etc/cas/services/
|
||||||
|
COPY etc/cas/saml/ /etc/cas/saml/
|
||||||
|
COPY --from=overlay cas-overlay/build/libs/cas.war cas-overlay/
|
||||||
|
|
||||||
|
EXPOSE 8080 8443
|
||||||
|
|
||||||
|
ENV PATH $PATH:$JAVA_HOME/bin:.
|
||||||
|
|
||||||
|
WORKDIR cas-overlay
|
||||||
|
ENTRYPOINT ["java", "-server", "-noverify", "-Xmx2048M", "-jar", "cas.war"]
|
|
@ -1,105 +0,0 @@
|
||||||
CAS Overlay Template
|
|
||||||
============================
|
|
||||||
|
|
||||||
Generic CAS WAR overlay to exercise the latest versions of CAS. This overlay could be freely used as a starting template for local CAS war overlays. The CAS services management overlay is available [here](https://github.com/apereo/cas-services-management-overlay).
|
|
||||||
|
|
||||||
# Versions
|
|
||||||
|
|
||||||
```xml
|
|
||||||
<cas.version>5.3.x</cas.version>
|
|
||||||
```
|
|
||||||
|
|
||||||
# Requirements
|
|
||||||
|
|
||||||
* JDK 1.8+
|
|
||||||
|
|
||||||
# Configuration
|
|
||||||
|
|
||||||
The `etc` directory contains the configuration files and directories that need to be copied to `/etc/cas/config`.
|
|
||||||
|
|
||||||
# Build
|
|
||||||
|
|
||||||
To see what commands are available to the build script, run:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
./build.sh help
|
|
||||||
```
|
|
||||||
|
|
||||||
To package the final web application, run:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
./build.sh package
|
|
||||||
```
|
|
||||||
|
|
||||||
To update `SNAPSHOT` versions run:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
./build.sh package -U
|
|
||||||
```
|
|
||||||
|
|
||||||
# Deployment
|
|
||||||
|
|
||||||
- Create a keystore file `thekeystore` under `/etc/cas`. Use the password `changeit` for both the keystore and the key/certificate entries.
|
|
||||||
- Ensure the keystore is loaded up with keys and certificates of the server.
|
|
||||||
|
|
||||||
On a successful deployment via the following methods, CAS will be available at:
|
|
||||||
|
|
||||||
* `http://cas.server.name:8080/cas`
|
|
||||||
* `https://cas.server.name:8443/cas`
|
|
||||||
|
|
||||||
## Executable WAR
|
|
||||||
|
|
||||||
Run the CAS web application as an executable WAR.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
./build.sh run
|
|
||||||
```
|
|
||||||
|
|
||||||
## Spring Boot
|
|
||||||
|
|
||||||
Run the CAS web application as an executable WAR via Spring Boot. This is most useful during development and testing.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
./build.sh bootrun
|
|
||||||
```
|
|
||||||
|
|
||||||
### Warning!
|
|
||||||
|
|
||||||
Be careful with this method of deployment. `bootRun` is not designed to work with already executable WAR artifacts such that CAS server web application. YMMV. Today, uses of this mode ONLY work when there is **NO OTHER** dependency added to the build script and the `cas-server-webapp` is the only present module. See [this issue](https://github.com/spring-projects/spring-boot/issues/8320) for more info.
|
|
||||||
|
|
||||||
|
|
||||||
## Spring Boot App Server Selection
|
|
||||||
|
|
||||||
There is an app.server property in the `pom.xml` that can be used to select a spring boot application server.
|
|
||||||
It defaults to `-tomcat` but `-jetty` and `-undertow` are supported.
|
|
||||||
|
|
||||||
It can also be set to an empty value (nothing) if you want to deploy CAS to an external application server of your choice.
|
|
||||||
|
|
||||||
```xml
|
|
||||||
<app.server>-tomcat<app.server>
|
|
||||||
```
|
|
||||||
|
|
||||||
## Windows Build
|
|
||||||
|
|
||||||
If you are building on windows, try `build.cmd` instead of `build.sh`. Arguments are similar but for usage, run:
|
|
||||||
|
|
||||||
```
|
|
||||||
build.cmd help
|
|
||||||
```
|
|
||||||
|
|
||||||
## External
|
|
||||||
|
|
||||||
Deploy resultant `target/cas.war` to a servlet container of choice.
|
|
||||||
|
|
||||||
|
|
||||||
## Command Line Shell
|
|
||||||
|
|
||||||
Invokes the CAS Command Line Shell. For a list of commands either use no arguments or use `-h`. To enter the interactive shell use `-sh`.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
./build.sh cli
|
|
||||||
```
|
|
||||||
|
|
||||||
### Relevant Articles:
|
|
||||||
|
|
||||||
- [CAS SSO With Spring Security](https://www.baeldung.com/spring-security-cas-sso)
|
|
|
@ -1,102 +0,0 @@
|
||||||
@echo off
|
|
||||||
|
|
||||||
@set JAVA_ARGS=-Xms500m -Xmx1g
|
|
||||||
@set CAS_DIR=\etc\cas
|
|
||||||
@set CONFIG_DIR=\etc\cas\config
|
|
||||||
|
|
||||||
@rem Call this script with DNAME and CERT_SUBJ_ALT_NAMES already set to override
|
|
||||||
@if "%DNAME%" == "" set DNAME=CN=cas.example.org,OU=Example,OU=Org,C=US
|
|
||||||
@rem List other host names or ip addresses you want in your certificate, may help with host name verification,
|
|
||||||
@rem if client apps make https connection for ticket validation and compare name in cert (include sub. alt. names)
|
|
||||||
@rem to name used to access CAS
|
|
||||||
@if "%CERT_SUBJ_ALT_NAMES%" == "" set CERT_SUBJ_ALT_NAMES=dns:example.org,dns:localhost,dns:%COMPUTERNAME%,ip:127.0.0.1
|
|
||||||
|
|
||||||
@rem Check for mvn in path, use it if found, otherwise use maven wrapper
|
|
||||||
@set MAVEN_CMD=mvn
|
|
||||||
@where /q mvn
|
|
||||||
@if %ERRORLEVEL% neq 0 set MAVEN_CMD=.\mvnw.bat
|
|
||||||
|
|
||||||
@if "%1" == "" call:help
|
|
||||||
@if "%1" == "copy" call:copy
|
|
||||||
@if "%1" == "clean" call:clean %2 %3 %4
|
|
||||||
@if "%1" == "package" call:package %2 %3 %4
|
|
||||||
@if "%1" == "bootrun" call:bootrun %2 %3 %4
|
|
||||||
@if "%1" == "debug" call:debug %2 %3 %4
|
|
||||||
@if "%1" == "run" call:run %2 %3 %4
|
|
||||||
@if "%1" == "runalone" call:runalone %2 %3 %4
|
|
||||||
@if "%1" == "help" call:help
|
|
||||||
@if "%1" == "gencert" call:gencert
|
|
||||||
@if "%1" == "cli" call:runcli %2 %3 %4
|
|
||||||
|
|
||||||
@rem function section starts here
|
|
||||||
@goto:eof
|
|
||||||
|
|
||||||
:copy
|
|
||||||
@echo "Creating configuration directory under %CONFIG_DIR%"
|
|
||||||
if not exist %CONFIG_DIR% mkdir %CONFIG_DIR%
|
|
||||||
|
|
||||||
@echo "Copying configuration files from etc/cas to /etc/cas"
|
|
||||||
xcopy /S /Y etc\cas\* \etc\cas
|
|
||||||
@goto:eof
|
|
||||||
|
|
||||||
:help
|
|
||||||
@echo "Usage: build.bat [copy|clean|package|run|debug|bootrun|gencert|cli] [optional extra args for maven or cli]"
|
|
||||||
@echo "To get started on a clean system, run "build.bat copy" and "build.bat gencert", then "build.bat run"
|
|
||||||
@echo "Note that using the copy or gencert arguments will create and/or overwrite the %CAS_DIR% which is outside this project"
|
|
||||||
@goto:eof
|
|
||||||
|
|
||||||
:clean
|
|
||||||
call %MAVEN_CMD% clean %1 %2 %3
|
|
||||||
exit /B %ERRORLEVEL%
|
|
||||||
@goto:eof
|
|
||||||
|
|
||||||
:package
|
|
||||||
call %MAVEN_CMD% clean package -T 5 %1 %2 %3
|
|
||||||
exit /B %ERRORLEVEL%
|
|
||||||
@goto:eof
|
|
||||||
|
|
||||||
:bootrun
|
|
||||||
call %MAVEN_CMD% clean package spring-boot:run -T 5 %1 %2 %3
|
|
||||||
exit /B %ERRORLEVEL%
|
|
||||||
@goto:eof
|
|
||||||
|
|
||||||
:debug
|
|
||||||
call:package %1 %2 %3 & java %JAVA_ARGS% -Xdebug -Xrunjdwp:transport=dt_socket,address=5000,server=y,suspend=n -jar target/cas.war
|
|
||||||
@goto:eof
|
|
||||||
|
|
||||||
:run
|
|
||||||
call:package %1 %2 %3 & java %JAVA_ARGS% -jar target/cas.war
|
|
||||||
@goto:eof
|
|
||||||
|
|
||||||
:runalone
|
|
||||||
call:package %1 %2 %3 & target/cas.war
|
|
||||||
@goto:eof
|
|
||||||
|
|
||||||
:gencert
|
|
||||||
where /q keytool
|
|
||||||
if ERRORLEVEL 1 (
|
|
||||||
@echo Java keytool.exe not found in path.
|
|
||||||
exit /b 1
|
|
||||||
) else (
|
|
||||||
if not exist %CAS_DIR% mkdir %CAS_DIR%
|
|
||||||
@echo on
|
|
||||||
@echo Generating self-signed SSL cert for %DNAME% in %CAS_DIR%\thekeystore
|
|
||||||
keytool -genkeypair -alias cas -keyalg RSA -keypass changeit -storepass changeit -keystore %CAS_DIR%\thekeystore -dname %DNAME% -ext SAN=%CERT_SUBJ_ALT_NAMES%
|
|
||||||
@echo Exporting cert for use in trust store (used by cas clients)
|
|
||||||
keytool -exportcert -alias cas -storepass changeit -keystore %CAS_DIR%\thekeystore -file %CAS_DIR%\cas.cer
|
|
||||||
)
|
|
||||||
@goto:eof
|
|
||||||
|
|
||||||
:runcli
|
|
||||||
for /f %%i in ('call %MAVEN_CMD% -q --non-recursive "-Dexec.executable=cmd" "-Dexec.args=/C echo ${cas.version}" "org.codehaus.mojo:exec-maven-plugin:1.3.1:exec"') do set CAS_VERSION=%%i
|
|
||||||
@set CAS_VERSION=%CAS_VERSION: =%
|
|
||||||
@set DOWNLOAD_DIR=target
|
|
||||||
@set COMMAND_FILE=cas-server-support-shell-%CAS_VERSION%.jar
|
|
||||||
@if not exist %DOWNLOAD_DIR% mkdir %DOWNLOAD_DIR%
|
|
||||||
@if not exist %DOWNLOAD_DIR%\%COMMAND_FILE% (
|
|
||||||
@call mvn org.apache.maven.plugins:maven-dependency-plugin:3.0.2:get -DgroupId=org.apereo.cas -DartifactId=cas-server-support-shell -Dversion=%CAS_VERSION% -Dpackaging=jar -DartifactItem.outputDirectory=%DOWNLOAD_DIR% -DartifactItem.destFileName=%COMMAND_FILE% -DremoteRepositories=central::default::http://repo1.maven.apache.org/maven2,snapshots::::https://oss.sonatype.org/content/repositories/snapshots -Dtransitive=false
|
|
||||||
@call mvn org.apache.maven.plugins:maven-dependency-plugin:3.0.2:copy -Dmdep.useBaseVersion=true -Dartifact=org.apereo.cas:cas-server-support-shell:%CAS_VERSION%:jar -DoutputDirectory=%DOWNLOAD_DIR%
|
|
||||||
)
|
|
||||||
@call java %JAVA_ARGS% -jar %DOWNLOAD_DIR%\%COMMAND_FILE% %1 %2 %3
|
|
||||||
|
|
||||||
@goto:eof
|
|
|
@ -0,0 +1,106 @@
|
||||||
|
buildscript {
|
||||||
|
repositories {
|
||||||
|
mavenLocal()
|
||||||
|
mavenCentral()
|
||||||
|
jcenter()
|
||||||
|
maven { url "https://repo.spring.io/libs-milestone" }
|
||||||
|
maven { url "https://repo.spring.io/libs-snapshot" }
|
||||||
|
maven { url "https://plugins.gradle.org/m2/" }
|
||||||
|
}
|
||||||
|
dependencies {
|
||||||
|
classpath "de.undercouch:gradle-download-task:${project.gradleDownloadTaskVersion}"
|
||||||
|
classpath "org.springframework.boot:spring-boot-gradle-plugin:${project.springBootVersion}"
|
||||||
|
classpath "gradle.plugin.com.google.cloud.tools:jib-gradle-plugin:${project.jibVersion}"
|
||||||
|
classpath "io.freefair.gradle:maven-plugin:${project.gradleMavenPluginVersion}"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
repositories {
|
||||||
|
mavenLocal()
|
||||||
|
mavenCentral()
|
||||||
|
jcenter()
|
||||||
|
maven { url "https://oss.sonatype.org/content/repositories/snapshots" }
|
||||||
|
maven { url "https://build.shibboleth.net/nexus/content/repositories/releases/" }
|
||||||
|
maven { url "https://repo.spring.io/milestone/" }
|
||||||
|
maven { url "https://repo.spring.io/snapshot/" }
|
||||||
|
maven { url "https://oss.jfrog.org/artifactory/oss-snapshot-local" }
|
||||||
|
}
|
||||||
|
|
||||||
|
def casServerVersion = project.'cas.version'
|
||||||
|
def casWebApplicationBinaryName = "cas.war"
|
||||||
|
|
||||||
|
project.ext."casServerVersion" = casServerVersion
|
||||||
|
project.ext."casWebApplicationBinaryName" = casWebApplicationBinaryName
|
||||||
|
|
||||||
|
apply plugin: "io.freefair.war-overlay"
|
||||||
|
apply from: rootProject.file("gradle/tasks.gradle")
|
||||||
|
|
||||||
|
apply plugin: "war"
|
||||||
|
apply plugin: "eclipse"
|
||||||
|
apply plugin: "idea"
|
||||||
|
|
||||||
|
apply from: rootProject.file("gradle/springboot.gradle")
|
||||||
|
apply from: rootProject.file("gradle/dockerjib.gradle")
|
||||||
|
|
||||||
|
dependencies {
|
||||||
|
// Other CAS dependencies/modules may be listed here...
|
||||||
|
compile "org.apereo.cas:cas-server-support-json-service-registry:${casServerVersion}"
|
||||||
|
compile "org.apereo.cas:cas-server-support-jdbc:${casServerVersion}"
|
||||||
|
}
|
||||||
|
|
||||||
|
tasks.findByName("jibDockerBuild")
|
||||||
|
.dependsOn(copyWebAppIntoJib, copyConfigIntoJib)
|
||||||
|
.finalizedBy(deleteWebAppFromJib)
|
||||||
|
|
||||||
|
tasks.findByName("jib")
|
||||||
|
.dependsOn(copyWebAppIntoJib, copyConfigIntoJib)
|
||||||
|
.finalizedBy(deleteWebAppFromJib)
|
||||||
|
|
||||||
|
configurations.all {
|
||||||
|
resolutionStrategy {
|
||||||
|
cacheChangingModulesFor 0, "seconds"
|
||||||
|
cacheDynamicVersionsFor 0, "seconds"
|
||||||
|
|
||||||
|
preferProjectModules()
|
||||||
|
|
||||||
|
def failIfConflict = project.hasProperty("failOnVersionConflict") && Boolean.valueOf(project.getProperty("failOnVersionConflict"))
|
||||||
|
if (failIfConflict) {
|
||||||
|
failOnVersionConflict()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
eclipse {
|
||||||
|
classpath {
|
||||||
|
downloadSources = true
|
||||||
|
downloadJavadoc = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
idea {
|
||||||
|
module {
|
||||||
|
downloadJavadoc = true
|
||||||
|
downloadSources = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bootWar {
|
||||||
|
entryCompression = ZipEntryCompression.STORED
|
||||||
|
overlays {
|
||||||
|
// https://docs.freefair.io/gradle-plugins/current/reference/#_io_freefair_war_overlay
|
||||||
|
// Note: The "excludes" property is only for files in the war dependency.
|
||||||
|
// If a jar is excluded from the war, it could be brought back into the final war as a dependency
|
||||||
|
// of non-war dependencies. Those should be excluded via normal gradle dependency exclusions.
|
||||||
|
cas {
|
||||||
|
from "org.apereo.cas:cas-server-webapp${project.appServer}:${casServerVersion}@war"
|
||||||
|
provided = false
|
||||||
|
//excludes = ["WEB-INF/lib/somejar-1.0*"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
wrapper {
|
||||||
|
distributionType = Wrapper.DistributionType.BIN
|
||||||
|
gradleVersion = "${project.gradleVersion}"
|
||||||
|
}
|
|
@ -1,189 +0,0 @@
|
||||||
#!/bin/bash
|
|
||||||
|
|
||||||
|
|
||||||
function copy() {
|
|
||||||
echo -e "Creating configuration directory under /etc/cas"
|
|
||||||
mkdir -p /etc/cas/config
|
|
||||||
|
|
||||||
echo -e "Copying configuration files from etc/cas to /etc/cas"
|
|
||||||
cp -rfv etc/cas/* /etc/cas
|
|
||||||
}
|
|
||||||
|
|
||||||
function help() {
|
|
||||||
echo "Usage: build.sh [copy|clean|package|run|debug|bootrun|gencert]"
|
|
||||||
echo " copy: Copy config from ./etc/cas/config to /etc/cas/config"
|
|
||||||
echo " clean: Clean Maven build directory"
|
|
||||||
echo " package: Clean and build CAS war"
|
|
||||||
echo " run: Build and run cas.war via Java (i.e. java -jar target/cas.war)"
|
|
||||||
echo " runalone: Build and run cas.war on its own as a standalone executable (target/cas.war)"
|
|
||||||
echo " debug: Run CAS.war and listen for Java debugger on port 5000"
|
|
||||||
echo " bootrun: Run with maven spring boot plugin"
|
|
||||||
echo " listviews: List all CAS views that ship with the web application and can be customized in the overlay"
|
|
||||||
echo " getview: Ask for a view name to be included in the overlay for customizations"
|
|
||||||
echo " gencert: Create keystore with SSL certificate in location where CAS looks by default"
|
|
||||||
echo " cli: Run the CAS command line shell and pass commands"
|
|
||||||
}
|
|
||||||
|
|
||||||
function clean() {
|
|
||||||
shift
|
|
||||||
./mvnw clean "$@"
|
|
||||||
}
|
|
||||||
|
|
||||||
function package() {
|
|
||||||
shift
|
|
||||||
./mvnw clean package -T 5 "$@"
|
|
||||||
# copy
|
|
||||||
}
|
|
||||||
|
|
||||||
function bootrun() {
|
|
||||||
shift
|
|
||||||
./mvnw clean package spring-boot:run -P bootiful -T 5 "$@"
|
|
||||||
}
|
|
||||||
|
|
||||||
function debug() {
|
|
||||||
package && java -Xdebug -Xrunjdwp:transport=dt_socket,address=5000,server=y,suspend=n -jar target/cas.war
|
|
||||||
}
|
|
||||||
|
|
||||||
function run() {
|
|
||||||
package && java -jar target/cas.war
|
|
||||||
}
|
|
||||||
|
|
||||||
function runalone() {
|
|
||||||
shift
|
|
||||||
./mvnw clean package -P default,exec "$@"
|
|
||||||
chmod +x target/cas.war
|
|
||||||
target/cas.war
|
|
||||||
}
|
|
||||||
|
|
||||||
function listviews() {
|
|
||||||
shift
|
|
||||||
explodeapp
|
|
||||||
find $PWD/target/cas -type f -name "*.html" | xargs -n 1 basename | sort | more
|
|
||||||
}
|
|
||||||
|
|
||||||
function explodeapp() {
|
|
||||||
if [ ! -d $PWD/target/cas ];then
|
|
||||||
echo "Building the CAS web application and exploding the final war file..."
|
|
||||||
./mvnw clean package war:exploded "$@"
|
|
||||||
fi
|
|
||||||
echo "Exploded the CAS web application file."
|
|
||||||
}
|
|
||||||
|
|
||||||
function getview() {
|
|
||||||
shift
|
|
||||||
explodeapp
|
|
||||||
echo "Searching for view name $@..."
|
|
||||||
results=`find $PWD/target/cas -type f -name "*.html" | grep -i "$@"`
|
|
||||||
echo -e "Found view(s): \n$results"
|
|
||||||
count=`wc -w <<< "$results"`
|
|
||||||
if [ "$count" -eq 1 ];then
|
|
||||||
# echo "Found view $results to include in the overlay"
|
|
||||||
firststring="target/cas/WEB-INF/classes"
|
|
||||||
secondstring="src/main/resources"
|
|
||||||
overlayfile=`echo "${results/$firststring/$secondstring}"`
|
|
||||||
overlaypath=`dirname "${overlayfile}"`
|
|
||||||
# echo "Overlay file is $overlayfile to be created at $overlaypath"
|
|
||||||
mkdir -p $overlaypath
|
|
||||||
cp $results $overlaypath
|
|
||||||
echo "Created view at $overlayfile"
|
|
||||||
ls $overlayfile
|
|
||||||
else
|
|
||||||
echo "More than one view file is found. Narrow down the search query..."
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function gencert() {
|
|
||||||
if [[ ! -d /etc/cas ]] ; then
|
|
||||||
copy
|
|
||||||
fi
|
|
||||||
which keytool
|
|
||||||
if [[ $? -ne 0 ]] ; then
|
|
||||||
echo Error: Java JDK \'keytool\' is not installed or is not in the path
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
# override DNAME and CERT_SUBJ_ALT_NAMES before calling or use dummy values
|
|
||||||
DNAME="${DNAME:-CN=cas.example.org,OU=Example,OU=Org,C=US}"
|
|
||||||
CERT_SUBJ_ALT_NAMES="${CERT_SUBJ_ALT_NAMES:-dns:example.org,dns:localhost,ip:127.0.0.1}"
|
|
||||||
echo "Generating keystore for CAS with DN ${DNAME}"
|
|
||||||
keytool -genkeypair -alias cas -keyalg RSA -keypass changeit -storepass changeit -keystore /etc/cas/thekeystore -dname ${DNAME} -ext SAN=${CERT_SUBJ_ALT_NAMES}
|
|
||||||
keytool -exportcert -alias cas -storepass changeit -keystore /etc/cas/thekeystore -file /etc/cas/cas.cer
|
|
||||||
}
|
|
||||||
|
|
||||||
function cli() {
|
|
||||||
|
|
||||||
CAS_VERSION=$(./mvnw -q -Dexec.executable="echo" -Dexec.args='${cas.version}' --non-recursive org.codehaus.mojo:exec-maven-plugin:1.3.1:exec 2>/dev/null)
|
|
||||||
# echo "CAS version: $CAS_VERSION"
|
|
||||||
JAR_FILE_NAME="cas-server-support-shell-${CAS_VERSION}.jar"
|
|
||||||
# echo "JAR name: $JAR_FILE_NAME"
|
|
||||||
JAR_PATH="org/apereo/cas/cas-server-support-shell/${CAS_VERSION}/${JAR_FILE_NAME}"
|
|
||||||
# echo "JAR path: $JAR_PATH"
|
|
||||||
|
|
||||||
JAR_FILE_LOCAL="$HOME/.m2/repository/$JAR_PATH";
|
|
||||||
# echo "Local JAR file path: $JAR_FILE_LOCAL";
|
|
||||||
if [ -f "$JAR_FILE_LOCAL" ]; then
|
|
||||||
# echo "Using JAR file locally at $JAR_FILE_LOCAL"
|
|
||||||
java -jar $JAR_FILE_LOCAL "$@"
|
|
||||||
exit 0;
|
|
||||||
fi
|
|
||||||
|
|
||||||
DOWNLOAD_DIR=./target
|
|
||||||
COMMAND_FILE="${DOWNLOAD_DIR}/${JAR_FILE_NAME}"
|
|
||||||
if [ ! -f "$COMMAND_FILE" ]; then
|
|
||||||
mkdir -p $DOWNLOAD_DIR
|
|
||||||
./mvnw org.apache.maven.plugins:maven-dependency-plugin:3.0.2:get -DgroupId=org.apereo.cas -DartifactId=cas-server-support-shell -Dversion=$CAS_VERSION -Dpackaging=jar -DartifactItem.outputDirectory=$DOWNLOAD_DIR -DremoteRepositories=central::default::http://repo1.maven.apache.org/maven2,snapshots::::https://oss.sonatype.org/content/repositories/snapshots -Dtransitive=false
|
|
||||||
./mvnw org.apache.maven.plugins:maven-dependency-plugin:3.0.2:copy -Dmdep.useBaseVersion=true -Dartifact=org.apereo.cas:cas-server-support-shell:$CAS_VERSION:jar -DoutputDirectory=$DOWNLOAD_DIR
|
|
||||||
fi
|
|
||||||
java -jar $COMMAND_FILE "$@"
|
|
||||||
exit 0;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
if [ $# -eq 0 ]; then
|
|
||||||
echo -e "No commands provided. Defaulting to [run]\n"
|
|
||||||
run
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
case "$1" in
|
|
||||||
"copy")
|
|
||||||
copy
|
|
||||||
;;
|
|
||||||
"clean")
|
|
||||||
shift
|
|
||||||
clean "$@"
|
|
||||||
;;
|
|
||||||
"package")
|
|
||||||
shift
|
|
||||||
package "$@"
|
|
||||||
;;
|
|
||||||
"bootrun")
|
|
||||||
shift
|
|
||||||
bootrun "$@"
|
|
||||||
;;
|
|
||||||
"debug")
|
|
||||||
debug "$@"
|
|
||||||
;;
|
|
||||||
"run")
|
|
||||||
run "$@"
|
|
||||||
;;
|
|
||||||
"runalone")
|
|
||||||
runalone "$@"
|
|
||||||
;;
|
|
||||||
"listviews")
|
|
||||||
listviews "$@"
|
|
||||||
;;
|
|
||||||
"gencert")
|
|
||||||
gencert "$@"
|
|
||||||
;;
|
|
||||||
"getview")
|
|
||||||
getview "$@"
|
|
||||||
;;
|
|
||||||
"cli")
|
|
||||||
shift
|
|
||||||
cli "$@"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
help
|
|
||||||
;;
|
|
||||||
esac
|
|
|
@ -0,0 +1,10 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
image_tag=(`cat gradle.properties | grep "cas.version" | cut -d= -f2`)
|
||||||
|
|
||||||
|
echo "Building CAS docker image tagged as [$image_tag]"
|
||||||
|
# read -p "Press [Enter] to continue..." any_key;
|
||||||
|
|
||||||
|
docker build --tag="org.apereo.cas/cas:$image_tag" . \
|
||||||
|
&& echo "Built CAS image successfully tagged as org.apereo.cas/cas:$image_tag" \
|
||||||
|
&& docker images "org.apereo.cas/cas:$image_tag"
|
|
@ -0,0 +1,7 @@
|
||||||
|
version: '3'
|
||||||
|
services:
|
||||||
|
cas:
|
||||||
|
build: .
|
||||||
|
ports:
|
||||||
|
- "8443:8443"
|
||||||
|
- "8080:8080"
|
|
@ -0,0 +1,12 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
read -p "Docker username: " docker_user
|
||||||
|
read -s -p "Docker password: " docker_psw
|
||||||
|
|
||||||
|
echo "$docker_psw" | docker login --username "$docker_user" --password-stdin
|
||||||
|
|
||||||
|
image_tag=(`cat gradle.properties | grep "cas.version" | cut -d= -f2`)
|
||||||
|
|
||||||
|
echo "Pushing CAS docker image tagged as $image_tag to org.apereo.cas/cas..."
|
||||||
|
docker push org.apereo.cas/cas:"$image_tag" \
|
||||||
|
&& echo "Pushed org.apereo.cas/cas:$image_tag successfully.";
|
|
@ -0,0 +1,7 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
docker stop cas > /dev/null 2>&1
|
||||||
|
docker rm cas > /dev/null 2>&1
|
||||||
|
image_tag=(`cat gradle.properties | grep "cas.version" | cut -d= -f2`)
|
||||||
|
docker run -d -p 8080:8080 -p 8443:8443 --name="cas" org.apereo.cas/cas:"${image_tag}"
|
||||||
|
docker logs -f cas
|
|
@ -1,2 +0,0 @@
|
||||||
info:
|
|
||||||
description: CAS Configuration
|
|
|
@ -1,7 +1,6 @@
|
||||||
cas.server.name: https://cas.example.org:8443
|
cas.server.name=https://cas.example.org:8443
|
||||||
cas.server.prefix: https://cas.example.org:8443/cas
|
cas.server.prefix=${cas.server.name}/cas
|
||||||
|
|
||||||
cas.adminPagesSecurity.ip=127\.0\.0\.1
|
|
||||||
|
|
||||||
logging.config: file:/etc/cas/config/log4j2.xml
|
logging.config: file:/etc/cas/config/log4j2.xml
|
||||||
# cas.serviceRegistry.config.location: classpath:/services
|
|
||||||
|
# cas.authn.accept.users=
|
||||||
|
|
|
@ -2,20 +2,26 @@
|
||||||
<!-- Specify the refresh internal in seconds. -->
|
<!-- Specify the refresh internal in seconds. -->
|
||||||
<Configuration monitorInterval="5" packages="org.apereo.cas.logging">
|
<Configuration monitorInterval="5" packages="org.apereo.cas.logging">
|
||||||
<Properties>
|
<Properties>
|
||||||
<!--
|
<Property name="baseDir">/var/log</Property>
|
||||||
Default log directory is the current directory but that can be overridden with -Dcas.log.dir=<logdir>
|
|
||||||
Or you can change this property to a new default
|
<Property name="cas.log.level">info</Property>
|
||||||
-->
|
<Property name="spring.webflow.log.level">warn</Property>
|
||||||
<Property name="cas.log.dir" >.</Property>
|
<Property name="spring.security.log.level">info</Property>
|
||||||
<!-- To see more CAS specific logging, adjust this property to info or debug or run server with -Dcas.log.leve=debug -->
|
<Property name="spring.cloud.log.level">warn</Property>
|
||||||
<Property name="cas.log.level" >warn</Property>
|
<Property name="spring.boot.admin.log.level">debug</Property>
|
||||||
|
<Property name="spring.web.log.level">warn</Property>
|
||||||
|
<Property name="spring.boot.log.level">warn</Property>
|
||||||
|
<Property name="ldap.log.level">warn</Property>
|
||||||
|
<Property name="pac4j.log.level">warn</Property>
|
||||||
|
<Property name="opensaml.log.level">warn</Property>
|
||||||
|
<Property name="hazelcast.log.level">warn</Property>
|
||||||
</Properties>
|
</Properties>
|
||||||
<Appenders>
|
<Appenders>
|
||||||
<Console name="console" target="SYSTEM_OUT">
|
<Console name="console" target="SYSTEM_OUT">
|
||||||
<PatternLayout pattern="%d %p [%c] - <%m>%n"/>
|
<PatternLayout pattern="%highlight{%d %p [%c] - <%m>}%n"/>
|
||||||
</Console>
|
</Console>
|
||||||
<RollingFile name="file" fileName="${sys:cas.log.dir}/cas.log" append="true"
|
<RollingFile name="file" fileName="${baseDir}/cas.log" append="true"
|
||||||
filePattern="${sys:cas.log.dir}/cas-%d{yyyy-MM-dd-HH}-%i.log">
|
filePattern="${baseDir}/cas-%d{yyyy-MM-dd-HH}-%i.log">
|
||||||
<PatternLayout pattern="%d %p [%c] - <%m>%n"/>
|
<PatternLayout pattern="%d %p [%c] - <%m>%n"/>
|
||||||
<Policies>
|
<Policies>
|
||||||
<OnStartupTriggeringPolicy />
|
<OnStartupTriggeringPolicy />
|
||||||
|
@ -23,8 +29,8 @@
|
||||||
<TimeBasedTriggeringPolicy />
|
<TimeBasedTriggeringPolicy />
|
||||||
</Policies>
|
</Policies>
|
||||||
</RollingFile>
|
</RollingFile>
|
||||||
<RollingFile name="auditlogfile" fileName="${sys:cas.log.dir}/cas_audit.log" append="true"
|
<RollingFile name="auditlogfile" fileName="${baseDir}/cas_audit.log" append="true"
|
||||||
filePattern="${sys:cas.log.dir}/cas_audit-%d{yyyy-MM-dd-HH}-%i.log">
|
filePattern="${baseDir}/cas_audit-%d{yyyy-MM-dd-HH}-%i.log">
|
||||||
<PatternLayout pattern="%d %p [%c] - %m%n"/>
|
<PatternLayout pattern="%d %p [%c] - %m%n"/>
|
||||||
<Policies>
|
<Policies>
|
||||||
<OnStartupTriggeringPolicy />
|
<OnStartupTriggeringPolicy />
|
||||||
|
@ -33,16 +39,6 @@
|
||||||
</Policies>
|
</Policies>
|
||||||
</RollingFile>
|
</RollingFile>
|
||||||
|
|
||||||
<RollingFile name="perfFileAppender" fileName="${sys:cas.log.dir}/perfStats.log" append="true"
|
|
||||||
filePattern="${sys:cas.log.dir}/perfStats-%d{yyyy-MM-dd-HH}-%i.log">
|
|
||||||
<PatternLayout pattern="%m%n"/>
|
|
||||||
<Policies>
|
|
||||||
<OnStartupTriggeringPolicy />
|
|
||||||
<SizeBasedTriggeringPolicy size="10 MB"/>
|
|
||||||
<TimeBasedTriggeringPolicy />
|
|
||||||
</Policies>
|
|
||||||
</RollingFile>
|
|
||||||
|
|
||||||
<CasAppender name="casAudit">
|
<CasAppender name="casAudit">
|
||||||
<AppenderRef ref="auditlogfile" />
|
<AppenderRef ref="auditlogfile" />
|
||||||
</CasAppender>
|
</CasAppender>
|
||||||
|
@ -52,52 +48,58 @@
|
||||||
<CasAppender name="casConsole">
|
<CasAppender name="casConsole">
|
||||||
<AppenderRef ref="console" />
|
<AppenderRef ref="console" />
|
||||||
</CasAppender>
|
</CasAppender>
|
||||||
<CasAppender name="casPerf">
|
|
||||||
<AppenderRef ref="perfFileAppender" />
|
|
||||||
</CasAppender>
|
|
||||||
</Appenders>
|
</Appenders>
|
||||||
<Loggers>
|
<Loggers>
|
||||||
<!-- If adding a Logger with level set higher than warn, make category as selective as possible -->
|
<!-- If adding a Logger with level set higher than warn, make category as selective as possible -->
|
||||||
<!-- Loggers inherit appenders from Root Logger unless additivity is false -->
|
<!-- Loggers inherit appenders from Root Logger unless additivity is false -->
|
||||||
<AsyncLogger name="org.apereo" level="${sys:cas.log.level}" includeLocation="true"/>
|
<AsyncLogger name="org.apereo" level="${sys:cas.log.level}" includeLocation="true"/>
|
||||||
<AsyncLogger name="org.apereo.services.persondir" level="${sys:cas.log.level}" includeLocation="true"/>
|
<AsyncLogger name="org.apereo.services.persondir" level="${sys:cas.log.level}" includeLocation="true"/>
|
||||||
<AsyncLogger name="org.apereo.cas.web.flow" level="info" includeLocation="true"/>
|
<AsyncLogger name="org.apereo.cas.web.flow" level="${sys:cas.log.level}" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="org.apereo.spring" level="${sys:cas.log.level}" includeLocation="true"/>
|
||||||
|
|
||||||
<AsyncLogger name="org.apache" level="warn" />
|
<AsyncLogger name="org.apache" level="warn" />
|
||||||
<AsyncLogger name="org.apache.http" level="error" />
|
<AsyncLogger name="org.apache.http" level="error" />
|
||||||
<AsyncLogger name="org.springframework" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.cloud.server" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.cloud.client" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.cloud.bus" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.aop" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.boot" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.boot.actuate.autoconfigure" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.webflow" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.session" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.amqp" level="error" />
|
|
||||||
<AsyncLogger name="org.springframework.integration" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.messaging" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.web" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.orm.jpa" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.scheduling" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.context.annotation" level="error" />
|
|
||||||
<AsyncLogger name="org.springframework.boot.devtools" level="error" />
|
|
||||||
<AsyncLogger name="org.springframework.web.socket" level="warn" />
|
|
||||||
<AsyncLogger name="org.thymeleaf" level="warn" />
|
|
||||||
<AsyncLogger name="org.pac4j" level="warn" />
|
|
||||||
<AsyncLogger name="org.opensaml" level="warn"/>
|
|
||||||
<AsyncLogger name="net.sf.ehcache" level="warn" />
|
|
||||||
<AsyncLogger name="com.couchbase" level="warn" includeLocation="true"/>
|
|
||||||
<AsyncLogger name="com.ryantenney.metrics" level="warn" />
|
|
||||||
<AsyncLogger name="net.jradius" level="warn" />
|
|
||||||
<AsyncLogger name="org.openid4java" level="warn" />
|
|
||||||
<AsyncLogger name="org.ldaptive" level="warn" />
|
|
||||||
<AsyncLogger name="com.hazelcast" level="warn" />
|
|
||||||
<AsyncLogger name="org.apereo.spring" level="warn" />
|
|
||||||
|
|
||||||
<!-- Log perf stats only to perfStats.log -->
|
<AsyncLogger name="org.springframework.boot" level="${sys:spring.boot.log.level" includeLocation="true"/>
|
||||||
<AsyncLogger name="perfStatsLogger" level="info" additivity="false" includeLocation="true">
|
<AsyncLogger name="org.springframework.boot.context.embedded" level="info" includeLocation="true" />
|
||||||
<AppenderRef ref="casPerf"/>
|
<AsyncLogger name="org.springframework.boot.autoconfigure.security.servlet.UserDetailsServiceAutoConfiguration"
|
||||||
</AsyncLogger>
|
level="${sys:spring.security.log.level}" includeLocation="true" />
|
||||||
|
<AsyncLogger name="org.springframework.boot.autoconfigure.security" level="${sys:spring.security.log.level}" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="org.springframework.boot.devtools" level="off" includeLocation="true"/>
|
||||||
|
|
||||||
|
<AsyncLogger name="org.springframework" level="warn" includeLocation="true" />
|
||||||
|
<AsyncLogger name="org.springframework.webflow" level="${sys:spring.webflow.log.level}" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="org.springframework.aop" level="warn" includeLocation="true" />
|
||||||
|
<AsyncLogger name="org.springframework.web" level="warn" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="org.springframework.session" level="warn" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="org.springframework.scheduling" level="info" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="org.springframework.cloud.vault" level="warn" includeLocation="true" />
|
||||||
|
<AsyncLogger name="org.springframework.web.client" level="warn" includeLocation="true" />
|
||||||
|
<AsyncLogger name="org.springframework.security" level="${sys:spring.security.log.level}" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="org.springframework.cloud" level="${sys:spring.cloud.log.level}" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="org.springframework.amqp" level="error" />
|
||||||
|
<AsyncLogger name="org.springframework.integration" level="warn" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="org.springframework.messaging" level="warn" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="org.springframework.web" level="${sys:spring.web.log.level}" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="org.springframework.orm.jpa" level="warn" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="org.springframework.scheduling" level="warn" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="org.springframework.context.annotation" level="off" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="org.springframework.web.socket" level="warn" includeLocation="true"/>
|
||||||
|
|
||||||
|
<AsyncLogger name="org.thymeleaf" level="warn" includeLocation="true"/>
|
||||||
|
|
||||||
|
<AsyncLogger name="org.pac4j" level="${sys:pac4j.log.level}" includeLocation="true"/>
|
||||||
|
|
||||||
|
<AsyncLogger name="org.opensaml" level="${sys:opensaml.log.level}" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="PROTOCOL_MESSAGE" level="${sys:opensaml.log.level}" includeLocation="true" />
|
||||||
|
|
||||||
|
<AsyncLogger name="net.sf.ehcache" level="warn" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="com.couchbase" level="warn" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="de.codecentric" level="${sys:spring.boot.admin.log.level}" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="net.jradius" level="warn" includeLocation="true" />
|
||||||
|
<AsyncLogger name="org.openid4java" level="warn" includeLocation="true" />
|
||||||
|
<AsyncLogger name="org.ldaptive" level="${sys:ldap.log.level}" includeLocation="true"/>
|
||||||
|
<AsyncLogger name="com.hazelcast" level="${sys:hazelcast.log.level}" includeLocation="true"/>
|
||||||
|
|
||||||
<!-- Log audit to all root appenders, and also to audit log (additivity is not false) -->
|
<!-- Log audit to all root appenders, and also to audit log (additivity is not false) -->
|
||||||
<AsyncLogger name="org.apereo.inspektr.audit.support" level="info" includeLocation="true" >
|
<AsyncLogger name="org.apereo.inspektr.audit.support" level="info" includeLocation="true" >
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
This directory is references in the Dockerfile so it needs to be here.
|
Binary file not shown.
|
@ -0,0 +1,28 @@
|
||||||
|
# Versions
|
||||||
|
cas.version=6.1.5
|
||||||
|
springBootVersion=2.2.0.RELEASE
|
||||||
|
|
||||||
|
# Use -jetty, -undertow to other containers
|
||||||
|
# Or blank if you want to deploy to an external container
|
||||||
|
appServer=-tomcat
|
||||||
|
executable=false
|
||||||
|
|
||||||
|
gradleVersion=5.6.3
|
||||||
|
tomcatVersion=9.0.30
|
||||||
|
|
||||||
|
group=org.apereo.cas
|
||||||
|
sourceCompatibility=11
|
||||||
|
targetCompatibility=11
|
||||||
|
|
||||||
|
jibVersion=1.7.0
|
||||||
|
|
||||||
|
# Location of the downloaded CAS shell JAR
|
||||||
|
shellDir=build/libs
|
||||||
|
ivyVersion=2.4.0
|
||||||
|
gradleDownloadTaskVersion=3.4.3
|
||||||
|
gradleMavenPluginVersion=3.8.4
|
||||||
|
|
||||||
|
# use without "-slim" in tag name if you want tools like jstack, adds about 100MB to image size
|
||||||
|
# (https://hub.docker.com/r/adoptopenjdk/openjdk11/tags/)
|
||||||
|
baseDockerImage=adoptopenjdk/openjdk11:alpine-jre
|
||||||
|
allowInsecureRegistries=false
|
|
@ -0,0 +1,52 @@
|
||||||
|
apply plugin: "com.google.cloud.tools.jib"
|
||||||
|
|
||||||
|
jib {
|
||||||
|
from {
|
||||||
|
image = project.baseDockerImage
|
||||||
|
}
|
||||||
|
to {
|
||||||
|
image = "${project.group}/${project.name}"
|
||||||
|
/**
|
||||||
|
ecr-login: Amazon Elastic Container Registry (ECR)
|
||||||
|
gcr: Google Container Registry (GCR)
|
||||||
|
osxkeychain: Docker Hub
|
||||||
|
*/
|
||||||
|
credHelper = "osxkeychain"
|
||||||
|
/**
|
||||||
|
auth {
|
||||||
|
username = "*******"
|
||||||
|
password = "*******"
|
||||||
|
}
|
||||||
|
tags = [casServerVersion]
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
container {
|
||||||
|
useCurrentTimestamp = true
|
||||||
|
entrypoint = ['docker/entrypoint.sh']
|
||||||
|
ports = ['80', '443', '8080', '8443']
|
||||||
|
labels = [version:casServerVersion, name:project.name, group:project.group]
|
||||||
|
}
|
||||||
|
extraDirectories {
|
||||||
|
paths = 'src/main/jib'
|
||||||
|
permissions = [
|
||||||
|
'/docker/entrypoint.sh': '755'
|
||||||
|
]
|
||||||
|
}
|
||||||
|
allowInsecureRegistries = project.allowInsecureRegistries
|
||||||
|
}
|
||||||
|
|
||||||
|
task copyWebAppIntoJib(type: Copy, group: "Docker", description: "Copy the web application into Docker image") {
|
||||||
|
dependsOn build
|
||||||
|
from "build/libs/${casWebApplicationBinaryName}"
|
||||||
|
into "src/main/jib/docker/cas/war"
|
||||||
|
}
|
||||||
|
|
||||||
|
task copyConfigIntoJib(type: Copy, group: "Docker", description: "Copy the CAS configuration into Docker image") {
|
||||||
|
dependsOn build
|
||||||
|
from "etc/cas"
|
||||||
|
into "src/main/jib/docker/cas"
|
||||||
|
}
|
||||||
|
|
||||||
|
task deleteWebAppFromJib(type: Delete, group: "Docker", description: "Explodes the CAS web application archive") {
|
||||||
|
delete "src/main/jib/docker/cas"
|
||||||
|
}
|
|
@ -0,0 +1,24 @@
|
||||||
|
apply plugin: "org.springframework.boot"
|
||||||
|
|
||||||
|
bootRun.enabled = false
|
||||||
|
bootRun.onlyIf { return false }
|
||||||
|
tasks.remove(tasks['bootRun'])
|
||||||
|
|
||||||
|
springBoot {
|
||||||
|
mainClassName = "org.apereo.cas.web.CasWebApplication"
|
||||||
|
}
|
||||||
|
|
||||||
|
bootWar {
|
||||||
|
doFirst {
|
||||||
|
def executable = project.hasProperty("executable") && Boolean.valueOf(project.getProperty("executable"))
|
||||||
|
if (executable) {
|
||||||
|
logger.info "Including launch script for executable WAR artifact"
|
||||||
|
launchScript()
|
||||||
|
} else {
|
||||||
|
logger.info "WAR artifact is not marked as an executable"
|
||||||
|
}
|
||||||
|
archiveName "${casWebApplicationBinaryName}"
|
||||||
|
baseName "cas"
|
||||||
|
excludeDevtools = true
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,258 @@
|
||||||
|
import org.apache.ivy.util.url.*
|
||||||
|
import org.apache.tools.ant.taskdefs.condition.Os
|
||||||
|
import org.gradle.api.tasks.Copy
|
||||||
|
|
||||||
|
import java.nio.file.*
|
||||||
|
import org.gradle.internal.logging.text.StyledTextOutputFactory;
|
||||||
|
import static org.gradle.internal.logging.text.StyledTextOutput.Style;
|
||||||
|
|
||||||
|
buildscript {
|
||||||
|
repositories {
|
||||||
|
mavenLocal()
|
||||||
|
mavenCentral()
|
||||||
|
jcenter()
|
||||||
|
}
|
||||||
|
dependencies {
|
||||||
|
classpath "org.apache.ivy:ivy:${project.ivyVersion}"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
apply plugin: "de.undercouch.download"
|
||||||
|
|
||||||
|
def tomcatDirectory = "${buildDir}/apache-tomcat-${tomcatVersion}"
|
||||||
|
project.ext."tomcatDirectory" = tomcatDirectory
|
||||||
|
|
||||||
|
def explodedDir="${buildDir}/cas"
|
||||||
|
def explodedResourcesDir="${buildDir}/cas-resources"
|
||||||
|
def resourceJarName = "cas-server-webapp-resources"
|
||||||
|
|
||||||
|
task copyCasConfiguration(type: Copy, group: "build", description: "Copy the CAS configuration from this project to /etc/cas/config") {
|
||||||
|
from "etc/cas/config"
|
||||||
|
into new File('/etc/cas/config').absolutePath
|
||||||
|
doFirst {
|
||||||
|
new File('/etc/cas/config').mkdirs()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
task explodeWarOnly(type: Copy, group: "build", description: "Explodes the CAS web application archive") {
|
||||||
|
dependsOn 'build'
|
||||||
|
from zipTree("build/libs/${casWebApplicationBinaryName}")
|
||||||
|
into explodedDir
|
||||||
|
}
|
||||||
|
|
||||||
|
task explodeWar(type: Copy, group: "build", description: "Explodes the CAS archive and resources jar from the CAS web application archive") {
|
||||||
|
dependsOn explodeWarOnly
|
||||||
|
from zipTree("${explodedDir}/WEB-INF/lib/${resourceJarName}-${casServerVersion}.jar")
|
||||||
|
into explodedResourcesDir
|
||||||
|
}
|
||||||
|
|
||||||
|
task run(group: "build", description: "Run the CAS web application in embedded container mode") {
|
||||||
|
dependsOn 'build'
|
||||||
|
doLast {
|
||||||
|
def casRunArgs = new ArrayList<>(Arrays.asList("-server -noverify -Xmx2048M -XX:+TieredCompilation -XX:TieredStopAtLevel=1".split(" ")))
|
||||||
|
if (project.hasProperty('args')) {
|
||||||
|
casRunArgs.addAll(project.args.split('\\s+'))
|
||||||
|
}
|
||||||
|
javaexec {
|
||||||
|
main = "-jar"
|
||||||
|
jvmArgs = casRunArgs
|
||||||
|
args = ["build/libs/${casWebApplicationBinaryName}"]
|
||||||
|
logger.info "Started ${commandLine}"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
task setExecutable(group: "build", description: "Configure the project to run in executable mode") {
|
||||||
|
doFirst {
|
||||||
|
project.setProperty("executable", "true")
|
||||||
|
logger.info "Configuring the project as executable"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
task executable(type:Exec, group: "build", description: "Run the CAS web application in standalone executable mode") {
|
||||||
|
dependsOn setExecutable, 'build'
|
||||||
|
doFirst {
|
||||||
|
workingDir "."
|
||||||
|
if (!Os.isFamily(Os.FAMILY_WINDOWS)) {
|
||||||
|
commandLine "chmod", "+x", bootWar.archivePath
|
||||||
|
}
|
||||||
|
logger.info "Running ${bootWar.archivePath}"
|
||||||
|
commandLine bootWar.archivePath
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
task debug(group: "build", description: "Debug the CAS web application in embedded mode on port 5005") {
|
||||||
|
dependsOn 'build'
|
||||||
|
doLast {
|
||||||
|
logger.info "Debugging process is started in a suspended state, listening on port 5005."
|
||||||
|
def casArgs = Arrays.asList("-Xmx2048M".split(" "))
|
||||||
|
javaexec {
|
||||||
|
main = "-jar"
|
||||||
|
jvmArgs = casArgs
|
||||||
|
debug = true
|
||||||
|
args = ["build/libs/${casWebApplicationBinaryName}"]
|
||||||
|
logger.info "Started ${commandLine}"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
task downloadShell(group: "shell", description: "Download CAS shell jar from snapshot or release maven repo") {
|
||||||
|
doFirst {
|
||||||
|
mkdir "${project.shellDir}"
|
||||||
|
}
|
||||||
|
doLast {
|
||||||
|
def downloadFile
|
||||||
|
if (isRunningCasServerSnapshot(casServerVersion)) {
|
||||||
|
def snapshotDir = "https://oss.sonatype.org/content/repositories/snapshots/org/apereo/cas/cas-server-support-shell/${casServerVersion}/"
|
||||||
|
def files = new ApacheURLLister().listFiles(new URL(snapshotDir))
|
||||||
|
files = files.sort{it.path}
|
||||||
|
files.each {
|
||||||
|
if (it.path.endsWith(".jar")) {
|
||||||
|
downloadFile = it
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
downloadFile = "https://repo1.maven.org/maven2/org/apereo/cas/cas-server-support-shell/${casServerVersion}/cas-server-support-shell-${casServerVersion}.jar"
|
||||||
|
}
|
||||||
|
logger.info "Downloading file: ${downloadFile}"
|
||||||
|
download {
|
||||||
|
src downloadFile
|
||||||
|
dest new File("${project.shellDir}", "cas-server-support-shell-${casServerVersion}.jar")
|
||||||
|
overwrite false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
task runShell(group: "shell", description: "Run the CAS shell") {
|
||||||
|
dependsOn downloadShell
|
||||||
|
doLast {
|
||||||
|
println "Run the following command to launch the shell:\n\tjava -jar ${project.shellDir}/cas-server-support-shell-${casServerVersion}.jar"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
task debugShell(group: "shell", description: "Run the CAS shell with debug options, wait for debugger on port 5005") {
|
||||||
|
dependsOn downloadShell
|
||||||
|
doLast {
|
||||||
|
println """
|
||||||
|
Run the following command to launch the shell:\n\t
|
||||||
|
java -Xrunjdwp:transport=dt_socket,address=5000,server=y,suspend=y -jar ${project.shellDir}/cas-server-support-shell-${casServerVersion}.jar
|
||||||
|
"""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
task showConfiguration(group: "build", description: "Show configurations for each dependency, etc") {
|
||||||
|
doLast() {
|
||||||
|
def cfg = project.hasProperty("configuration") ? project.property("configuration") : "compile"
|
||||||
|
configurations.getByName(cfg).each { println it }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
task allDependenciesInsight(group: "build", type: DependencyInsightReportTask, description: "Produce insight information for all dependencies") {}
|
||||||
|
|
||||||
|
task allDependencies(group: "build", type: DependencyReportTask, description: "Display a graph of all project dependencies") {}
|
||||||
|
|
||||||
|
task casVersion (group: "build", description: "Display the current CAS version") {
|
||||||
|
doFirst {
|
||||||
|
def verbose = project.hasProperty("verbose") && Boolean.valueOf(project.getProperty("verbose"))
|
||||||
|
if (verbose) {
|
||||||
|
def out = services.get(StyledTextOutputFactory).create("CAS")
|
||||||
|
println "******************************************************************"
|
||||||
|
out.withStyle(Style.Info).println "Apereo CAS $casServerVersion"
|
||||||
|
out.withStyle(Style.Description).println "Enterprise Single SignOn for all earthlings and beyond"
|
||||||
|
out.withStyle(Style.SuccessHeader).println "- GitHub: "
|
||||||
|
out.withStyle(Style.Success).println "https://github.com/apereo/cas"
|
||||||
|
out.withStyle(Style.SuccessHeader).println "- Docs: "
|
||||||
|
out.withStyle(Style.Success).println "https://apereo.github.io/cas"
|
||||||
|
out.withStyle(Style.SuccessHeader).println "- Blog: "
|
||||||
|
out.withStyle(Style.Success).println "https://apereo.github.io"
|
||||||
|
println "******************************************************************"
|
||||||
|
} else {
|
||||||
|
println casServerVersion
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
task createKeystore(group: "build", description: "Create CAS keystore") {
|
||||||
|
doFirst {
|
||||||
|
mkdir "/etc/cas"
|
||||||
|
|
||||||
|
def keystorePath = "/etc/cas/thekeystore"
|
||||||
|
|
||||||
|
def dn = "CN=cas.example.org,OU=Example,OU=Org,C=US"
|
||||||
|
if (project.hasProperty("certificateDn")) {
|
||||||
|
dn = project.getProperty("certificateDn")
|
||||||
|
}
|
||||||
|
def subjectAltName = "dns:example.org,dns:localhost,ip:127.0.0.1"
|
||||||
|
if (project.hasProperty("certificateSubAltName")) {
|
||||||
|
subjectAltName = project.getProperty("certificateSubAltName")
|
||||||
|
}
|
||||||
|
// this will fail if thekeystore exists and has cert with cas alias already (so delete if you want to recreate)
|
||||||
|
logger.info "Generating keystore for CAS with DN ${dn}"
|
||||||
|
exec {
|
||||||
|
workingDir "."
|
||||||
|
commandLine "keytool", "-genkeypair", "-alias", "cas",
|
||||||
|
"-keyalg", "RSA",
|
||||||
|
"-keypass", "changeit", "-storepass", "changeit",
|
||||||
|
"-keystore", keystorePath,
|
||||||
|
"-dname", dn, "-ext", "SAN=${subjectAltName}"
|
||||||
|
}
|
||||||
|
logger.info "Exporting cert from keystore..."
|
||||||
|
exec {
|
||||||
|
workingDir "."
|
||||||
|
commandLine "keytool", "-exportcert", "-alias", "cas",
|
||||||
|
"-storepass", "changeit", "-keystore", keystorePath,
|
||||||
|
"-file", "/etc/cas/cas.cer"
|
||||||
|
}
|
||||||
|
logger.info "Import /etc/cas/cas.cer into your Java truststore (JAVA_HOME/lib/security/cacerts)"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
task listTemplateViews (group: "build", description: "List all CAS views") {
|
||||||
|
dependsOn explodeWar
|
||||||
|
|
||||||
|
doFirst {
|
||||||
|
fileTree(explodedResourcesDir).matching {
|
||||||
|
include "**/*.html"
|
||||||
|
}
|
||||||
|
.collect { it.name }
|
||||||
|
.toSorted()
|
||||||
|
.each { println it }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
task getResource(group: "build", description: "Fetch a CAS resource and move it into the overlay") {
|
||||||
|
dependsOn explodeWar
|
||||||
|
|
||||||
|
doFirst {
|
||||||
|
def resourceName = project.getProperty("resourceName")
|
||||||
|
|
||||||
|
def results = fileTree(explodedResourcesDir).matching {
|
||||||
|
include "**/${resourceName}.*"
|
||||||
|
}
|
||||||
|
if (results.isEmpty()) {
|
||||||
|
println "No resources could be found matching ${resourceName}"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if (results.size() > 1) {
|
||||||
|
println "Multiple resources found matching ${resourceName}: ${results}"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
def fromFile = explodedResourcesDir
|
||||||
|
def resourcesDir = "src/main/resources"
|
||||||
|
mkdir resourcesDir
|
||||||
|
|
||||||
|
def resourceFile = results[0].canonicalPath
|
||||||
|
def toResourceFile = resourceFile.replace(fromFile, resourcesDir)
|
||||||
|
|
||||||
|
def parent = file(toResourceFile).getParent()
|
||||||
|
mkdir parent
|
||||||
|
|
||||||
|
Files.copy(Paths.get(resourceFile), Paths.get(toResourceFile), StandardCopyOption.REPLACE_EXISTING)
|
||||||
|
println "Copied file ${resourceFile} to ${toResourceFile}"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
def isRunningCasServerSnapshot(casServerVersion) {
|
||||||
|
return "${casServerVersion}".contains("-SNAPSHOT")
|
||||||
|
}
|
|
@ -0,0 +1,5 @@
|
||||||
|
distributionBase=GRADLE_USER_HOME
|
||||||
|
distributionPath=wrapper/dists
|
||||||
|
distributionUrl=https\://services.gradle.org/distributions/gradle-5.6.3-bin.zip
|
||||||
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
|
zipStorePath=wrapper/dists
|
|
@ -0,0 +1,188 @@
|
||||||
|
#!/usr/bin/env sh
|
||||||
|
|
||||||
|
#
|
||||||
|
# Copyright 2015 the original author or authors.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# https://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
##############################################################################
|
||||||
|
##
|
||||||
|
## Gradle start up script for UN*X
|
||||||
|
##
|
||||||
|
##############################################################################
|
||||||
|
|
||||||
|
# Attempt to set APP_HOME
|
||||||
|
# Resolve links: $0 may be a link
|
||||||
|
PRG="$0"
|
||||||
|
# Need this for relative symlinks.
|
||||||
|
while [ -h "$PRG" ] ; do
|
||||||
|
ls=`ls -ld "$PRG"`
|
||||||
|
link=`expr "$ls" : '.*-> \(.*\)$'`
|
||||||
|
if expr "$link" : '/.*' > /dev/null; then
|
||||||
|
PRG="$link"
|
||||||
|
else
|
||||||
|
PRG=`dirname "$PRG"`"/$link"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
SAVED="`pwd`"
|
||||||
|
cd "`dirname \"$PRG\"`/" >/dev/null
|
||||||
|
APP_HOME="`pwd -P`"
|
||||||
|
cd "$SAVED" >/dev/null
|
||||||
|
|
||||||
|
APP_NAME="Gradle"
|
||||||
|
APP_BASE_NAME=`basename "$0"`
|
||||||
|
|
||||||
|
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
||||||
|
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
|
||||||
|
|
||||||
|
# Use the maximum available, or set MAX_FD != -1 to use that value.
|
||||||
|
MAX_FD="maximum"
|
||||||
|
|
||||||
|
warn () {
|
||||||
|
echo "$*"
|
||||||
|
}
|
||||||
|
|
||||||
|
die () {
|
||||||
|
echo
|
||||||
|
echo "$*"
|
||||||
|
echo
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# OS specific support (must be 'true' or 'false').
|
||||||
|
cygwin=false
|
||||||
|
msys=false
|
||||||
|
darwin=false
|
||||||
|
nonstop=false
|
||||||
|
case "`uname`" in
|
||||||
|
CYGWIN* )
|
||||||
|
cygwin=true
|
||||||
|
;;
|
||||||
|
Darwin* )
|
||||||
|
darwin=true
|
||||||
|
;;
|
||||||
|
MINGW* )
|
||||||
|
msys=true
|
||||||
|
;;
|
||||||
|
NONSTOP* )
|
||||||
|
nonstop=true
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
|
||||||
|
|
||||||
|
# Determine the Java command to use to start the JVM.
|
||||||
|
if [ -n "$JAVA_HOME" ] ; then
|
||||||
|
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
|
||||||
|
# IBM's JDK on AIX uses strange locations for the executables
|
||||||
|
JAVACMD="$JAVA_HOME/jre/sh/java"
|
||||||
|
else
|
||||||
|
JAVACMD="$JAVA_HOME/bin/java"
|
||||||
|
fi
|
||||||
|
if [ ! -x "$JAVACMD" ] ; then
|
||||||
|
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
|
||||||
|
|
||||||
|
Please set the JAVA_HOME variable in your environment to match the
|
||||||
|
location of your Java installation."
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
JAVACMD="java"
|
||||||
|
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
||||||
|
|
||||||
|
Please set the JAVA_HOME variable in your environment to match the
|
||||||
|
location of your Java installation."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Increase the maximum file descriptors if we can.
|
||||||
|
if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
|
||||||
|
MAX_FD_LIMIT=`ulimit -H -n`
|
||||||
|
if [ $? -eq 0 ] ; then
|
||||||
|
if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
|
||||||
|
MAX_FD="$MAX_FD_LIMIT"
|
||||||
|
fi
|
||||||
|
ulimit -n $MAX_FD
|
||||||
|
if [ $? -ne 0 ] ; then
|
||||||
|
warn "Could not set maximum file descriptor limit: $MAX_FD"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# For Darwin, add options to specify how the application appears in the dock
|
||||||
|
if $darwin; then
|
||||||
|
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
|
||||||
|
fi
|
||||||
|
|
||||||
|
# For Cygwin or MSYS, switch paths to Windows format before running java
|
||||||
|
if [ "$cygwin" = "true" -o "$msys" = "true" ] ; then
|
||||||
|
APP_HOME=`cygpath --path --mixed "$APP_HOME"`
|
||||||
|
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
|
||||||
|
JAVACMD=`cygpath --unix "$JAVACMD"`
|
||||||
|
|
||||||
|
# We build the pattern for arguments to be converted via cygpath
|
||||||
|
ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
|
||||||
|
SEP=""
|
||||||
|
for dir in $ROOTDIRSRAW ; do
|
||||||
|
ROOTDIRS="$ROOTDIRS$SEP$dir"
|
||||||
|
SEP="|"
|
||||||
|
done
|
||||||
|
OURCYGPATTERN="(^($ROOTDIRS))"
|
||||||
|
# Add a user-defined pattern to the cygpath arguments
|
||||||
|
if [ "$GRADLE_CYGPATTERN" != "" ] ; then
|
||||||
|
OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
|
||||||
|
fi
|
||||||
|
# Now convert the arguments - kludge to limit ourselves to /bin/sh
|
||||||
|
i=0
|
||||||
|
for arg in "$@" ; do
|
||||||
|
CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
|
||||||
|
CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
|
||||||
|
|
||||||
|
if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
|
||||||
|
eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
|
||||||
|
else
|
||||||
|
eval `echo args$i`="\"$arg\""
|
||||||
|
fi
|
||||||
|
i=$((i+1))
|
||||||
|
done
|
||||||
|
case $i in
|
||||||
|
(0) set -- ;;
|
||||||
|
(1) set -- "$args0" ;;
|
||||||
|
(2) set -- "$args0" "$args1" ;;
|
||||||
|
(3) set -- "$args0" "$args1" "$args2" ;;
|
||||||
|
(4) set -- "$args0" "$args1" "$args2" "$args3" ;;
|
||||||
|
(5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
|
||||||
|
(6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
|
||||||
|
(7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
|
||||||
|
(8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
|
||||||
|
(9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Escape application args
|
||||||
|
save () {
|
||||||
|
for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
|
||||||
|
echo " "
|
||||||
|
}
|
||||||
|
APP_ARGS=$(save "$@")
|
||||||
|
|
||||||
|
# Collect all arguments for the java command, following the shell quoting and substitution rules
|
||||||
|
eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
|
||||||
|
|
||||||
|
# by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong
|
||||||
|
if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then
|
||||||
|
cd "$(dirname "$0")"
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec "$JAVACMD" "$@"
|
|
@ -0,0 +1,100 @@
|
||||||
|
@rem
|
||||||
|
@rem Copyright 2015 the original author or authors.
|
||||||
|
@rem
|
||||||
|
@rem Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
@rem you may not use this file except in compliance with the License.
|
||||||
|
@rem You may obtain a copy of the License at
|
||||||
|
@rem
|
||||||
|
@rem https://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
@rem
|
||||||
|
@rem Unless required by applicable law or agreed to in writing, software
|
||||||
|
@rem distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
@rem See the License for the specific language governing permissions and
|
||||||
|
@rem limitations under the License.
|
||||||
|
@rem
|
||||||
|
|
||||||
|
@if "%DEBUG%" == "" @echo off
|
||||||
|
@rem ##########################################################################
|
||||||
|
@rem
|
||||||
|
@rem Gradle startup script for Windows
|
||||||
|
@rem
|
||||||
|
@rem ##########################################################################
|
||||||
|
|
||||||
|
@rem Set local scope for the variables with windows NT shell
|
||||||
|
if "%OS%"=="Windows_NT" setlocal
|
||||||
|
|
||||||
|
set DIRNAME=%~dp0
|
||||||
|
if "%DIRNAME%" == "" set DIRNAME=.
|
||||||
|
set APP_BASE_NAME=%~n0
|
||||||
|
set APP_HOME=%DIRNAME%
|
||||||
|
|
||||||
|
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
||||||
|
set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
|
||||||
|
|
||||||
|
@rem Find java.exe
|
||||||
|
if defined JAVA_HOME goto findJavaFromJavaHome
|
||||||
|
|
||||||
|
set JAVA_EXE=java.exe
|
||||||
|
%JAVA_EXE% -version >NUL 2>&1
|
||||||
|
if "%ERRORLEVEL%" == "0" goto init
|
||||||
|
|
||||||
|
echo.
|
||||||
|
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
||||||
|
echo.
|
||||||
|
echo Please set the JAVA_HOME variable in your environment to match the
|
||||||
|
echo location of your Java installation.
|
||||||
|
|
||||||
|
goto fail
|
||||||
|
|
||||||
|
:findJavaFromJavaHome
|
||||||
|
set JAVA_HOME=%JAVA_HOME:"=%
|
||||||
|
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
|
||||||
|
|
||||||
|
if exist "%JAVA_EXE%" goto init
|
||||||
|
|
||||||
|
echo.
|
||||||
|
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
|
||||||
|
echo.
|
||||||
|
echo Please set the JAVA_HOME variable in your environment to match the
|
||||||
|
echo location of your Java installation.
|
||||||
|
|
||||||
|
goto fail
|
||||||
|
|
||||||
|
:init
|
||||||
|
@rem Get command-line arguments, handling Windows variants
|
||||||
|
|
||||||
|
if not "%OS%" == "Windows_NT" goto win9xME_args
|
||||||
|
|
||||||
|
:win9xME_args
|
||||||
|
@rem Slurp the command line arguments.
|
||||||
|
set CMD_LINE_ARGS=
|
||||||
|
set _SKIP=2
|
||||||
|
|
||||||
|
:win9xME_args_slurp
|
||||||
|
if "x%~1" == "x" goto execute
|
||||||
|
|
||||||
|
set CMD_LINE_ARGS=%*
|
||||||
|
|
||||||
|
:execute
|
||||||
|
@rem Setup the command line
|
||||||
|
|
||||||
|
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
|
||||||
|
|
||||||
|
@rem Execute Gradle
|
||||||
|
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
|
||||||
|
|
||||||
|
:end
|
||||||
|
@rem End local scope for the variables with windows NT shell
|
||||||
|
if "%ERRORLEVEL%"=="0" goto mainEnd
|
||||||
|
|
||||||
|
:fail
|
||||||
|
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
|
||||||
|
rem the _cmd.exe /c_ return code!
|
||||||
|
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
|
||||||
|
exit /b 1
|
||||||
|
|
||||||
|
:mainEnd
|
||||||
|
if "%OS%"=="Windows_NT" endlocal
|
||||||
|
|
||||||
|
:omega
|
Binary file not shown.
|
@ -1,3 +0,0 @@
|
||||||
#Maven download properties
|
|
||||||
#Fri Dec 01 21:35:11 MST 2017
|
|
||||||
distributionUrl=https\://repository.apache.org/content/repositories/releases/org/apache/maven/apache-maven/3.5.2/apache-maven-3.5.2-bin.zip
|
|
|
@ -1,234 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
# ----------------------------------------------------------------------------
|
|
||||||
# Licensed to the Apache Software Foundation (ASF) under one
|
|
||||||
# or more contributor license agreements. See the NOTICE file
|
|
||||||
# distributed with this work for additional information
|
|
||||||
# regarding copyright ownership. The ASF licenses this file
|
|
||||||
# to you under the Apache License, Version 2.0 (the
|
|
||||||
# "License"); you may not use this file except in compliance
|
|
||||||
# with the License. You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing,
|
|
||||||
# software distributed under the License is distributed on an
|
|
||||||
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
||||||
# KIND, either express or implied. See the License for the
|
|
||||||
# specific language governing permissions and limitations
|
|
||||||
# under the License.
|
|
||||||
# ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# ----------------------------------------------------------------------------
|
|
||||||
# Maven2 Start Up Batch script
|
|
||||||
#
|
|
||||||
# Required ENV vars:
|
|
||||||
# ------------------
|
|
||||||
# JAVA_HOME - location of a JDK home dir
|
|
||||||
#
|
|
||||||
# Optional ENV vars
|
|
||||||
# -----------------
|
|
||||||
# M2_HOME - location of maven2's installed home dir
|
|
||||||
# MAVEN_OPTS - parameters passed to the Java VM when running Maven
|
|
||||||
# e.g. to debug Maven itself, use
|
|
||||||
# set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
|
|
||||||
# MAVEN_SKIP_RC - flag to disable loading of mavenrc files
|
|
||||||
# ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
if [ -z "$MAVEN_SKIP_RC" ] ; then
|
|
||||||
|
|
||||||
if [ -f /etc/mavenrc ] ; then
|
|
||||||
. /etc/mavenrc
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -f "$HOME/.mavenrc" ] ; then
|
|
||||||
. "$HOME/.mavenrc"
|
|
||||||
fi
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
# OS specific support. $var _must_ be set to either true or false.
|
|
||||||
cygwin=false;
|
|
||||||
darwin=false;
|
|
||||||
mingw=false
|
|
||||||
case "`uname`" in
|
|
||||||
CYGWIN*) cygwin=true ;;
|
|
||||||
MINGW*) mingw=true;;
|
|
||||||
Darwin*) darwin=true
|
|
||||||
#
|
|
||||||
# Look for the Apple JDKs first to preserve the existing behaviour, and then look
|
|
||||||
# for the new JDKs provided by Oracle.
|
|
||||||
#
|
|
||||||
if [ -z "$JAVA_HOME" ] && [ -L /System/Library/Frameworks/JavaVM.framework/Versions/CurrentJDK ] ; then
|
|
||||||
#
|
|
||||||
# Apple JDKs
|
|
||||||
#
|
|
||||||
export JAVA_HOME=/System/Library/Frameworks/JavaVM.framework/Versions/CurrentJDK/Home
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$JAVA_HOME" ] && [ -L /System/Library/Java/JavaVirtualMachines/CurrentJDK ] ; then
|
|
||||||
#
|
|
||||||
# Apple JDKs
|
|
||||||
#
|
|
||||||
export JAVA_HOME=/System/Library/Java/JavaVirtualMachines/CurrentJDK/Contents/Home
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$JAVA_HOME" ] && [ -L "/Library/Java/JavaVirtualMachines/CurrentJDK" ] ; then
|
|
||||||
#
|
|
||||||
# Oracle JDKs
|
|
||||||
#
|
|
||||||
export JAVA_HOME=/Library/Java/JavaVirtualMachines/CurrentJDK/Contents/Home
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$JAVA_HOME" ] && [ -x "/usr/libexec/java_home" ]; then
|
|
||||||
#
|
|
||||||
# Apple JDKs
|
|
||||||
#
|
|
||||||
export JAVA_HOME=`/usr/libexec/java_home`
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if [ -z "$JAVA_HOME" ] ; then
|
|
||||||
if [ -r /etc/gentoo-release ] ; then
|
|
||||||
JAVA_HOME=`java-config --jre-home`
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$M2_HOME" ] ; then
|
|
||||||
## resolve links - $0 may be a link to maven's home
|
|
||||||
PRG="$0"
|
|
||||||
|
|
||||||
# need this for relative symlinks
|
|
||||||
while [ -h "$PRG" ] ; do
|
|
||||||
ls=`ls -ld "$PRG"`
|
|
||||||
link=`expr "$ls" : '.*-> \(.*\)$'`
|
|
||||||
if expr "$link" : '/.*' > /dev/null; then
|
|
||||||
PRG="$link"
|
|
||||||
else
|
|
||||||
PRG="`dirname "$PRG"`/$link"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
saveddir=`pwd`
|
|
||||||
|
|
||||||
M2_HOME=`dirname "$PRG"`/..
|
|
||||||
|
|
||||||
# make it fully qualified
|
|
||||||
M2_HOME=`cd "$M2_HOME" && pwd`
|
|
||||||
|
|
||||||
cd "$saveddir"
|
|
||||||
# echo Using m2 at $M2_HOME
|
|
||||||
fi
|
|
||||||
|
|
||||||
# For Cygwin, ensure paths are in UNIX format before anything is touched
|
|
||||||
if $cygwin ; then
|
|
||||||
[ -n "$M2_HOME" ] &&
|
|
||||||
M2_HOME=`cygpath --unix "$M2_HOME"`
|
|
||||||
[ -n "$JAVA_HOME" ] &&
|
|
||||||
JAVA_HOME=`cygpath --unix "$JAVA_HOME"`
|
|
||||||
[ -n "$CLASSPATH" ] &&
|
|
||||||
CLASSPATH=`cygpath --path --unix "$CLASSPATH"`
|
|
||||||
fi
|
|
||||||
|
|
||||||
# For Migwn, ensure paths are in UNIX format before anything is touched
|
|
||||||
if $mingw ; then
|
|
||||||
[ -n "$M2_HOME" ] &&
|
|
||||||
M2_HOME="`(cd "$M2_HOME"; pwd)`"
|
|
||||||
[ -n "$JAVA_HOME" ] &&
|
|
||||||
JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`"
|
|
||||||
# TODO classpath?
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$JAVA_HOME" ]; then
|
|
||||||
javaExecutable="`which javac`"
|
|
||||||
if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then
|
|
||||||
# readlink(1) is not available as standard on Solaris 10.
|
|
||||||
readLink=`which readlink`
|
|
||||||
if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then
|
|
||||||
if $darwin ; then
|
|
||||||
javaHome="`dirname \"$javaExecutable\"`"
|
|
||||||
javaExecutable="`cd \"$javaHome\" && pwd -P`/javac"
|
|
||||||
else
|
|
||||||
javaExecutable="`readlink -f \"$javaExecutable\"`"
|
|
||||||
fi
|
|
||||||
javaHome="`dirname \"$javaExecutable\"`"
|
|
||||||
javaHome=`expr "$javaHome" : '\(.*\)/bin'`
|
|
||||||
JAVA_HOME="$javaHome"
|
|
||||||
export JAVA_HOME
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$JAVACMD" ] ; then
|
|
||||||
if [ -n "$JAVA_HOME" ] ; then
|
|
||||||
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
|
|
||||||
# IBM's JDK on AIX uses strange locations for the executables
|
|
||||||
JAVACMD="$JAVA_HOME/jre/sh/java"
|
|
||||||
else
|
|
||||||
JAVACMD="$JAVA_HOME/bin/java"
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
JAVACMD="`which java`"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ ! -x "$JAVACMD" ] ; then
|
|
||||||
echo "Error: JAVA_HOME is not defined correctly." >&2
|
|
||||||
echo " We cannot execute $JAVACMD" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$JAVA_HOME" ] ; then
|
|
||||||
echo "Warning: JAVA_HOME environment variable is not set."
|
|
||||||
fi
|
|
||||||
|
|
||||||
CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher
|
|
||||||
|
|
||||||
# For Cygwin, switch paths to Windows format before running java
|
|
||||||
if $cygwin; then
|
|
||||||
[ -n "$M2_HOME" ] &&
|
|
||||||
M2_HOME=`cygpath --path --windows "$M2_HOME"`
|
|
||||||
[ -n "$JAVA_HOME" ] &&
|
|
||||||
JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"`
|
|
||||||
[ -n "$CLASSPATH" ] &&
|
|
||||||
CLASSPATH=`cygpath --path --windows "$CLASSPATH"`
|
|
||||||
fi
|
|
||||||
|
|
||||||
# traverses directory structure from process work directory to filesystem root
|
|
||||||
# first directory with .mvn subdirectory is considered project base directory
|
|
||||||
find_maven_basedir() {
|
|
||||||
local basedir=$(pwd)
|
|
||||||
local wdir=$(pwd)
|
|
||||||
while [ "$wdir" != '/' ] ; do
|
|
||||||
wdir=$(cd "$wdir/.."; pwd)
|
|
||||||
if [ -d "$wdir"/.mvn ] ; then
|
|
||||||
basedir=$wdir
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
echo "${basedir}"
|
|
||||||
}
|
|
||||||
|
|
||||||
# concatenates all lines of a file
|
|
||||||
concat_lines() {
|
|
||||||
if [ -f "$1" ]; then
|
|
||||||
echo "$(tr -s '\n' ' ' < "$1")"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-$(find_maven_basedir)}
|
|
||||||
MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS"
|
|
||||||
|
|
||||||
# Provide a "standardized" way to retrieve the CLI args that will
|
|
||||||
# work with both Windows and non-Windows executions.
|
|
||||||
MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@"
|
|
||||||
export MAVEN_CMD_LINE_ARGS
|
|
||||||
|
|
||||||
WRAPPER_LAUNCHER="org.apache.maven.wrapper.MavenWrapperMain"
|
|
||||||
|
|
||||||
exec "$JAVACMD" \
|
|
||||||
$MAVEN_OPTS \
|
|
||||||
"-Dmaven.home=${M2_HOME}" "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \
|
|
||||||
-classpath \
|
|
||||||
"$MAVEN_PROJECTBASEDIR/maven/maven-wrapper.jar" \
|
|
||||||
${WRAPPER_LAUNCHER} "$@"
|
|
|
@ -1,174 +0,0 @@
|
||||||
@REM ----------------------------------------------------------------------------
|
|
||||||
@REM Licensed to the Apache Software Foundation (ASF) under one
|
|
||||||
@REM or more contributor license agreements. See the NOTICE file
|
|
||||||
@REM distributed with this work for additional information
|
|
||||||
@REM regarding copyright ownership. The ASF licenses this file
|
|
||||||
@REM to you under the Apache License, Version 2.0 (the
|
|
||||||
@REM "License"); you may not use this file except in compliance
|
|
||||||
@REM with the License. You may obtain a copy of the License at
|
|
||||||
@REM
|
|
||||||
@REM http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
@REM
|
|
||||||
@REM Unless required by applicable law or agreed to in writing,
|
|
||||||
@REM software distributed under the License is distributed on an
|
|
||||||
@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
||||||
@REM KIND, either express or implied. See the License for the
|
|
||||||
@REM specific language governing permissions and limitations
|
|
||||||
@REM under the License.
|
|
||||||
@REM ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
@REM ----------------------------------------------------------------------------
|
|
||||||
@REM Maven2 Start Up Batch script
|
|
||||||
@REM
|
|
||||||
@REM Required ENV vars:
|
|
||||||
@REM JAVA_HOME - location of a JDK home dir
|
|
||||||
@REM
|
|
||||||
@REM Optional ENV vars
|
|
||||||
@REM M2_HOME - location of maven2's installed home dir
|
|
||||||
@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands
|
|
||||||
@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a key stroke before ending
|
|
||||||
@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven
|
|
||||||
@REM e.g. to debug Maven itself, use
|
|
||||||
@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
|
|
||||||
@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files
|
|
||||||
@REM ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on'
|
|
||||||
@echo off
|
|
||||||
@REM enable echoing my setting MAVEN_BATCH_ECHO to 'on'
|
|
||||||
@if "%MAVEN_BATCH_ECHO%" == "on" echo %MAVEN_BATCH_ECHO%
|
|
||||||
|
|
||||||
@REM set %HOME% to equivalent of $HOME
|
|
||||||
if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%")
|
|
||||||
|
|
||||||
@REM Execute a user defined script before this one
|
|
||||||
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre
|
|
||||||
@REM check for pre script, once with legacy .bat ending and once with .cmd ending
|
|
||||||
if exist "%HOME%\mavenrc_pre.bat" call "%HOME%\mavenrc_pre.bat"
|
|
||||||
if exist "%HOME%\mavenrc_pre.cmd" call "%HOME%\mavenrc_pre.cmd"
|
|
||||||
:skipRcPre
|
|
||||||
|
|
||||||
@setlocal
|
|
||||||
|
|
||||||
set ERROR_CODE=0
|
|
||||||
|
|
||||||
@REM To isolate internal variables from possible post scripts, we use another setlocal
|
|
||||||
@setlocal
|
|
||||||
|
|
||||||
@REM ==== START VALIDATION ====
|
|
||||||
if not "%JAVA_HOME%" == "" goto OkJHome
|
|
||||||
|
|
||||||
echo.
|
|
||||||
echo Error: JAVA_HOME not found in your environment. >&2
|
|
||||||
echo Please set the JAVA_HOME variable in your environment to match the >&2
|
|
||||||
echo location of your Java installation. >&2
|
|
||||||
echo.
|
|
||||||
goto error
|
|
||||||
|
|
||||||
:OkJHome
|
|
||||||
if exist "%JAVA_HOME%\bin\java.exe" goto chkMHome
|
|
||||||
|
|
||||||
echo.
|
|
||||||
echo Error: JAVA_HOME is set to an invalid directory. >&2
|
|
||||||
echo JAVA_HOME = "%JAVA_HOME%" >&2
|
|
||||||
echo Please set the JAVA_HOME variable in your environment to match the >&2
|
|
||||||
echo location of your Java installation. >&2
|
|
||||||
echo.
|
|
||||||
goto error
|
|
||||||
|
|
||||||
:chkMHome
|
|
||||||
if not "%M2_HOME%"=="" goto valMHome
|
|
||||||
|
|
||||||
SET "M2_HOME=%~dp0.."
|
|
||||||
if not "%M2_HOME%"=="" goto valMHome
|
|
||||||
|
|
||||||
echo.
|
|
||||||
echo Error: M2_HOME not found in your environment. >&2
|
|
||||||
echo Please set the M2_HOME variable in your environment to match the >&2
|
|
||||||
echo location of the Maven installation. >&2
|
|
||||||
echo.
|
|
||||||
goto error
|
|
||||||
|
|
||||||
:valMHome
|
|
||||||
|
|
||||||
:stripMHome
|
|
||||||
if not "_%M2_HOME:~-1%"=="_\" goto checkMCmd
|
|
||||||
set "M2_HOME=%M2_HOME:~0,-1%"
|
|
||||||
goto stripMHome
|
|
||||||
|
|
||||||
:checkMCmd
|
|
||||||
if exist "%M2_HOME%\bin\mvn.cmd" goto init
|
|
||||||
|
|
||||||
echo.
|
|
||||||
echo Error: M2_HOME is set to an invalid directory. >&2
|
|
||||||
echo M2_HOME = "%M2_HOME%" >&2
|
|
||||||
echo Please set the M2_HOME variable in your environment to match the >&2
|
|
||||||
echo location of the Maven installation >&2
|
|
||||||
echo.
|
|
||||||
goto error
|
|
||||||
@REM ==== END VALIDATION ====
|
|
||||||
|
|
||||||
:init
|
|
||||||
|
|
||||||
set MAVEN_CMD_LINE_ARGS=%*
|
|
||||||
|
|
||||||
@REM Find the project base dir, i.e. the directory that contains the folder ".mvn".
|
|
||||||
@REM Fallback to current working directory if not found.
|
|
||||||
|
|
||||||
set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR%
|
|
||||||
IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir
|
|
||||||
|
|
||||||
set EXEC_DIR=%CD%
|
|
||||||
set WDIR=%EXEC_DIR%
|
|
||||||
:findBaseDir
|
|
||||||
IF EXIST "%WDIR%"\.mvn goto baseDirFound
|
|
||||||
cd ..
|
|
||||||
IF "%WDIR%"=="%CD%" goto baseDirNotFound
|
|
||||||
set WDIR=%CD%
|
|
||||||
goto findBaseDir
|
|
||||||
|
|
||||||
:baseDirFound
|
|
||||||
set MAVEN_PROJECTBASEDIR=%WDIR%
|
|
||||||
cd "%EXEC_DIR%"
|
|
||||||
goto endDetectBaseDir
|
|
||||||
|
|
||||||
:baseDirNotFound
|
|
||||||
set MAVEN_PROJECTBASEDIR=%EXEC_DIR%
|
|
||||||
cd "%EXEC_DIR%"
|
|
||||||
|
|
||||||
:endDetectBaseDir
|
|
||||||
|
|
||||||
IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig
|
|
||||||
|
|
||||||
@setlocal EnableExtensions EnableDelayedExpansion
|
|
||||||
for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a
|
|
||||||
@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS%
|
|
||||||
|
|
||||||
:endReadAdditionalConfig
|
|
||||||
|
|
||||||
SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe"
|
|
||||||
set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\maven\maven-wrapper.jar"
|
|
||||||
set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
|
|
||||||
%MAVEN_JAVA_EXE% %JVM_CONFIG_MAVEN_PROPS% %MAVEN_OPTS% %MAVEN_DEBUG_OPTS% -classpath %WRAPPER_JAR% %WRAPPER_LAUNCHER% %MAVEN_CMD_LINE_ARGS%
|
|
||||||
|
|
||||||
if ERRORLEVEL 1 goto error
|
|
||||||
goto end
|
|
||||||
|
|
||||||
:error
|
|
||||||
set ERROR_CODE=1
|
|
||||||
|
|
||||||
:end
|
|
||||||
@endlocal & set ERROR_CODE=%ERROR_CODE%
|
|
||||||
|
|
||||||
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPost
|
|
||||||
@REM check for post script, once with legacy .bat ending and once with .cmd ending
|
|
||||||
if exist "%HOME%\mavenrc_post.bat" call "%HOME%\mavenrc_post.bat"
|
|
||||||
if exist "%HOME%\mavenrc_post.cmd" call "%HOME%\mavenrc_post.cmd"
|
|
||||||
:skipRcPost
|
|
||||||
|
|
||||||
@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on'
|
|
||||||
if "%MAVEN_BATCH_PAUSE%" == "on" pause
|
|
||||||
|
|
||||||
if "%MAVEN_TERMINATE_CMD%" == "on" exit %ERROR_CODE%
|
|
||||||
|
|
||||||
exit /B %ERROR_CODE%
|
|
|
@ -1,208 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<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>
|
|
||||||
<artifactId>cas-server</artifactId>
|
|
||||||
<version>1.0</version>
|
|
||||||
<name>cas-server</name>
|
|
||||||
<packaging>war</packaging>
|
|
||||||
|
|
||||||
<parent>
|
|
||||||
<groupId>com.baeldung</groupId>
|
|
||||||
<artifactId>parent-boot-1</artifactId>
|
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
|
||||||
<relativePath>../../parent-boot-1</relativePath>
|
|
||||||
</parent>
|
|
||||||
|
|
||||||
<dependencies>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.apereo.cas</groupId>
|
|
||||||
<artifactId>cas-server-support-json-service-registry</artifactId>
|
|
||||||
<version>${cas.version}</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.apereo.cas</groupId>
|
|
||||||
<artifactId>cas-server-support-jdbc</artifactId>
|
|
||||||
<version>${cas.version}</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.apereo.cas</groupId>
|
|
||||||
<artifactId>cas-server-support-jdbc-drivers</artifactId>
|
|
||||||
<version>${cas.version}</version>
|
|
||||||
</dependency>
|
|
||||||
</dependencies>
|
|
||||||
|
|
||||||
<build>
|
|
||||||
<plugins>
|
|
||||||
<plugin>
|
|
||||||
<groupId>com.rimerosolutions.maven.plugins</groupId>
|
|
||||||
<artifactId>wrapper-maven-plugin</artifactId>
|
|
||||||
<version>${wrapper-maven-plugin.version}</version>
|
|
||||||
<configuration>
|
|
||||||
<verifyDownload>true</verifyDownload>
|
|
||||||
<checksumAlgorithm>MD5</checksumAlgorithm>
|
|
||||||
</configuration>
|
|
||||||
</plugin>
|
|
||||||
<plugin>
|
|
||||||
<groupId>org.springframework.boot</groupId>
|
|
||||||
<artifactId>spring-boot-maven-plugin</artifactId>
|
|
||||||
<configuration>
|
|
||||||
<mainClass>${mainClassName}</mainClass>
|
|
||||||
<addResources>true</addResources>
|
|
||||||
<executable>${isExecutable}</executable>
|
|
||||||
<layout>WAR</layout>
|
|
||||||
</configuration>
|
|
||||||
<executions>
|
|
||||||
<execution>
|
|
||||||
<goals>
|
|
||||||
<goal>repackage</goal>
|
|
||||||
</goals>
|
|
||||||
</execution>
|
|
||||||
</executions>
|
|
||||||
</plugin>
|
|
||||||
<plugin>
|
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
|
||||||
<artifactId>maven-war-plugin</artifactId>
|
|
||||||
<version>${maven-war-plugin.version}</version>
|
|
||||||
<configuration>
|
|
||||||
<warName>cas</warName>
|
|
||||||
<failOnMissingWebXml>false</failOnMissingWebXml>
|
|
||||||
<recompressZippedFiles>false</recompressZippedFiles>
|
|
||||||
<archive>
|
|
||||||
<compress>false</compress>
|
|
||||||
<manifestFile>${manifestFileToUse}</manifestFile>
|
|
||||||
</archive>
|
|
||||||
<overlays>
|
|
||||||
<overlay>
|
|
||||||
<groupId>org.apereo.cas</groupId>
|
|
||||||
<artifactId>cas-server-webapp${app.server}</artifactId>
|
|
||||||
</overlay>
|
|
||||||
</overlays>
|
|
||||||
</configuration>
|
|
||||||
</plugin>
|
|
||||||
</plugins>
|
|
||||||
<finalName>cas</finalName>
|
|
||||||
</build>
|
|
||||||
|
|
||||||
<profiles>
|
|
||||||
<profile>
|
|
||||||
<activation>
|
|
||||||
<activeByDefault>true</activeByDefault>
|
|
||||||
</activation>
|
|
||||||
<id>default</id>
|
|
||||||
<dependencies>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.apereo.cas</groupId>
|
|
||||||
<artifactId>cas-server-webapp${app.server}</artifactId>
|
|
||||||
<version>${cas.version}</version>
|
|
||||||
<type>war</type>
|
|
||||||
<scope>runtime</scope>
|
|
||||||
</dependency>
|
|
||||||
<!-- ...Additional dependencies may be placed here... -->
|
|
||||||
</dependencies>
|
|
||||||
</profile>
|
|
||||||
|
|
||||||
<profile>
|
|
||||||
<activation>
|
|
||||||
<activeByDefault>false</activeByDefault>
|
|
||||||
</activation>
|
|
||||||
<id>exec</id>
|
|
||||||
<properties>
|
|
||||||
<mainClassName>org.apereo.cas.web.CasWebApplication</mainClassName>
|
|
||||||
<isExecutable>true</isExecutable>
|
|
||||||
<manifestFileToUse></manifestFileToUse>
|
|
||||||
</properties>
|
|
||||||
<build>
|
|
||||||
<plugins>
|
|
||||||
<plugin>
|
|
||||||
<groupId>com.soebes.maven.plugins</groupId>
|
|
||||||
<artifactId>echo-maven-plugin</artifactId>
|
|
||||||
<version>${echo-maven-plugin.version}</version>
|
|
||||||
<executions>
|
|
||||||
<execution>
|
|
||||||
<phase>prepare-package</phase>
|
|
||||||
<goals>
|
|
||||||
<goal>echo</goal>
|
|
||||||
</goals>
|
|
||||||
</execution>
|
|
||||||
</executions>
|
|
||||||
<configuration>
|
|
||||||
<echos>
|
|
||||||
<echo>Executable profile to make the generated CAS web application executable.</echo>
|
|
||||||
</echos>
|
|
||||||
</configuration>
|
|
||||||
</plugin>
|
|
||||||
</plugins>
|
|
||||||
</build>
|
|
||||||
</profile>
|
|
||||||
|
|
||||||
<profile>
|
|
||||||
<activation>
|
|
||||||
<activeByDefault>false</activeByDefault>
|
|
||||||
</activation>
|
|
||||||
<id>bootiful</id>
|
|
||||||
<properties>
|
|
||||||
<app.server>-tomcat</app.server>
|
|
||||||
<isExecutable>false</isExecutable>
|
|
||||||
</properties>
|
|
||||||
<dependencies>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.apereo.cas</groupId>
|
|
||||||
<artifactId>cas-server-webapp${app.server}</artifactId>
|
|
||||||
<version>${cas.version}</version>
|
|
||||||
<type>war</type>
|
|
||||||
<scope>runtime</scope>
|
|
||||||
</dependency>
|
|
||||||
</dependencies>
|
|
||||||
</profile>
|
|
||||||
|
|
||||||
<profile>
|
|
||||||
<activation>
|
|
||||||
<activeByDefault>false</activeByDefault>
|
|
||||||
</activation>
|
|
||||||
<id>pgp</id>
|
|
||||||
<build>
|
|
||||||
<plugins>
|
|
||||||
<plugin>
|
|
||||||
<groupId>com.github.s4u.plugins</groupId>
|
|
||||||
<artifactId>pgpverify-maven-plugin</artifactId>
|
|
||||||
<version>${pgpverify-maven-plugin.version}</version>
|
|
||||||
<executions>
|
|
||||||
<execution>
|
|
||||||
<goals>
|
|
||||||
<goal>check</goal>
|
|
||||||
</goals>
|
|
||||||
</execution>
|
|
||||||
</executions>
|
|
||||||
<configuration>
|
|
||||||
<pgpKeyServer>hkp://pool.sks-keyservers.net</pgpKeyServer>
|
|
||||||
<pgpKeysCachePath>${settings.localRepository}/pgpkeys-cache</pgpKeysCachePath>
|
|
||||||
<scope>test</scope>
|
|
||||||
<verifyPomFiles>true</verifyPomFiles>
|
|
||||||
<failNoSignature>false</failNoSignature>
|
|
||||||
</configuration>
|
|
||||||
</plugin>
|
|
||||||
</plugins>
|
|
||||||
</build>
|
|
||||||
</profile>
|
|
||||||
</profiles>
|
|
||||||
|
|
||||||
<properties>
|
|
||||||
<cas.version>5.3.3</cas.version>
|
|
||||||
<!-- app.server could be -jetty, -undertow, -tomcat, or blank if you plan to provide appserver -->
|
|
||||||
<app.server>-tomcat</app.server>
|
|
||||||
|
|
||||||
<mainClassName>org.springframework.boot.loader.WarLauncher</mainClassName>
|
|
||||||
<isExecutable>false</isExecutable>
|
|
||||||
<manifestFileToUse>${project.build.directory}/war/work/org.apereo.cas/cas-server-webapp${app.server}/META-INF/MANIFEST.MF</manifestFileToUse>
|
|
||||||
|
|
||||||
<wrapper-maven-plugin.version>0.0.4</wrapper-maven-plugin.version>
|
|
||||||
<maven-war-plugin.version>2.6</maven-war-plugin.version>
|
|
||||||
|
|
||||||
<echo-maven-plugin.version>0.3.0</echo-maven-plugin.version>
|
|
||||||
<pgpverify-maven-plugin.version>1.1.0</pgpverify-maven-plugin.version>
|
|
||||||
</properties>
|
|
||||||
|
|
||||||
</project>
|
|
|
@ -0,0 +1 @@
|
||||||
|
rootProject.name='cas'
|
|
@ -0,0 +1,22 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
#echo -e "\nChecking java..."
|
||||||
|
#java -version
|
||||||
|
|
||||||
|
#echo -e "\nCreating CAS configuration directories..."
|
||||||
|
mkdir -p /etc/cas/config
|
||||||
|
mkdir -p /etc/cas/services
|
||||||
|
|
||||||
|
#echo "Listing provided CAS docker artifacts..."
|
||||||
|
#ls -R docker/cas
|
||||||
|
|
||||||
|
#echo -e "\nMoving CAS configuration artifacts..."
|
||||||
|
mv docker/cas/thekeystore /etc/cas 2>/dev/null
|
||||||
|
mv docker/cas/config/*.* /etc/cas/config 2>/dev/null
|
||||||
|
mv docker/cas/services/*.* /etc/cas/services 2>/dev/null
|
||||||
|
|
||||||
|
#echo -e "\nListing CAS configuration under /etc/cas..."
|
||||||
|
#ls -R /etc/cas
|
||||||
|
|
||||||
|
echo -e "\nRunning CAS..."
|
||||||
|
exec java -Xms512m -Xmx2048M -XX:+TieredCompilation -XX:TieredStopAtLevel=1 -jar docker/cas/war/cas.war
|
|
@ -1,134 +1,4 @@
|
||||||
##
|
server.port=8443
|
||||||
# CAS Server Context Configuration
|
spring.main.allow-bean-definition-overriding=true
|
||||||
#
|
|
||||||
server.context-path=/cas
|
|
||||||
server.port=6443
|
|
||||||
|
|
||||||
server.ssl.key-store=classpath:/etc/cas/thekeystore
|
server.ssl.key-store=classpath:/etc/cas/thekeystore
|
||||||
server.ssl.key-store-password=changeit
|
server.ssl.key-store-password=changeit
|
||||||
server.ssl.key-password=changeit
|
|
||||||
# server.ssl.ciphers=
|
|
||||||
# server.ssl.client-auth=
|
|
||||||
# server.ssl.enabled=
|
|
||||||
# server.ssl.key-alias=
|
|
||||||
# server.ssl.key-store-provider=
|
|
||||||
# server.ssl.key-store-type=
|
|
||||||
# server.ssl.protocol=
|
|
||||||
# server.ssl.trust-store=
|
|
||||||
# server.ssl.trust-store-password=
|
|
||||||
# server.ssl.trust-store-provider=
|
|
||||||
# server.ssl.trust-store-type=
|
|
||||||
|
|
||||||
server.max-http-header-size=2097152
|
|
||||||
server.use-forward-headers=true
|
|
||||||
server.connection-timeout=20000
|
|
||||||
server.error.include-stacktrace=NEVER
|
|
||||||
|
|
||||||
server.tomcat.max-http-post-size=2097152
|
|
||||||
server.tomcat.basedir=build/tomcat
|
|
||||||
server.tomcat.accesslog.enabled=true
|
|
||||||
server.tomcat.accesslog.pattern=%t %a "%r" %s (%D ms)
|
|
||||||
server.tomcat.accesslog.suffix=.log
|
|
||||||
server.tomcat.max-threads=10
|
|
||||||
server.tomcat.port-header=X-Forwarded-Port
|
|
||||||
server.tomcat.protocol-header=X-Forwarded-Proto
|
|
||||||
server.tomcat.protocol-header-https-value=https
|
|
||||||
server.tomcat.remote-ip-header=X-FORWARDED-FOR
|
|
||||||
server.tomcat.uri-encoding=UTF-8
|
|
||||||
|
|
||||||
spring.http.encoding.charset=UTF-8
|
|
||||||
spring.http.encoding.enabled=true
|
|
||||||
spring.http.encoding.force=true
|
|
||||||
|
|
||||||
##
|
|
||||||
#CAS CONFIG LOCATION
|
|
||||||
#
|
|
||||||
standalone.config=classpath:/etc/cas/config
|
|
||||||
|
|
||||||
|
|
||||||
##
|
|
||||||
# CAS Cloud Bus Configuration
|
|
||||||
#
|
|
||||||
spring.cloud.bus.enabled=false
|
|
||||||
# spring.cloud.bus.refresh.enabled=true
|
|
||||||
# spring.cloud.bus.env.enabled=true
|
|
||||||
# spring.cloud.bus.destination=CasCloudBus
|
|
||||||
# spring.cloud.bus.ack.enabled=true
|
|
||||||
|
|
||||||
endpoints.enabled=false
|
|
||||||
endpoints.sensitive=true
|
|
||||||
|
|
||||||
endpoints.restart.enabled=false
|
|
||||||
endpoints.shutdown.enabled=false
|
|
||||||
|
|
||||||
management.security.enabled=true
|
|
||||||
management.security.roles=ACTUATOR,ADMIN
|
|
||||||
management.security.sessions=if_required
|
|
||||||
management.context-path=/status
|
|
||||||
management.add-application-context-header=false
|
|
||||||
|
|
||||||
security.basic.authorize-mode=role
|
|
||||||
security.basic.enabled=false
|
|
||||||
security.basic.path=/cas/status/**
|
|
||||||
|
|
||||||
##
|
|
||||||
# CAS Web Application Session Configuration
|
|
||||||
#
|
|
||||||
server.session.timeout=300
|
|
||||||
server.session.cookie.http-only=true
|
|
||||||
server.session.tracking-modes=COOKIE
|
|
||||||
|
|
||||||
##
|
|
||||||
# CAS Thymeleaf View Configuration
|
|
||||||
#
|
|
||||||
spring.thymeleaf.encoding=UTF-8
|
|
||||||
spring.thymeleaf.cache=true
|
|
||||||
spring.thymeleaf.mode=HTML
|
|
||||||
##
|
|
||||||
# CAS Log4j Configuration
|
|
||||||
#
|
|
||||||
# logging.config=file:/etc/cas/log4j2.xml
|
|
||||||
|
|
||||||
server.context-parameters.isLog4jAutoInitializationDisabled=true
|
|
||||||
|
|
||||||
##
|
|
||||||
# CAS AspectJ Configuration
|
|
||||||
#
|
|
||||||
spring.aop.auto=true
|
|
||||||
spring.aop.proxy-target-class=true
|
|
||||||
|
|
||||||
##
|
|
||||||
# CAS Authentication Credentials
|
|
||||||
#
|
|
||||||
#cas.authn.accept.users=casuser::Mellon
|
|
||||||
cas.authn.accept.users=
|
|
||||||
cas.authn.accept.name=
|
|
||||||
|
|
||||||
#CAS Database Authentication Property
|
|
||||||
cas.authn.jdbc.query[0].sql=SELECT * FROM users WHERE email = ?
|
|
||||||
cas.authn.jdbc.query[0].url=jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC
|
|
||||||
cas.authn.jdbc.query[0].dialect=org.hibernate.dialect.MySQLDialect
|
|
||||||
cas.authn.jdbc.query[0].user=root
|
|
||||||
cas.authn.jdbc.query[0].password=1234
|
|
||||||
cas.authn.jdbc.query[0].ddlAuto=none
|
|
||||||
#cas.authn.jdbc.query[0].driverClass=com.mysql.jdbc.Driver
|
|
||||||
cas.authn.jdbc.query[0].driverClass=com.mysql.cj.jdbc.Driver
|
|
||||||
cas.authn.jdbc.query[0].fieldPassword=password
|
|
||||||
cas.authn.jdbc.query[0].passwordEncoder.type=NONE
|
|
||||||
|
|
||||||
|
|
||||||
##
|
|
||||||
# CAS Delegated Authentication
|
|
||||||
#
|
|
||||||
cas.authn.pac4j.bitbucket.clientName=Bitbucket
|
|
||||||
cas.authn.pac4j.dropbox.clientName=Dropbox
|
|
||||||
cas.authn.pac4j.facebook.clientName=Facebook
|
|
||||||
cas.authn.pac4j.foursquare.clientName=Foursquare
|
|
||||||
cas.authn.pac4j.github.clientName=Github
|
|
||||||
cas.authn.pac4j.google.clientName=Google
|
|
||||||
cas.authn.pac4j.linkedIn.clientName=LinkedIn
|
|
||||||
cas.authn.pac4j.paypal.clientName=PayPal
|
|
||||||
cas.authn.pac4j.twitter.clientName=Twitter
|
|
||||||
cas.authn.pac4j.yahoo.clientName=Yahoo
|
|
||||||
cas.authn.pac4j.windowsLive.clientName=Windows Live
|
|
||||||
cas.authn.pac4j.wordpress.clientName=WordPress
|
|
|
@ -1,9 +0,0 @@
|
||||||
cas.server.name: https://localhost:6443
|
|
||||||
cas.server.prefix: https://localhost:643/cas
|
|
||||||
|
|
||||||
cas.adminPagesSecurity.ip=127\.0\.0\.1
|
|
||||||
|
|
||||||
logging.config: file:/etc/cas/config/log4j2.xml
|
|
||||||
|
|
||||||
cas.serviceRegistry.initFromJson=true
|
|
||||||
cas.serviceRegistry.config.location=classpath:/services
|
|
|
@ -4,13 +4,13 @@ USE `test`;
|
||||||
|
|
||||||
-- Dumping structure for table test.users
|
-- Dumping structure for table test.users
|
||||||
CREATE TABLE IF NOT EXISTS `users` (
|
CREATE TABLE IF NOT EXISTS `users` (
|
||||||
`id` int(11) NOT NULL AUTO_INCREMENT,
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||||
`email` varchar(50) DEFAULT NULL,
|
`email` varchar(50) DEFAULT NULL,
|
||||||
`password` text DEFAULT NULL,
|
`password` text DEFAULT NULL,
|
||||||
PRIMARY KEY (`id`)
|
PRIMARY KEY (`id`)
|
||||||
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=latin1;
|
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=latin1;
|
||||||
|
|
||||||
/*!40000 ALTER TABLE `users` DISABLE KEYS */;
|
/*!40000 ALTER TABLE `users` DISABLE KEYS */;
|
||||||
INSERT INTO `users` (`id`, `email`, `password`) VALUES
|
INSERT INTO `users` (`id`, `email`, `password`) VALUES
|
||||||
(1, 'test@test.com', 'Mellon');
|
(1, 'test@test.com', 'Mellon');
|
||||||
/*!40000 ALTER TABLE `users` ENABLE KEYS */;
|
/*!40000 ALTER TABLE `users` ENABLE KEYS */;
|
|
@ -1,2 +0,0 @@
|
||||||
info:
|
|
||||||
description: CAS Configuration
|
|
|
@ -1,7 +1,15 @@
|
||||||
cas.server.name: https://cas.example.org:8443
|
cas.serviceRegistry.initFromJson=true
|
||||||
cas.server.prefix: https://cas.example.org:8443/cas
|
cas.serviceRegistry.json.location=classpath:/etc/cas/services
|
||||||
|
|
||||||
cas.adminPagesSecurity.ip=127\.0\.0\.1
|
|
||||||
|
|
||||||
logging.config: file:/etc/cas/config/log4j2.xml
|
cas.authn.accept.users=
|
||||||
# cas.serviceRegistry.config.location: classpath:/services
|
|
||||||
|
cas.authn.jdbc.query[0].sql=SELECT * FROM users WHERE email = ?
|
||||||
|
cas.authn.jdbc.query[0].url=jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC
|
||||||
|
cas.authn.jdbc.query[0].dialect=org.hibernate.dialect.MySQLDialect
|
||||||
|
cas.authn.jdbc.query[0].user=root
|
||||||
|
cas.authn.jdbc.query[0].password=smattroot
|
||||||
|
cas.authn.jdbc.query[0].ddlAuto=none
|
||||||
|
cas.authn.jdbc.query[0].driverClass=com.mysql.cj.jdbc.Driver
|
||||||
|
cas.authn.jdbc.query[0].fieldPassword=password
|
||||||
|
cas.authn.jdbc.query[0].passwordEncoder.type=NONE
|
|
@ -1,117 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
|
||||||
<!-- Specify the refresh internal in seconds. -->
|
|
||||||
<Configuration monitorInterval="5" packages="org.apereo.cas.logging">
|
|
||||||
<Properties>
|
|
||||||
<!--
|
|
||||||
Default log directory is the current directory but that can be overridden with -Dcas.log.dir=<logdir>
|
|
||||||
Or you can change this property to a new default
|
|
||||||
-->
|
|
||||||
<Property name="cas.log.dir" >.</Property>
|
|
||||||
<!-- To see more CAS specific logging, adjust this property to info or debug or run server with -Dcas.log.leve=debug -->
|
|
||||||
<Property name="cas.log.level" >warn</Property>
|
|
||||||
</Properties>
|
|
||||||
<Appenders>
|
|
||||||
<Console name="console" target="SYSTEM_OUT">
|
|
||||||
<PatternLayout pattern="%d %p [%c] - <%m>%n"/>
|
|
||||||
</Console>
|
|
||||||
<RollingFile name="file" fileName="${sys:cas.log.dir}/cas.log" append="true"
|
|
||||||
filePattern="${sys:cas.log.dir}/cas-%d{yyyy-MM-dd-HH}-%i.log">
|
|
||||||
<PatternLayout pattern="%d %p [%c] - <%m>%n"/>
|
|
||||||
<Policies>
|
|
||||||
<OnStartupTriggeringPolicy />
|
|
||||||
<SizeBasedTriggeringPolicy size="10 MB"/>
|
|
||||||
<TimeBasedTriggeringPolicy />
|
|
||||||
</Policies>
|
|
||||||
</RollingFile>
|
|
||||||
<RollingFile name="auditlogfile" fileName="${sys:cas.log.dir}/cas_audit.log" append="true"
|
|
||||||
filePattern="${sys:cas.log.dir}/cas_audit-%d{yyyy-MM-dd-HH}-%i.log">
|
|
||||||
<PatternLayout pattern="%d %p [%c] - %m%n"/>
|
|
||||||
<Policies>
|
|
||||||
<OnStartupTriggeringPolicy />
|
|
||||||
<SizeBasedTriggeringPolicy size="10 MB"/>
|
|
||||||
<TimeBasedTriggeringPolicy />
|
|
||||||
</Policies>
|
|
||||||
</RollingFile>
|
|
||||||
|
|
||||||
<RollingFile name="perfFileAppender" fileName="${sys:cas.log.dir}/perfStats.log" append="true"
|
|
||||||
filePattern="${sys:cas.log.dir}/perfStats-%d{yyyy-MM-dd-HH}-%i.log">
|
|
||||||
<PatternLayout pattern="%m%n"/>
|
|
||||||
<Policies>
|
|
||||||
<OnStartupTriggeringPolicy />
|
|
||||||
<SizeBasedTriggeringPolicy size="10 MB"/>
|
|
||||||
<TimeBasedTriggeringPolicy />
|
|
||||||
</Policies>
|
|
||||||
</RollingFile>
|
|
||||||
|
|
||||||
<CasAppender name="casAudit">
|
|
||||||
<AppenderRef ref="auditlogfile" />
|
|
||||||
</CasAppender>
|
|
||||||
<CasAppender name="casFile">
|
|
||||||
<AppenderRef ref="file" />
|
|
||||||
</CasAppender>
|
|
||||||
<CasAppender name="casConsole">
|
|
||||||
<AppenderRef ref="console" />
|
|
||||||
</CasAppender>
|
|
||||||
<CasAppender name="casPerf">
|
|
||||||
<AppenderRef ref="perfFileAppender" />
|
|
||||||
</CasAppender>
|
|
||||||
</Appenders>
|
|
||||||
<Loggers>
|
|
||||||
<!-- If adding a Logger with level set higher than warn, make category as selective as possible -->
|
|
||||||
<!-- Loggers inherit appenders from Root Logger unless additivity is false -->
|
|
||||||
<AsyncLogger name="org.apereo" level="${sys:cas.log.level}" includeLocation="true"/>
|
|
||||||
<AsyncLogger name="org.apereo.services.persondir" level="${sys:cas.log.level}" includeLocation="true"/>
|
|
||||||
<AsyncLogger name="org.apereo.cas.web.flow" level="info" includeLocation="true"/>
|
|
||||||
<AsyncLogger name="org.apache" level="warn" />
|
|
||||||
<AsyncLogger name="org.apache.http" level="error" />
|
|
||||||
<AsyncLogger name="org.springframework" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.cloud.server" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.cloud.client" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.cloud.bus" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.aop" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.boot" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.boot.actuate.autoconfigure" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.webflow" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.session" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.amqp" level="error" />
|
|
||||||
<AsyncLogger name="org.springframework.integration" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.messaging" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.web" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.orm.jpa" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.scheduling" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.context.annotation" level="error" />
|
|
||||||
<AsyncLogger name="org.springframework.boot.devtools" level="error" />
|
|
||||||
<AsyncLogger name="org.springframework.web.socket" level="warn" />
|
|
||||||
<AsyncLogger name="org.thymeleaf" level="warn" />
|
|
||||||
<AsyncLogger name="org.pac4j" level="warn" />
|
|
||||||
<AsyncLogger name="org.opensaml" level="warn"/>
|
|
||||||
<AsyncLogger name="net.sf.ehcache" level="warn" />
|
|
||||||
<AsyncLogger name="com.couchbase" level="warn" includeLocation="true"/>
|
|
||||||
<AsyncLogger name="com.ryantenney.metrics" level="warn" />
|
|
||||||
<AsyncLogger name="net.jradius" level="warn" />
|
|
||||||
<AsyncLogger name="org.openid4java" level="warn" />
|
|
||||||
<AsyncLogger name="org.ldaptive" level="warn" />
|
|
||||||
<AsyncLogger name="com.hazelcast" level="warn" />
|
|
||||||
<AsyncLogger name="org.apereo.spring" level="warn" />
|
|
||||||
|
|
||||||
<!-- Log perf stats only to perfStats.log -->
|
|
||||||
<AsyncLogger name="perfStatsLogger" level="info" additivity="false" includeLocation="true">
|
|
||||||
<AppenderRef ref="casPerf"/>
|
|
||||||
</AsyncLogger>
|
|
||||||
|
|
||||||
<!-- Log audit to all root appenders, and also to audit log (additivity is not false) -->
|
|
||||||
<AsyncLogger name="org.apereo.inspektr.audit.support" level="info" includeLocation="true" >
|
|
||||||
<AppenderRef ref="casAudit"/>
|
|
||||||
</AsyncLogger>
|
|
||||||
|
|
||||||
<!-- All Loggers inherit appenders specified here, unless additivity="false" on the Logger -->
|
|
||||||
<AsyncRoot level="warn">
|
|
||||||
<AppenderRef ref="casFile"/>
|
|
||||||
<!--
|
|
||||||
For deployment to an application server running as service,
|
|
||||||
delete the casConsole appender below
|
|
||||||
-->
|
|
||||||
<AppenderRef ref="casConsole"/>
|
|
||||||
</AsyncRoot>
|
|
||||||
</Loggers>
|
|
||||||
</Configuration>
|
|
|
@ -0,0 +1,8 @@
|
||||||
|
{
|
||||||
|
"@class" : "org.apereo.cas.services.RegexRegisteredService",
|
||||||
|
"serviceId" : "http://cas-client:8900/login/cas",
|
||||||
|
"name" : "casSecuredApp",
|
||||||
|
"id" : 8900,
|
||||||
|
"logoutType" : "BACK_CHANNEL",
|
||||||
|
"logoutUrl" : "http://cas-client:8900/exit/cas"
|
||||||
|
}
|
Binary file not shown.
Binary file not shown.
|
@ -1,117 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
|
||||||
<!-- Specify the refresh internal in seconds. -->
|
|
||||||
<Configuration monitorInterval="5" packages="org.apereo.cas.logging">
|
|
||||||
<Properties>
|
|
||||||
<!--
|
|
||||||
Default log directory is the current directory but that can be overridden with -Dcas.log.dir=<logdir>
|
|
||||||
Or you can change this property to a new default
|
|
||||||
-->
|
|
||||||
<Property name="cas.log.dir" >.</Property>
|
|
||||||
<!-- To see more CAS specific logging, adjust this property to info or debug or run server with -Dcas.log.leve=debug -->
|
|
||||||
<Property name="cas.log.level" >warn</Property>
|
|
||||||
</Properties>
|
|
||||||
<Appenders>
|
|
||||||
<Console name="console" target="SYSTEM_OUT">
|
|
||||||
<PatternLayout pattern="%d %p [%c] - <%m>%n"/>
|
|
||||||
</Console>
|
|
||||||
<RollingFile name="file" fileName="${sys:cas.log.dir}/cas.log" append="true"
|
|
||||||
filePattern="${sys:cas.log.dir}/cas-%d{yyyy-MM-dd-HH}-%i.log">
|
|
||||||
<PatternLayout pattern="%d %p [%c] - <%m>%n"/>
|
|
||||||
<Policies>
|
|
||||||
<OnStartupTriggeringPolicy />
|
|
||||||
<SizeBasedTriggeringPolicy size="10 MB"/>
|
|
||||||
<TimeBasedTriggeringPolicy />
|
|
||||||
</Policies>
|
|
||||||
</RollingFile>
|
|
||||||
<RollingFile name="auditlogfile" fileName="${sys:cas.log.dir}/cas_audit.log" append="true"
|
|
||||||
filePattern="${sys:cas.log.dir}/cas_audit-%d{yyyy-MM-dd-HH}-%i.log">
|
|
||||||
<PatternLayout pattern="%d %p [%c] - %m%n"/>
|
|
||||||
<Policies>
|
|
||||||
<OnStartupTriggeringPolicy />
|
|
||||||
<SizeBasedTriggeringPolicy size="10 MB"/>
|
|
||||||
<TimeBasedTriggeringPolicy />
|
|
||||||
</Policies>
|
|
||||||
</RollingFile>
|
|
||||||
|
|
||||||
<RollingFile name="perfFileAppender" fileName="${sys:cas.log.dir}/perfStats.log" append="true"
|
|
||||||
filePattern="${sys:cas.log.dir}/perfStats-%d{yyyy-MM-dd-HH}-%i.log">
|
|
||||||
<PatternLayout pattern="%m%n"/>
|
|
||||||
<Policies>
|
|
||||||
<OnStartupTriggeringPolicy />
|
|
||||||
<SizeBasedTriggeringPolicy size="10 MB"/>
|
|
||||||
<TimeBasedTriggeringPolicy />
|
|
||||||
</Policies>
|
|
||||||
</RollingFile>
|
|
||||||
|
|
||||||
<CasAppender name="casAudit">
|
|
||||||
<AppenderRef ref="auditlogfile" />
|
|
||||||
</CasAppender>
|
|
||||||
<CasAppender name="casFile">
|
|
||||||
<AppenderRef ref="file" />
|
|
||||||
</CasAppender>
|
|
||||||
<CasAppender name="casConsole">
|
|
||||||
<AppenderRef ref="console" />
|
|
||||||
</CasAppender>
|
|
||||||
<CasAppender name="casPerf">
|
|
||||||
<AppenderRef ref="perfFileAppender" />
|
|
||||||
</CasAppender>
|
|
||||||
</Appenders>
|
|
||||||
<Loggers>
|
|
||||||
<!-- If adding a Logger with level set higher than warn, make category as selective as possible -->
|
|
||||||
<!-- Loggers inherit appenders from Root Logger unless additivity is false -->
|
|
||||||
<AsyncLogger name="org.apereo" level="${sys:cas.log.level}" includeLocation="true"/>
|
|
||||||
<AsyncLogger name="org.apereo.services.persondir" level="${sys:cas.log.level}" includeLocation="true"/>
|
|
||||||
<AsyncLogger name="org.apereo.cas.web.flow" level="info" includeLocation="true"/>
|
|
||||||
<AsyncLogger name="org.apache" level="warn" />
|
|
||||||
<AsyncLogger name="org.apache.http" level="error" />
|
|
||||||
<AsyncLogger name="org.springframework" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.cloud.server" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.cloud.client" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.cloud.bus" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.aop" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.boot" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.boot.actuate.autoconfigure" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.webflow" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.session" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.amqp" level="error" />
|
|
||||||
<AsyncLogger name="org.springframework.integration" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.messaging" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.web" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.orm.jpa" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.scheduling" level="warn" />
|
|
||||||
<AsyncLogger name="org.springframework.context.annotation" level="error" />
|
|
||||||
<AsyncLogger name="org.springframework.boot.devtools" level="error" />
|
|
||||||
<AsyncLogger name="org.springframework.web.socket" level="warn" />
|
|
||||||
<AsyncLogger name="org.thymeleaf" level="warn" />
|
|
||||||
<AsyncLogger name="org.pac4j" level="warn" />
|
|
||||||
<AsyncLogger name="org.opensaml" level="warn"/>
|
|
||||||
<AsyncLogger name="net.sf.ehcache" level="warn" />
|
|
||||||
<AsyncLogger name="com.couchbase" level="warn" includeLocation="true"/>
|
|
||||||
<AsyncLogger name="com.ryantenney.metrics" level="warn" />
|
|
||||||
<AsyncLogger name="net.jradius" level="warn" />
|
|
||||||
<AsyncLogger name="org.openid4java" level="warn" />
|
|
||||||
<AsyncLogger name="org.ldaptive" level="warn" />
|
|
||||||
<AsyncLogger name="com.hazelcast" level="warn" />
|
|
||||||
<AsyncLogger name="org.apereo.spring" level="warn" />
|
|
||||||
|
|
||||||
<!-- Log perf stats only to perfStats.log -->
|
|
||||||
<AsyncLogger name="perfStatsLogger" level="info" additivity="false" includeLocation="true">
|
|
||||||
<AppenderRef ref="casPerf"/>
|
|
||||||
</AsyncLogger>
|
|
||||||
|
|
||||||
<!-- Log audit to all root appenders, and also to audit log (additivity is not false) -->
|
|
||||||
<AsyncLogger name="org.apereo.inspektr.audit.support" level="info" includeLocation="true" >
|
|
||||||
<AppenderRef ref="casAudit"/>
|
|
||||||
</AsyncLogger>
|
|
||||||
|
|
||||||
<!-- All Loggers inherit appenders specified here, unless additivity="false" on the Logger -->
|
|
||||||
<AsyncRoot level="warn">
|
|
||||||
<AppenderRef ref="casFile"/>
|
|
||||||
<!--
|
|
||||||
For deployment to an application server running as service,
|
|
||||||
delete the casConsole appender below
|
|
||||||
-->
|
|
||||||
<AppenderRef ref="casConsole"/>
|
|
||||||
</AsyncRoot>
|
|
||||||
</Loggers>
|
|
||||||
</Configuration>
|
|
|
@ -1,8 +0,0 @@
|
||||||
{
|
|
||||||
"@class" : "org.apereo.cas.services.RegexRegisteredService",
|
|
||||||
"serviceId" : "^http://localhost:9000/login/cas",
|
|
||||||
"name" : "CAS Spring Secured App",
|
|
||||||
"description": "This is a Spring App that usses the CAS Server for it's authentication",
|
|
||||||
"id" : 19991,
|
|
||||||
"evaluationOrder" : 1
|
|
||||||
}
|
|
23
cas/pom.xml
23
cas/pom.xml
|
@ -1,23 +0,0 @@
|
||||||
<?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>
|
|
||||||
<artifactId>cas</artifactId>
|
|
||||||
<name>cas</name>
|
|
||||||
<packaging>pom</packaging>
|
|
||||||
|
|
||||||
<parent>
|
|
||||||
<groupId>com.baeldung</groupId>
|
|
||||||
<artifactId>parent-modules</artifactId>
|
|
||||||
<version>1.0.0-SNAPSHOT</version>
|
|
||||||
<relativePath>..</relativePath>
|
|
||||||
</parent>
|
|
||||||
|
|
||||||
<modules>
|
|
||||||
<module>cas-secured-app</module>
|
|
||||||
<module>cas-server</module>
|
|
||||||
</modules>
|
|
||||||
|
|
||||||
</project>
|
|
|
@ -0,0 +1,110 @@
|
||||||
|
package com.baeldung.stringtoint
|
||||||
|
|
||||||
|
import org.junit.Test
|
||||||
|
|
||||||
|
import java.text.DecimalFormat
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals
|
||||||
|
import static org.junit.Assert.assertNull
|
||||||
|
|
||||||
|
class ConvertStringToInt {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void givenString_whenUsingAsInteger_thenConvertToInteger() {
|
||||||
|
def stringNum = "123"
|
||||||
|
def invalidString = "123a"
|
||||||
|
Integer expectedInteger = 123
|
||||||
|
Integer integerNum = stringNum as Integer
|
||||||
|
def intNum = invalidString?.isInteger() ? invalidString as Integer : null
|
||||||
|
|
||||||
|
assertNull(null, intNum)
|
||||||
|
assertEquals(integerNum, expectedInteger)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void givenString_whenUsingAsInt_thenConvertToInt() {
|
||||||
|
def stringNum = "123"
|
||||||
|
int expectedInt = 123
|
||||||
|
int intNum = stringNum as int
|
||||||
|
|
||||||
|
assertEquals(intNum, expectedInt)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void givenString_whenUsingToInteger_thenConvertToInteger() {
|
||||||
|
def stringNum = "123"
|
||||||
|
int expectedInt = 123
|
||||||
|
int intNum = stringNum.toInteger()
|
||||||
|
|
||||||
|
assertEquals(intNum, expectedInt)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void givenString_whenUsingParseInt_thenConvertToInteger() {
|
||||||
|
def stringNum = "123"
|
||||||
|
int expectedInt = 123
|
||||||
|
int intNum = Integer.parseInt(stringNum)
|
||||||
|
|
||||||
|
assertEquals(intNum, expectedInt)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void givenString_whenUsingValueOf_thenConvertToInteger() {
|
||||||
|
def stringNum = "123"
|
||||||
|
int expectedInt = 123
|
||||||
|
int intNum = Integer.valueOf(stringNum)
|
||||||
|
|
||||||
|
assertEquals(intNum, expectedInt)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void givenString_whenUsingIntValue_thenConvertToInteger() {
|
||||||
|
def stringNum = "123"
|
||||||
|
int expectedInt = 123
|
||||||
|
int intNum = new Integer(stringNum).intValue()
|
||||||
|
|
||||||
|
assertEquals(intNum, expectedInt)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void givenString_whenUsingNewInteger_thenConvertToInteger() {
|
||||||
|
def stringNum = "123"
|
||||||
|
int expectedInt = 123
|
||||||
|
int intNum = new Integer(stringNum)
|
||||||
|
|
||||||
|
assertEquals(intNum, expectedInt)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void givenString_whenUsingDecimalFormat_thenConvertToInteger() {
|
||||||
|
def stringNum = "123"
|
||||||
|
int expectedInt = 123
|
||||||
|
DecimalFormat decimalFormat = new DecimalFormat("#")
|
||||||
|
int intNum = decimalFormat.parse(stringNum).intValue()
|
||||||
|
|
||||||
|
assertEquals(intNum, expectedInt)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(expected = NumberFormatException.class)
|
||||||
|
void givenInvalidString_whenUsingAs_thenThrowNumberFormatException() {
|
||||||
|
def invalidString = "123a"
|
||||||
|
invalidString as Integer
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(expected = NullPointerException.class)
|
||||||
|
void givenNullString_whenUsingToInteger_thenThrowNullPointerException() {
|
||||||
|
def invalidString = null
|
||||||
|
invalidString.toInteger()
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void givenString_whenUsingIsInteger_thenCheckIfCorrectValue() {
|
||||||
|
def invalidString = "123a"
|
||||||
|
def validString = "123"
|
||||||
|
def invalidNum = invalidString?.isInteger() ? invalidString as Integer : false
|
||||||
|
def correctNum = validString?.isInteger() ? validString as Integer : false
|
||||||
|
|
||||||
|
assertEquals(false, invalidNum)
|
||||||
|
assertEquals(123, correctNum)
|
||||||
|
}
|
||||||
|
}
|
|
@ -7,3 +7,4 @@ This module contains articles about Java 14.
|
||||||
- [Guide to the @Serial Annotation in Java 14](https://www.baeldung.com/java-14-serial-annotation)
|
- [Guide to the @Serial Annotation in Java 14](https://www.baeldung.com/java-14-serial-annotation)
|
||||||
- [Java Text Blocks](https://www.baeldung.com/java-text-blocks)
|
- [Java Text Blocks](https://www.baeldung.com/java-text-blocks)
|
||||||
- [Pattern Matching for instanceof in Java 14](https://www.baeldung.com/java-pattern-matching-instanceof)
|
- [Pattern Matching for instanceof in Java 14](https://www.baeldung.com/java-pattern-matching-instanceof)
|
||||||
|
- [Helpful NullPointerExceptions in Java 14](https://www.baeldung.com/java-14-nullpointerexception)
|
||||||
|
|
|
@ -0,0 +1,56 @@
|
||||||
|
package com.baeldung.java14.helpfulnullpointerexceptions;
|
||||||
|
|
||||||
|
public class HelpfulNullPointerException {
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
Employee employee = null;
|
||||||
|
employee.getName();
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getEmployeeEmailAddress(Employee employee) {
|
||||||
|
String emailAddress = employee.getPersonalDetails().getEmailAddress().toLowerCase();
|
||||||
|
return emailAddress;
|
||||||
|
}
|
||||||
|
|
||||||
|
static class Employee {
|
||||||
|
String name;
|
||||||
|
PersonalDetails personalDetails;
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setName(String name) {
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public PersonalDetails getPersonalDetails() {
|
||||||
|
return personalDetails;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPersonalDetails(PersonalDetails personalDetails) {
|
||||||
|
this.personalDetails = personalDetails;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static class PersonalDetails {
|
||||||
|
String emailAddress;
|
||||||
|
String phone;
|
||||||
|
|
||||||
|
public String getEmailAddress() {
|
||||||
|
return emailAddress;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setEmailAddress(String emailAddress) {
|
||||||
|
this.emailAddress = emailAddress;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getPhone() {
|
||||||
|
return phone;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPhone(String phone) {
|
||||||
|
this.phone = phone;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,37 @@
|
||||||
|
package com.baeldung.java14.helpfulnullpointerexceptions;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import static com.baeldung.java14.helpfulnullpointerexceptions.HelpfulNullPointerException.Employee;
|
||||||
|
import static com.baeldung.java14.helpfulnullpointerexceptions.HelpfulNullPointerException.PersonalDetails;
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
|
public class HelpfulNullPointerExceptionUnitTest {
|
||||||
|
|
||||||
|
@Test (expected = NullPointerException.class)
|
||||||
|
public void givenAnEmptyPersonalDetails_whenEmailAddressIsAccessed_thenThrowNPE() {
|
||||||
|
var helpfulNPE = new HelpfulNullPointerException();
|
||||||
|
|
||||||
|
var employee = new Employee();
|
||||||
|
employee.setName("Eduard");
|
||||||
|
employee.setPersonalDetails(new PersonalDetails());
|
||||||
|
helpfulNPE.getEmployeeEmailAddress(employee);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenCompletePersonalDetails_whenEmailAddressIsAccessed_thenSuccess() {
|
||||||
|
var helpfulNPE = new HelpfulNullPointerException();
|
||||||
|
var emailAddress = "eduard@gmx.com";
|
||||||
|
|
||||||
|
var employee = new Employee();
|
||||||
|
employee.setName("Eduard");
|
||||||
|
|
||||||
|
var personalDetails = new PersonalDetails();
|
||||||
|
personalDetails.setEmailAddress(emailAddress.toUpperCase());
|
||||||
|
personalDetails.setPhone("1234");
|
||||||
|
employee.setPersonalDetails(personalDetails);
|
||||||
|
|
||||||
|
assertThat(helpfulNPE.getEmployeeEmailAddress(employee)).isEqualTo(emailAddress);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -4,7 +4,6 @@ This module contains articles about Java 8 core features
|
||||||
|
|
||||||
### Relevant Articles:
|
### Relevant Articles:
|
||||||
|
|
||||||
- [How to Delay Code Execution in Java](https://www.baeldung.com/java-delay-code-execution)
|
|
||||||
- [Run a Java Application from the Command Line](https://www.baeldung.com/java-run-jar-with-arguments)
|
- [Run a Java Application from the Command Line](https://www.baeldung.com/java-run-jar-with-arguments)
|
||||||
- [Java 8 Stream skip() vs limit()](https://www.baeldung.com/java-stream-skip-vs-limit)
|
- [Java 8 Stream skip() vs limit()](https://www.baeldung.com/java-stream-skip-vs-limit)
|
||||||
- [Guide to Java BiFunction Interface](https://www.baeldung.com/java-bifunction-interface)
|
- [Guide to Java BiFunction Interface](https://www.baeldung.com/java-bifunction-interface)
|
||||||
|
|
|
@ -8,5 +8,4 @@ This module contains articles about Java 9 core features
|
||||||
- [Introduction to Chronicle Queue](https://www.baeldung.com/java-chronicle-queue)
|
- [Introduction to Chronicle Queue](https://www.baeldung.com/java-chronicle-queue)
|
||||||
- [Iterate Through a Range of Dates in Java](https://www.baeldung.com/java-iterate-date-range)
|
- [Iterate Through a Range of Dates in Java](https://www.baeldung.com/java-iterate-date-range)
|
||||||
- [Initialize a HashMap in Java](https://www.baeldung.com/java-initialize-hashmap)
|
- [Initialize a HashMap in Java](https://www.baeldung.com/java-initialize-hashmap)
|
||||||
- [Immutable Set in Java](https://www.baeldung.com/java-immutable-set)
|
|
||||||
- [Immutable ArrayList in Java](https://www.baeldung.com/java-immutable-list)
|
- [Immutable ArrayList in Java](https://www.baeldung.com/java-immutable-list)
|
||||||
|
|
|
@ -12,4 +12,3 @@
|
||||||
- [Sorting in Java](https://www.baeldung.com/java-sorting)
|
- [Sorting in Java](https://www.baeldung.com/java-sorting)
|
||||||
- [Getting the Size of an Iterable in Java](https://www.baeldung.com/java-iterable-size)
|
- [Getting the Size of an Iterable in Java](https://www.baeldung.com/java-iterable-size)
|
||||||
- [Java Null-Safe Streams from Collections](https://www.baeldung.com/java-null-safe-streams-from-collections)
|
- [Java Null-Safe Streams from Collections](https://www.baeldung.com/java-null-safe-streams-from-collections)
|
||||||
- [Operating on and Removing an Item from Stream](https://www.baeldung.com/java-use-remove-item-stream)
|
|
||||||
|
|
|
@ -13,5 +13,4 @@ This module contains articles about Map data structures in Java.
|
||||||
- [Sort a HashMap in Java](https://www.baeldung.com/java-hashmap-sort)
|
- [Sort a HashMap in Java](https://www.baeldung.com/java-hashmap-sort)
|
||||||
- [Finding the Highest Value in a Java Map](https://www.baeldung.com/java-find-map-max)
|
- [Finding the Highest Value in a Java Map](https://www.baeldung.com/java-find-map-max)
|
||||||
- [Initialize a HashMap in Java](https://www.baeldung.com/java-initialize-hashmap)
|
- [Initialize a HashMap in Java](https://www.baeldung.com/java-initialize-hashmap)
|
||||||
- [Java TreeMap vs HashMap](https://www.baeldung.com/java-treemap-vs-hashmap)
|
- More articles: [[<-- prev]](/core-java-modules/core-java-collections-maps) [[next -->]](/core-java-modules/core-java-collections-maps-3)
|
||||||
- More articles: [[<-- prev>]](/../java-collections-maps)
|
|
|
@ -3,16 +3,16 @@
|
||||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
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">
|
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>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>java-collections-maps-2</artifactId>
|
<artifactId>core-java-collections-maps-2</artifactId>
|
||||||
<version>0.1.0-SNAPSHOT</version>
|
<version>0.1.0-SNAPSHOT</version>
|
||||||
<name>java-collections-maps-2</name>
|
<name>core-java-collections-maps-2</name>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
<artifactId>parent-java</artifactId>
|
<artifactId>parent-java</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<relativePath>../parent-java</relativePath>
|
<relativePath>../../parent-java</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<dependencies>
|
<dependencies>
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue