/*
* Copyright (c) MuleSoft, Inc. All rights reserved. http://www.mulesoft.com
* The software in this package is published under the terms of the CPAL v1.0
* license, a copy of which has been included with this distribution in the
* LICENSE.txt file.
*/
package org.mule.runtime.module.spring.security;
import org.mule.runtime.api.security.Authentication;
import org.mule.runtime.core.api.security.SecurityContext;
import org.mule.runtime.core.api.security.SecurityContextFactory;
import org.springframework.security.core.context.SecurityContextHolder;
import org.springframework.security.core.context.SecurityContextImpl;
/**
* <code>SpringSecurityContextFactory</code> creates an SpringSecurityContext for an Authentication object.
*/
public class SpringSecurityContextFactory implements SecurityContextFactory {
@Override
public SecurityContext create(Authentication authentication) {
org.springframework.security.core.context.SecurityContext context = new SecurityContextImpl();
context.setAuthentication(((SpringAuthenticationAdapter) authentication).getDelegate());
if (authentication.getProperties() != null) {
if (authentication.getProperties().containsKey("securityMode")) {
String securityMode = (String) authentication.getProperties().get("securityMode");
SecurityContextHolder.setStrategyName(securityMode);
}
}
SecurityContextHolder.setContext(context);
return new SpringSecurityContext(context);
}
}