blob: e60c56357b504e227fcf65b7a98a713469c00c3f [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 <%= polygene.packageName %>.bootstrap.domain;
import org.apache.polygene.api.common.Visibility;
import org.apache.polygene.bootstrap.AssemblyException;
import org.apache.polygene.bootstrap.LayerAssembly;
import org.apache.polygene.bootstrap.ModuleAssembly;
import org.apache.polygene.bootstrap.layered.ModuleAssembler;
import org.apache.polygene.library.shiro.assembly.PasswordDomainAssembler;
import org.apache.polygene.library.shiro.assembly.PermissionsDomainAssembler;
import org.apache.polygene.library.shiro.assembly.StandaloneShiroAssembler;
import org.apache.polygene.library.shiro.ini.ShiroIniConfiguration;
import <%= polygene.packageName %>.model.security.RealmService;
import <%= polygene.packageName %>.model.security.SecurityRepository;
import <%= polygene.packageName %>.model.security.User;
import <%= polygene.packageName %>.model.security.UserFactory;
public class SecurityModule
implements ModuleAssembler
{
public static String NAME;
@Override
public ModuleAssembly assemble( LayerAssembly layer, ModuleAssembly module )
throws AssemblyException
{
module.services( SecurityRepository.class )
.visibleIn( Visibility.application )
.instantiateOnStartup();
new StandaloneShiroAssembler()
.withConfig( module, Visibility.layer )
.assemble( module );
module.services( RealmService.class );
module.forMixin( ShiroIniConfiguration.class )
.declareDefaults()
.iniResourcePath().set( "classpath:standalone-shiro.ini" );
new PasswordDomainAssembler()
.withConfig( module, Visibility.layer )
.assemble( module );
new PermissionsDomainAssembler().assemble( module );
module.entities( User.class );
module.services( UserFactory.class );
return module;
}
}