All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.seedstack.seed.security.rule.SecurityITRule Maven / Gradle / Ivy

The newest version!
/**
 * Copyright (c) 2013-2015 by The SeedStack authors. All rights reserved.
 *
 * This file is part of SeedStack, An enterprise-oriented full development stack.
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 */
package org.seedstack.seed.security.rule;

import javax.inject.Inject;
import javax.inject.Named;

import org.apache.shiro.authc.UsernamePasswordToken;
import org.apache.shiro.mgt.SecurityManager;
import org.apache.shiro.subject.Subject;
import org.apache.shiro.util.ThreadContext;
import org.junit.rules.TestRule;
import org.junit.runner.Description;
import org.junit.runners.model.Statement;

import org.seedstack.seed.it.api.ITBind;
import org.seedstack.seed.security.api.WithUser;

/**
 * MethodRule used to connect a user to seed security if annotation @ {@link org.seedstack.seed.security.api.WithUser} is present on method or on target class.
 * 
 * @author U236838
 */
@ITBind
public class SecurityITRule implements TestRule {
    /**
     * The securityManager to be used
     */
    @Inject
    @Named("defaultSecurityManager")
    private SecurityManager securityManager;

    @Override
    public Statement apply(final Statement base, final Description description) {
        return new Statement() {
            @Override
            public void evaluate() throws Throwable {
                WithUser userAnno = description.getAnnotation(WithUser.class);
                if (userAnno == null) {
                    userAnno = description.getTestClass().getAnnotation(WithUser.class);
                }

                if (userAnno != null) {
                    ThreadContext.bind(securityManager);
                    Subject subject = new Subject.Builder(securityManager).buildSubject();
                    UsernamePasswordToken token = new UsernamePasswordToken(userAnno.id(), userAnno.password());
                    subject.login(token);
                    ThreadContext.bind(subject);
                }

                base.evaluate();
            }
        };
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy