Bladeren bron

SEC-652: Add a trustPassword to AbstractTicketValidator for use with password protected keystores (as in the sample application).

Luke Taylor 18 jaren geleden
bovenliggende
commit
26ea65ddb1

+ 14 - 0
core/src/main/java/org/springframework/security/providers/cas/ticketvalidator/AbstractTicketValidator.java

@@ -44,6 +44,7 @@ public abstract class AbstractTicketValidator implements TicketValidator, Initia
     private ServiceProperties serviceProperties;
     private String casValidate;
     private String trustStore;
+    private String trustPassword;
 
     //~ Methods ========================================================================================================
 
@@ -60,6 +61,10 @@ public abstract class AbstractTicketValidator implements TicketValidator, Initia
 
             System.setProperty("javax.net.ssl.trustStore", trustStore);
         }
+
+        if (StringUtils.hasLength(trustPassword)) {
+            System.setProperty("javax.net.ssl.trustStorePassword", trustPassword);
+        }
     }
 
     /**
@@ -97,4 +102,13 @@ public abstract class AbstractTicketValidator implements TicketValidator, Initia
     public void setTrustStore(String trustStore) {
         this.trustStore = trustStore;
     }
+
+    /**
+     * Optional property which causes the system property <tt>javax.net.ssl.trustStorePassword</tt> to be set.
+     *
+     * @param trustPassword
+     */
+    public void setTrustPassword(String trustPassword) {
+        this.trustPassword = trustPassword;
+    }
 }