123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 |
- package com.fs.company.controller;
- import com.fs.common.constant.Constants;
- import com.fs.common.core.domain.AjaxResult;
- import com.fs.common.core.redis.RedisCache;
- import com.fs.common.utils.PatternUtils;
- import com.fs.common.utils.ServletUtils;
- import com.fs.company.domain.CompanyMenu;
- import com.fs.company.domain.CompanyUser;
- import com.fs.company.service.ICompanyMenuService;
- import com.fs.core.security.LoginBody;
- import com.fs.core.security.LoginUser;
- import com.fs.core.web.service.CompanyLoginService;
- import com.fs.core.web.service.CompanyPermissionService;
- import com.fs.core.web.service.TokenService;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.web.bind.annotation.GetMapping;
- import org.springframework.web.bind.annotation.PostMapping;
- import org.springframework.web.bind.annotation.RequestBody;
- import org.springframework.web.bind.annotation.RestController;
- import java.util.ArrayList;
- import java.util.List;
- import java.util.Set;
- /**
- * 登录验证
- *
- */
- @RestController
- public class CompanyLoginController
- {
- @Autowired
- private CompanyLoginService loginService;
- @Autowired
- private ICompanyMenuService menuService;
- @Autowired
- private CompanyPermissionService permissionService;
- @Autowired
- private TokenService tokenService;
- @Autowired
- private RedisCache redisCache;
- /**
- * 登录方法
- *
- * @param loginBody 登录信息
- * @return 结果
- */
- @PostMapping("/login")
- public AjaxResult login(@RequestBody LoginBody loginBody)
- {
- if (!PatternUtils.checkPassword(loginBody.getPassword())) {
- return AjaxResult.error("密码格式不正确,需包含字母、数字和特殊字符,长度为 8-20 位");
- }
- AjaxResult ajax = AjaxResult.success();
- // 生成令牌
- String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(),
- loginBody.getUuid());
- ajax.put(Constants.TOKEN, token);
- return ajax;
- }
- // @PostMapping("/loginByToken")
- // public AjaxResult loginByAdmin(@RequestBody LoginToken param)
- // {
- // Long userId=redisCache.getCacheObject("")
- //
- // AjaxResult ajax = AjaxResult.success();
- // // 生成令牌
- // String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(),
- // loginBody.getUuid());
- // ajax.put(Constants.TOKEN, token);
- // return ajax;
- // }
- /**
- * 获取用户信息
- *
- * @return 用户信息
- */
- @GetMapping("getInfo")
- public AjaxResult getInfo()
- {
- LoginUser loginUser = tokenService.getLoginUser(ServletUtils.getRequest());
- CompanyUser user = loginUser.getUser();
- // 角色集合
- Set<String> roles = permissionService.getRolePermission(user);
- // 权限集合
- Set<String> permissions = permissionService.getMenuPermission(user);
- AjaxResult ajax = AjaxResult.success();
- ajax.put("user", user);
- ajax.put("roles", roles);
- ajax.put("permissions", permissions);
- return ajax;
- }
- /**
- * 获取路由信息
- *
- * @return 路由信息
- */
- @GetMapping("getRouters")
- public AjaxResult getRouters()
- {
- LoginUser loginUser = tokenService.getLoginUser(ServletUtils.getRequest());
- Long companyId = loginUser.getCompany().getCompanyId();
- // 用户信息
- CompanyUser user = loginUser.getUser();
- List<CompanyMenu> menus = new ArrayList<>();
- if (companyId.equals(174L)){
- menus = menuService.selectMenuTreeByCompany(user.getUserId(), loginUser.getUser().isAdmin());
- }else {
- menus = menuService.selectMenuTreeByUserId(user.getUserId(), loginUser.getUser().isAdmin());
- }
- return AjaxResult.success(menuService.buildMenus(menus));
- }
- }
|