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

org.swiftboot.auth.interceptor.UserSessionArgumentResolver Maven / Gradle / Ivy

The newest version!
package org.swiftboot.auth.interceptor;

import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.core.MethodParameter;
import org.springframework.web.bind.support.WebDataBinderFactory;
import org.springframework.web.context.request.NativeWebRequest;
import org.springframework.web.context.request.ServletWebRequest;
import org.springframework.web.method.support.HandlerMethodArgumentResolver;
import org.springframework.web.method.support.ModelAndViewContainer;
import org.swiftboot.auth.config.SwiftbootAuthConfigBean;
import org.swiftboot.auth.annotation.Addition;
import org.swiftboot.auth.annotation.ExpireTime;
import org.swiftboot.auth.annotation.UserId;
import org.swiftboot.auth.annotation.UserName;
import org.swiftboot.auth.service.Session;
import org.swiftboot.auth.service.SessionService;

import javax.annotation.Resource;
import java.util.Map;

/**
 * Populate values from session to the annotated parameter of controller.
 * {@link UserId}, {@link UserName}, {@link ExpireTime}, {@link Addition}, {@link org.swiftboot.auth.annotation.Session}
 *
 * @author swiftech
 * @see org.swiftboot.auth.filter.AuthFilter
 * @since 2.1
 */
public class UserSessionArgumentResolver implements HandlerMethodArgumentResolver {

    private static final Logger log = LoggerFactory.getLogger(UserSessionArgumentResolver.class);

    @Resource
    private SwiftbootAuthConfigBean configBean;

    @Resource
    private SessionService sessionService;

    @Override
    public boolean supportsParameter(MethodParameter parameter) {
        return parameter.hasParameterAnnotation(UserId.class)
                || parameter.hasParameterAnnotation(UserName.class)
                || parameter.hasParameterAnnotation(ExpireTime.class)
                || parameter.hasParameterAnnotation(Addition.class)
                || parameter.hasParameterAnnotation(org.swiftboot.auth.annotation.Session.class);
    }

    @Override
    public Object resolveArgument(MethodParameter parameter,
                                  ModelAndViewContainer mavContainer,
                                  NativeWebRequest webRequest,
                                  WebDataBinderFactory binderFactory) throws Exception {
        ServletWebRequest servletWebRequest = (ServletWebRequest) webRequest;
        // Try to get token from headers, if the token is in Cookie, it must have been extracted from Cookie in previous AuthFilter
        String token = servletWebRequest.getHeader(configBean.getSession().getTokenKey());
        if (StringUtils.isBlank(token)) {
            log.trace("No token found in headers");
            return null;
        }
        else {
            Session session = sessionService.getSession(token);
            if (session == null) {
                log.trace("No session found in for token: " + token);
                return null;
            }
            log.info("Find and pre-set user id: " + session.getUserId());
            if (parameter.hasParameterAnnotation(UserId.class)) {
                return session.getUserId();
            }
            else if (parameter.hasParameterAnnotation(UserName.class)) {
                return session.getUserName();
            }
            else if (parameter.hasParameterAnnotation(ExpireTime.class)) {
                return session.getExpireTime();
            }
            else if (parameter.hasParameterAnnotation(Addition.class)) {
                Addition anno = parameter.getParameterAnnotation(Addition.class);
                if (anno != null && StringUtils.isNotBlank(anno.value())) {
                    Map additions = session.getAdditions();
                    if (additions != null && additions.containsKey(anno.value())) {
                        return additions.get(anno.value());
                    }
                }
                return null;
            }
            else if (parameter.hasParameterAnnotation(org.swiftboot.auth.annotation.Session.class)) {
                return session;
            }
            else {
                return null;
            }
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy