Преглед изворни кода

更换管理员接口
找回密码申述接口

wangmh пре 8 година
родитељ
комит
b7188ba85b

+ 98 - 0
sso-server/src/main/java/com/uas/sso/controller/AppealController.java

@@ -0,0 +1,98 @@
+package com.uas.sso.controller;
+
+import com.uas.sso.entity.ResetPwdAppeal;
+import com.uas.sso.entity.Token;
+import com.uas.sso.service.ResetPwdAppealService;
+import com.uas.sso.service.UserService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.ui.ModelMap;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestMethod;
+import org.springframework.web.bind.annotation.RequestParam;
+import org.springframework.web.bind.annotation.RestController;
+
+import javax.validation.Valid;
+
+import static com.sun.xml.internal.ws.api.message.Packet.Status.Request;
+
+/**
+ * @author wangmh
+ * @create 2018-01-16 8:50
+ * @desc 申述controller
+ **/
+@RestController
+@RequestMapping("/appeal")
+public class AppealController extends BaseController {
+
+    @Autowired
+    private UserService userService;
+
+    @Autowired
+    private ResetPwdAppealService resetPwdAppealService;
+
+    /**
+     * 获取手机号验证码
+     *
+     * @author wangmh
+     * @date 2018/1/16 10:37
+     * @param mobile 手机号
+     * @return 验证码tokenId
+     */
+    @RequestMapping(value = "/check/mobile", method = RequestMethod.GET)
+    public ModelMap checkMobile(String mobile) {
+        if (!userService.mobileHasRegistered(mobile)) {
+            return error("用户手机号未被注册");
+        }
+
+        String token = getMobileCode(mobile);
+        return success(new ModelMap("token", token));
+    }
+
+    /**
+     * 校验验证码
+     *
+     * @author wangmh
+     * @date 2018/1/16 10:44
+     * @param mobile 手机号
+     * @param token 验证码tokenId
+     * @param code 验证码
+     * @return
+     */
+    @RequestMapping(value = "/checkMobile", method = RequestMethod.POST)
+    public ModelMap checkMobile(String mobile, @RequestParam String token, String code) {
+        Token existToken = tokenService.findOne(token);
+        if (existToken == null || existToken.isExpired()) {
+            return error("验证码已过期,请重新获取");
+        }
+
+        // 校验验证码
+        checkMobileCode(token, mobile, code);
+
+        // 返回信息
+        return success();
+    }
+
+    /**
+     * 找回密码申述
+     * @param resetPwdAppeal 申述信息
+     * @param token 验证码tokenId
+     * @param code 验证码
+     * @return
+     */
+    @RequestMapping(value = "/resetPwd", method = RequestMethod.POST)
+    public ModelMap resetPwd(@Valid ResetPwdAppeal resetPwdAppeal, String token, String code) {
+        Token existToken = tokenService.findOne(token);
+        if (existToken == null || existToken.isExpired()) {
+            return error("验证码已过期,请重新获取");
+        }
+
+        // TODO 参数空检验
+
+        // 校验验证码
+        checkMobileCode(token, resetPwdAppeal.getMobile(), code);
+
+        // 保存申述信息
+        resetPwdAppealService.submit(resetPwdAppeal);
+        return success();
+    }
+}

+ 1 - 1
sso-server/src/main/java/com/uas/sso/controller/BaseController.java

@@ -200,7 +200,7 @@ public class BaseController {
      * 获取手机号验证码
      *
      * @param mobile 手机号
-     * @return
+     * @return tokenId
      */
     protected String getMobileCode(String mobile) {
         return getValidCode(mobile, null);

+ 288 - 0
sso-server/src/main/java/com/uas/sso/controller/ChangeAdminController.java

@@ -0,0 +1,288 @@
+package com.uas.sso.controller;
+
+import com.uas.sso.core.Status;
+import com.uas.sso.entity.*;
+import com.uas.sso.service.ChangeAdminService;
+import com.uas.sso.service.UserService;
+import com.uas.sso.service.UserspaceService;
+import com.uas.sso.support.SystemSession;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.ui.ModelMap;
+import org.springframework.util.StringUtils;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestMethod;
+import org.springframework.web.bind.annotation.RequestParam;
+import org.springframework.web.bind.annotation.RestController;
+
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @author wangmh
+ * @create 2018-01-15 10:24
+ * @desc 更换管理员controller(需要登录)
+ **/
+@RestController
+@RequestMapping("/sso/change/admin")
+public class ChangeAdminController extends BaseController {
+
+    @Autowired
+    private UserService userService;
+
+    @Autowired
+    private UserspaceService userspaceService;
+
+    @Autowired
+    private ChangeAdminService changeAdminService;
+
+    @Autowired
+    private static final String STEP_SECONT_TOKEN = "changeAdmin";
+
+    /**
+     * 获取校验类型
+     *
+     * @return
+     */
+    @RequestMapping(value = "/checkType", method = RequestMethod.GET)
+    public ModelMap getCheckType() {
+        // 获取用户信息
+        UserAccount userAccount = SystemSession.getUserAccount();
+        User user = userService.findOne(userAccount.getUserUU());
+
+        // 判断是否未企业管理员
+        Userspace userspace = userspaceService.findOne(userAccount.getSpaceUU());
+        if (!userspace.getAdminUU().equals(user.getUserUU())) {
+            return success();
+        }
+
+        // 设置返回数据
+        ModelMap data = new ModelMap();
+        data.put("mobile", Status.AUTHENTICATED.getCode() == user.getMobileValidCode() ? user.getMobile() : null);
+        data.put("email", Status.AUTHENTICATED.getCode() == user.getEmailValidCode() ? user.getEmail() : null);
+        data.put("questions", user.getQuestions());
+        request.getSession().setAttribute("user", user);
+        return success(data);
+    }
+
+    /**
+     * 手机号获取验证码
+     *
+     * @return
+     * @author wangmh
+     * @date 2018/1/15 11:52
+     */
+    @RequestMapping(value = "/check/mobile", method = RequestMethod.GET)
+    public ModelMap checkByMobile() {
+        UserAccount userAccount = SystemSession.getUserAccount();
+
+        // 获取验证码
+        String token = getMobileCode(userAccount.getMobile());
+
+        // 设置返回值
+        return success(new ModelMap("token", token));
+    }
+
+    /**
+     * 手机号校验验证码
+     *
+     * @return
+     * @author wangmh
+     * @date 2018/1/15 11:53
+     */
+    @RequestMapping(value = "/check/mobile", method = RequestMethod.POST)
+    public ModelMap checkByMobile(@RequestParam String token, @RequestParam String code) {
+        UserAccount userAccount = SystemSession.getUserAccount();
+
+        // 校验验证码
+        checkMobileCode(token, userAccount.getMobile(), code);
+        tokenService.delete(token);
+
+        // 设置返回值
+        Token existToken = new Token(userAccount, 7 * 24 * 60 * 60);
+        request.getSession().setAttribute("existToken", existToken);
+        tokenService.save(existToken);
+        return success(new ModelMap("token", existToken));
+    }
+
+    /**
+     * 获取邮箱验证
+     *
+     * @return
+     * @author wangmh
+     * @date 2018/1/15 13:56
+     */
+    @RequestMapping(value = "/check/email", method = RequestMethod.GET)
+    public ModelMap checkByEmail() {
+        UserAccount userAccount = SystemSession.getUserAccount();
+
+        // 设置发送邮件信息
+        Token existToken = new Token(userAccount, 7 * 24 * 60 * 60);
+        tokenService.save(existToken);
+        ModelMap data = new ModelMap();
+        data.put("vipName", userAccount.getVipName());
+        // TODO 邮件认证地址
+        data.put("url", "http://192.168.253.66:8081/sso/resetPwd/check/question?token="+existToken.getId());
+
+        // 发送邮件
+        String email = userAccount.getEmail();
+        if (!StringUtils.isEmpty(email)) {
+            Setting mailTplId = settingService.findOne("templateForSendMailWhenResetPassword");
+            if (!StringUtils.isEmpty(mailTplId)) {
+                mailService.send(mailTplId.getValue(), email, data);
+            }
+        }
+
+        // 设置返回值
+        request.getSession().setAttribute("existToken", existToken);
+        return success();
+    }
+
+    /**
+     * 获取用户的密保问题
+     *
+     * @author wangmh
+     * @date 2018/1/15 16:19
+     * @return
+     */
+    @RequestMapping(value = "/check/question", method = RequestMethod.GET)
+    public ModelMap checkByQuestion() {
+        UserAccount userAccount = SystemSession.getUserAccount();
+
+        // 查询密保
+        User user = userService.findOne(userAccount.getUserUU());
+        List<UserQuestion> questions = user.getQuestions();
+
+        // 将问题返回用户,答案放入session
+        Map<Long, String> userAnswer = new HashMap<>(questions.size());
+        for (UserQuestion question : questions) {
+            userAnswer.put(question.getId(), question.getAnswer());
+        }
+        request.getSession().setAttribute("answers", userAnswer);
+        ModelMap data = new ModelMap();
+        data.put("question", questions);
+        return success(data);
+    }
+
+    /**
+     * 校验用户密保答案
+     *
+     * @author wangmh
+     * @date 2018/1/15 16:20
+     * @param answers 用户输入的答案
+     * @return
+     */
+    @RequestMapping(value = "/check/question", method = RequestMethod.POST)
+    public ModelMap checkByQuestion(List<Map<String, Object>> answers) {
+        UserAccount userAccount = SystemSession.getUserAccount();
+
+        // 校验密保答案
+        Map<Long, String> userAnswer = (Map<Long, String>) request.getSession().getAttribute("answers");
+        for (Map<String, Object> answer : answers) {
+            if (!answer.get("answer").equals(userAnswer.get(answer.get("id")))){
+                return error("答案错误");
+            }
+        }
+
+        // 返回token
+        Token existToken = new Token(userAccount, 7 * 24 * 60 * 60);
+        request.getSession().setAttribute("existToken", existToken);
+        tokenService.save(existToken);
+        ModelMap data = new ModelMap();
+        data.put("token", existToken.getId());
+        return success(data);
+    }
+
+    /**
+     * 校验第一步传的token
+     * @param token 第一步返回的token
+     * @return
+     */
+    @RequestMapping(value = "/apply", method = RequestMethod.GET)
+    public ModelMap checkToken(@RequestParam String token) {
+        if (StringUtils.isEmpty(token)) {
+            return error("验证信息已过期,请重新验证");
+        }
+        Token existToken = tokenService.findOne(token);
+        if (existToken == null) {
+            return error("验证信息已过期,请重新验证");
+        }
+
+        return success();
+    }
+
+    /**
+     * 获取验证码
+     * 
+     * @author wangmh
+     * @date 2018/1/15 18:09
+     * @param mobile 新管理员手机号
+     * @param token 第一步返回的token
+     * @return
+     */
+    @RequestMapping(value = "/check/newMobile", method = RequestMethod.GET)
+    public ModelMap checkByNewMobile(String mobile, @RequestParam String token) {
+        
+        // 校验第一步返回的token
+        checkToken(token);
+
+        // 获取token并返回
+        return success(new ModelMap("token", getMobileCode(mobile)));
+    }
+
+    /**
+     * 校验验证码
+     *
+     * @author wangmh
+     * @date 2018/1/15 18:22
+     * @param mobile 手机号
+     * @param token 获取验证码返回的token
+     * @param code 验证码
+     * @return
+     */
+    @RequestMapping(value = "/check/newMobile", method = RequestMethod.POST)
+    public ModelMap checkByNewMobile(String mobile, @RequestParam String token, String code,
+                                     @RequestParam String codeToken, String changeReason, String contactTel) {
+
+        // 校验第一步返回的token
+        if (StringUtils.isEmpty(token)) {
+            return error("验证信息已过期,请重新验证");
+        }
+        Token existToken = tokenService.findOne(token);
+        if (existToken == null) {
+            return error("验证信息已过期,请重新验证");
+        }
+
+        // 校验空参数
+        if (StringUtils.isEmpty(changeReason.trim())) {
+            return error("更换原因不能为空");
+        }
+        if (StringUtils.isEmpty(contactTel.trim())) {
+            return error("联系电话不能为空");
+        }
+
+        // 校验验证码
+        checkMobileCode(codeToken, mobile, code);
+
+        // 获取新管理员
+        User afterAdmin = userService.findByMobile(mobile);
+
+        // 获取提交者
+        UserAccount userAccount = (UserAccount) existToken.getBind();
+
+        // 获取之前的管理员
+        Userspace userspace = userspaceService.findOne(userAccount.getSpaceUU());
+        User beforeAdmin = userService.findOne(userspace.getAdminUU());
+
+        ChangeAdmin changeAdmin = new ChangeAdmin();
+        changeAdmin.setSubmitterUU(userAccount.getUserUU());
+        changeAdmin.setBeforeAdminUU(beforeAdmin.getUserUU());
+        changeAdmin.setAfterAdminUU(afterAdmin.getUserUU());
+        changeAdmin.setChangeReason(changeReason);
+        changeAdmin.setContactTel(contactTel);
+        changeAdminService.submit(changeAdmin);
+
+        return success();
+    }
+
+}

+ 2 - 2
sso-server/src/main/java/com/uas/sso/controller/ResetPasswordController.java

@@ -107,7 +107,7 @@ public class ResetPasswordController extends BaseController {
     /**
      * 获取可以校验方式
      *
-     * @param type 修改密码类型
+     * @param type 修改密码类型(update or reset)
      * @return
      */
     @RequestMapping(value = "/CheckType/{type}", method = RequestMethod.GET)
@@ -132,7 +132,7 @@ public class ResetPasswordController extends BaseController {
         data.put("mobile", Status.AUTHENTICATED.getCode() == user.getMobileValidCode() ? user.getMobile() : null);
         data.put("email", Status.AUTHENTICATED.getCode() == user.getEmailValidCode() ? user.getEmail() : null);
         request.getSession().setAttribute("user", user);
-        return success();
+        return success(data);
     }
 
     /**

+ 13 - 0
sso-server/src/main/java/com/uas/sso/dao/ChangeAdminDao.java

@@ -0,0 +1,13 @@
+package com.uas.sso.dao;
+
+import com.uas.sso.entity.ChangeAdmin;
+import org.springframework.data.jpa.repository.JpaRepository;
+import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
+
+/**
+ * @author wangmh
+ * @create 2018-01-15 19:36
+ * @desc
+ **/
+public interface ChangeAdminDao extends JpaRepository<ChangeAdmin, Long>, JpaSpecificationExecutor<ChangeAdmin> {
+}

+ 13 - 0
sso-server/src/main/java/com/uas/sso/dao/ResetPwdAppealDao.java

@@ -0,0 +1,13 @@
+package com.uas.sso.dao;
+
+import com.uas.sso.entity.ResetPwdAppeal;
+import org.springframework.data.jpa.repository.JpaRepository;
+import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
+
+/**
+ * @author wangmh
+ * @create 2018-01-16 14:27
+ * @desc
+ **/
+public interface ResetPwdAppealDao extends JpaRepository<ResetPwdAppeal, Long>, JpaSpecificationExecutor<ResetPwdAppeal> {
+}

+ 177 - 0
sso-server/src/main/java/com/uas/sso/entity/ChangeAdmin.java

@@ -0,0 +1,177 @@
+package com.uas.sso.entity;
+
+import javax.persistence.*;
+import java.io.Serializable;
+import java.sql.Timestamp;
+
+/**
+ * @author wangmh
+ * @create 2018-01-15 18:33
+ * @desc 更换管理员实体
+ **/
+@Entity
+@Table(name = "sso$us$admin")
+public class ChangeAdmin implements Serializable {
+
+    /**
+     *
+     */
+    private static final long serialVersionUID = 1L;
+
+    /**
+     * 主键
+     */
+    @Id
+    @Column(name = "_id")
+    @SequenceGenerator(name="sso$us$admin_gen", sequenceName="sso$us$admin_seq", allocationSize=1)
+    @GeneratedValue(strategy=GenerationType.IDENTITY, generator="sso$us$admin_gen")
+    private Long id;
+
+    /**
+     * 提交人uu号
+     */
+    @Column(name = "submitteruu", nullable = false)
+    private Long submitterUU;
+
+    /**
+     * 提交时间
+     */
+    @Column(name = "submit_time", nullable = false)
+    private Timestamp submitDate;
+
+    /**
+     * 更换管理员原因
+     */
+    @Column(name = "change_reason", length = 1000, nullable = false)
+    private String changeReason;
+
+    /**
+     * 更换前管理员的uu号
+     */
+    @Column(name = "before_admin_uu")
+    private Long beforeAdminUU;
+
+    /**
+     * 更换后管理员的uu号
+     */
+    @Column(name = "after_admin_uu")
+    private Long afterAdminUU;
+
+    /**
+     * 审核人
+     */
+    @Column(name = "auditor")
+    private String auditor;
+
+    /**
+     * 认证日期
+     */
+    @Column(name = "valid_date")
+    private String validDate;
+
+    /**
+     * 认证状态
+     */
+    @Column(name = "valid_code", nullable = false)
+    private Short validCode;
+
+    /**
+     * 不通过原因
+     */
+    @Column(name = "invalid_reason")
+    private String invalidReason;
+
+    /**
+     * 联系人电话
+     */
+    @Column(name = "contact_tel")
+    private String contactTel;
+
+    public Long getId() {
+        return id;
+    }
+
+    public void setId(Long id) {
+        this.id = id;
+    }
+
+    public Long getSubmitterUU() {
+        return submitterUU;
+    }
+
+    public void setSubmitterUU(Long submitterUU) {
+        this.submitterUU = submitterUU;
+    }
+
+    public Timestamp getSubmitDate() {
+        return submitDate;
+    }
+
+    public void setSubmitDate(Timestamp submitDate) {
+        this.submitDate = submitDate;
+    }
+
+    public String getChangeReason() {
+        return changeReason;
+    }
+
+    public void setChangeReason(String changeReason) {
+        this.changeReason = changeReason;
+    }
+
+    public Long getBeforeAdminUU() {
+        return beforeAdminUU;
+    }
+
+    public void setBeforeAdminUU(Long beforeAdminUU) {
+        this.beforeAdminUU = beforeAdminUU;
+    }
+
+    public Long getAfterAdminUU() {
+        return afterAdminUU;
+    }
+
+    public void setAfterAdminUU(Long afterAdminUU) {
+        this.afterAdminUU = afterAdminUU;
+    }
+
+    public String getAuditor() {
+        return auditor;
+    }
+
+    public void setAuditor(String auditor) {
+        this.auditor = auditor;
+    }
+
+    public String getValidDate() {
+        return validDate;
+    }
+
+    public void setValidDate(String validDate) {
+        this.validDate = validDate;
+    }
+
+    public Short getValidCode() {
+        return validCode;
+    }
+
+    public void setValidCode(Short validCode) {
+        this.validCode = validCode;
+    }
+
+    public String getInvalidReason() {
+        return invalidReason;
+    }
+
+    public void setInvalidReason(String invalidReason) {
+        this.invalidReason = invalidReason;
+    }
+
+    public String getContactTel() {
+        return contactTel;
+    }
+
+    public void setContactTel(String contactTel) {
+        this.contactTel = contactTel;
+    }
+}

+ 149 - 0
sso-server/src/main/java/com/uas/sso/entity/ResetPwdAppeal.java

@@ -0,0 +1,149 @@
+package com.uas.sso.entity;
+
+import javax.persistence.*;
+import java.io.Serializable;
+
+/**
+ * @author wangmh
+ * @create 2018-01-16 10:58
+ * @desc 找回密码申述实体
+ **/
+@Entity
+@Table(name = "sso$appeal$password")
+public class ResetPwdAppeal implements Serializable {
+
+
+    /**
+     *
+     */
+    private static final long serialVersionUID = 1L;
+
+    /**
+     * 主键
+     */
+    @Id
+    @Column(name = "_id")
+    @SequenceGenerator(name = "sso$appeal$password_gen", sequenceName = "sso$appeal$password_seq", allocationSize = 1)
+    @GeneratedValue(strategy = GenerationType.IDENTITY, generator = "sso$appeal$password_gen")
+    private Long id;
+
+    /**
+     * 手机号
+     */
+    @Column(name = "mobile", nullable = false)
+    private String mobile;
+
+    /**
+     * 申述密码
+     */
+    @Column(name = "_password", nullable = false)
+    private String password;
+
+    /**
+     * 联系人
+     */
+    @Column(name = "contact_name", nullable = false)
+    private String contactName;
+
+    /**
+     * 联系人
+     */
+    @Column(name = "contact_tel", nullable = false)
+    private String contactTel;
+
+    /**
+     * 联系人
+     */
+    @Column(name = "contact_email", nullable = false)
+    private String contactEmail;
+
+    /**
+     * 审核人
+     */
+    @Column(name = "auditor")
+    private String auditor;
+
+    /**
+     * 审核日期
+     */
+    @Column(name = "audit_date")
+    private String auditDate;
+
+    /**
+     * 审核状态(Status枚举)
+     */
+    @Column(name = "status", nullable = false)
+    private short status;
+
+    public Long getId() {
+        return id;
+    }
+
+    public void setId(Long id) {
+        this.id = id;
+    }
+
+    public String getMobile() {
+        return mobile;
+    }
+
+    public void setMobile(String mobile) {
+        this.mobile = mobile;
+    }
+
+    public String getPassword() {
+        return password;
+    }
+
+    public void setPassword(String password) {
+        this.password = password;
+    }
+
+    public String getContactName() {
+        return contactName;
+    }
+
+    public void setContactName(String contactName) {
+        this.contactName = contactName;
+    }
+
+    public String getContactTel() {
+        return contactTel;
+    }
+
+    public void setContactTel(String contactTel) {
+        this.contactTel = contactTel;
+    }
+
+    public String getContactEmail() {
+        return contactEmail;
+    }
+
+    public void setContactEmail(String contactEmail) {
+        this.contactEmail = contactEmail;
+    }
+
+    public String getAuditor() {
+        return auditor;
+    }
+
+    public void setAuditor(String auditor) {
+        this.auditor = auditor;
+    }
+
+    public String getAuditDate() {
+        return auditDate;
+    }
+
+    public void setAuditDate(String auditDate) {
+        this.auditDate = auditDate;
+    }
+
+    public short getStatus() {
+        return status;
+    }
+
+    public void setStatus(short status) {
+        this.status = status;
+    }
+}

+ 4 - 2
sso-server/src/main/java/com/uas/sso/entity/UserRecord.java

@@ -16,6 +16,8 @@ public class UserRecord implements Serializable {
 
     @Id
     @Column(name = "_id")
+    @SequenceGenerator(name = "sso$user$record_gen", sequenceName = "sso$user$record_seq", allocationSize = 1)
+    @GeneratedValue(strategy = GenerationType.IDENTITY, generator = "sso$user$record_gen")
     private Long id;
 
     @Column(name = "last_login_time")
@@ -36,8 +38,8 @@ public class UserRecord implements Serializable {
         this.id = id;
     }
 
-    public long getLastLoginTime() {
-        return lastLoginTime.getTime();
+    public Timestamp getLastLoginTime() {
+        return lastLoginTime;
     }
 
     public void setLastLoginTime(long lastLoginTime) {

+ 17 - 0
sso-server/src/main/java/com/uas/sso/entity/Userspace.java

@@ -163,6 +163,15 @@ public class Userspace implements Serializable {
             inverseJoinColumns = {@JoinColumn(name="user_uu", referencedColumnName="useruu")})
     private List<User> users;
 
+    /**
+     * 企业开通的应用
+     */
+    @ManyToMany
+    @JoinTable(name = "sso$app_userspace",
+            joinColumns = {@JoinColumn(name="space_uu", referencedColumnName="spaceuu")},
+            inverseJoinColumns = {@JoinColumn(name="app_uid", referencedColumnName="uid_")})
+    private List<App> apps;
+
     public Userspace() {
     }
 
@@ -349,4 +358,12 @@ public class Userspace implements Serializable {
     public void setUsers(List<User> users) {
         this.users = users;
     }
+
+    public List<App> getApps() {
+        return apps;
+    }
+
+    public void setApps(List<App> apps) {
+        this.apps = apps;
+    }
 }

+ 17 - 0
sso-server/src/main/java/com/uas/sso/service/ChangeAdminService.java

@@ -0,0 +1,17 @@
+package com.uas.sso.service;
+
+import com.uas.sso.entity.ChangeAdmin;
+
+/**
+ * @author wangmh
+ * @create 2018-01-15 18:32
+ * @desc 更换管理员service
+ **/
+public interface ChangeAdminService {
+
+    /**
+     * 提交申请
+     * @param changeAdmin 更换管理员信息
+     */
+    void submit(ChangeAdmin changeAdmin);
+}

+ 17 - 0
sso-server/src/main/java/com/uas/sso/service/ResetPwdAppealService.java

@@ -0,0 +1,17 @@
+package com.uas.sso.service;
+
+import com.uas.sso.entity.ResetPwdAppeal;
+
+/**
+ * @author wangmh
+ * @create 2018-01-16 13:31
+ * @desc 重置密码申述service
+ **/
+public interface ResetPwdAppealService {
+
+    /**
+     * 提交申述
+     * @param resetPwdAppeal 重置密码申述信息
+     */
+    void submit(ResetPwdAppeal resetPwdAppeal);
+}

+ 9 - 0
sso-server/src/main/java/com/uas/sso/service/UserspaceService.java

@@ -66,4 +66,13 @@ public interface UserspaceService {
      */
     void submitValidInfo(Userspace userspace);
 
+    /**
+     * 根据企业uu号查找企业信息
+     *
+     * @author wangmh
+     * @date 2018/1/15 13:47
+     * @param spaceUU 企业uu号
+     * @return 企业信息
+     */
+    Userspace findOne(Long spaceUU);
 }

+ 35 - 0
sso-server/src/main/java/com/uas/sso/service/impl/ChangeAdminServiceImpl.java

@@ -0,0 +1,35 @@
+package com.uas.sso.service.impl;
+
+import com.sun.istack.internal.NotNull;
+import com.uas.sso.core.Status;
+import com.uas.sso.dao.ChangeAdminDao;
+import com.uas.sso.entity.ChangeAdmin;
+import com.uas.sso.service.ChangeAdminService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+
+import java.sql.Timestamp;
+
+/**
+ * @author wangmh
+ * @create 2018-01-15 19:32
+ * @desc
+ **/
+@Service
+public class ChangeAdminServiceImpl implements ChangeAdminService {
+
+    @Autowired
+    private ChangeAdminDao changeAdminDao;
+
+    @Override
+    public void submit(@NotNull ChangeAdmin changeAdmin) {
+        // 设置时间和审核状态
+        if (changeAdmin.getSubmitDate() == null) {
+            changeAdmin.setSubmitDate(new Timestamp(System.currentTimeMillis()));
+        }
+        changeAdmin.setValidCode((short) Status.TO_BE_CERTIFIED.getCode());
+
+        // 保存信息
+        changeAdminDao.save(changeAdmin);
+    }
+}

+ 30 - 0
sso-server/src/main/java/com/uas/sso/service/impl/ResetPwdAppealServiceImpl.java

@@ -0,0 +1,30 @@
+package com.uas.sso.service.impl;
+
+import com.uas.sso.core.Status;
+import com.uas.sso.dao.ResetPwdAppealDao;
+import com.uas.sso.entity.ResetPwdAppeal;
+import com.uas.sso.service.ResetPwdAppealService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+
+/**
+ * @author wangmh
+ * @create 2018-01-16 13:33
+ * @desc 重置密码申述service实现
+ **/
+@Service
+public class ResetPwdAppealServiceImpl implements ResetPwdAppealService {
+
+    @Autowired
+    private ResetPwdAppealDao resetPwdAppealDao;
+
+    @Override
+    public void submit(ResetPwdAppeal resetPwdAppeal) {
+        resetPwdAppeal.setAuditDate(null);
+        resetPwdAppeal.setAuditor(null);
+        resetPwdAppeal.setStatus((short) Status.TO_BE_CERTIFIED.getCode());
+
+        // 保存信息
+        resetPwdAppealDao.save(resetPwdAppeal);
+    }
+}

+ 5 - 0
sso-server/src/main/java/com/uas/sso/service/impl/UserspaceServiceImpl.java

@@ -179,4 +179,9 @@ public class UserspaceServiceImpl implements UserspaceService {
         // TODO 保存日志
 
     }
+
+    @Override
+    public Userspace findOne(Long spaceUU) {
+        return userspaceDao.findOne(spaceUU);
+    }
 }