blob: f14a5481c05e3d4a707d6993d6bc88e0673238d0 [file] [log] [blame]
/*
* 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.
*/
package org.apache.shiro.cdi.core.producers;
import org.apache.shiro.authc.pam.AuthenticationStrategy;
import org.apache.shiro.authz.permission.PermissionResolver;
import org.apache.shiro.authz.permission.RolePermissionResolver;
import org.apache.shiro.cache.CacheManager;
import org.apache.shiro.cdi.producers.AbstractSecurityManagerProducer;
import org.apache.shiro.event.EventBus;
import org.apache.shiro.mgt.DefaultSecurityManager;
import org.apache.shiro.mgt.DefaultSubjectFactory;
import org.apache.shiro.mgt.RememberMeManager;
import org.apache.shiro.mgt.SecurityManager;
import org.apache.shiro.mgt.SubjectDAO;
import org.apache.shiro.mgt.SubjectFactory;
import org.apache.shiro.realm.Realm;
import org.apache.shiro.session.mgt.DefaultSessionManager;
import org.apache.shiro.session.mgt.SessionFactory;
import org.apache.shiro.session.mgt.SessionManager;
import org.apache.shiro.session.mgt.eis.MemorySessionDAO;
import org.apache.shiro.session.mgt.eis.SessionDAO;
import org.apache.shiro.util.Destroyable;
import javax.enterprise.context.ApplicationScoped;
import javax.enterprise.inject.Instance;
import javax.enterprise.inject.New;
import javax.enterprise.inject.Produces;
import javax.enterprise.inject.Typed;
public class SecurityManagerProducer extends AbstractSecurityManagerProducer {
@Produces
@ApplicationScoped
@Typed({SecurityManager.class, DefaultSecurityManager.class, Destroyable.class})
@Override
protected DefaultSecurityManager securityManager(@New DefaultSecurityManager securityManager,
Instance<Realm> realms,
EventBus eventBus,
SessionManager sessionManager,
Instance<CacheManager> cacheManager,
SubjectDAO subjectDAO,
SubjectFactory subjectFactory,
Instance<RememberMeManager> rememberMeManager,
AuthenticationStrategy authenticationStrategy,
Instance<PermissionResolver> permissionResolver,
Instance<RolePermissionResolver> rolePermissionResolver) {
return configureSecurityManager(securityManager,
realms,
eventBus,
sessionManager,
cacheManager,
subjectDAO,
subjectFactory,
rememberMeManager,
authenticationStrategy,
permissionResolver,
rolePermissionResolver);
}
@Produces
protected DefaultSubjectFactory subjectFactory(@New DefaultSubjectFactory subjectFactory) {
return subjectFactory;
}
@Produces
protected SessionManager sessionManager(@New DefaultSessionManager sessionManager,
SessionDAO sessionDAO,
SessionFactory sessionFactory) {
sessionManager.setSessionDAO(sessionDAO);
sessionManager.setSessionFactory(sessionFactory);
sessionManager.setDeleteInvalidSessions(true); // TODO: add configuration for this.
return sessionManager;
}
@Produces
protected MemorySessionDAO sessionDAO(@New MemorySessionDAO memorySessionDAO) {
return memorySessionDAO;
}
}