Compare commits

..

10 Commits

Author SHA1 Message Date
1a42273465 Merge remote-tracking branch 'origin/personal/pjq/organization' into merge/1
# Conflicts:
#	src/main/java/org/cmh/backend/authentication/controller/AuthenticationController.java
#	src/main/java/org/cmh/backend/authentication/repository/UserRepository.java
#	src/main/java/org/cmh/backend/authentication/service/UserService.java
2024-07-05 21:02:22 +08:00
54f055dea9 只有组织管理模块.新 2024-07-04 17:37:53 +08:00
bdba24dc26 Revert "只有组织管理模块"
This reverts commit 9fb75be5ab.
2024-07-04 17:35:47 +08:00
9fb75be5ab 只有组织管理模块 2024-07-04 17:33:15 +08:00
1e874606f3 完成组织管理(测试用) 2024-07-04 17:09:24 +08:00
ecf466716a 完成组织管理 2024-07-04 17:09:24 +08:00
187a5afbc2 基本的组织管理完成 2024-07-04 17:09:24 +08:00
d9f54774bd 登录功能基础完成 2024-07-04 17:09:24 +08:00
bac47d9749 添加了注册功能,但User中username意义不够明确,想改成accout,此版作备份用 2024-07-04 17:09:23 +08:00
bdc19166a3 merge main& solve conflict 2024-07-04 17:09:00 +08:00
9 changed files with 205 additions and 0 deletions

View File

@ -0,0 +1,79 @@
package org.cmh.backend.OrganizationManagement.controller;
import org.aspectj.weaver.ast.Or;
import org.cmh.backend.OrganizationManagement.model.Organization;
import org.cmh.backend.OrganizationManagement.service.OrganizationService;
import org.cmh.backend.authentication.model.User;
import org.cmh.backend.authentication.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.*;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Map;
import static org.springframework.http.ResponseEntity.ok;
@RestController
@RequestMapping("/organizations")
public class OrganizationController {
@Autowired
private OrganizationService organizationService;
@GetMapping("/listAll")
public ResponseEntity<List<Organization>> listAll() {
List<Organization> data = organizationService.listAll();
// System.out.println(data);
return ok(data);
}
@PostMapping("/addOrganization")
public Organization add(@RequestBody Map<String, String> credentials) {
Organization organization = new Organization();
if(credentials.get("organizationId") != null){
organization.setOrganizationId(Long.parseLong(credentials.get("organizationId")));
}
organization.setOrganizationName(credentials.get("organizationName"));
organization.setOrganizationStatus(Boolean.parseBoolean(credentials.get("organizationStatus")));
if(Integer.parseInt(credentials.get("parentOrganization")) != 0){
organization.setParentOrganization(organizationService.getById(Long.parseLong(credentials.get("parentOrganization"))));
}else{
organization.setParentOrganization(null);
}
organization.setEmail(credentials.get("email"));
organization.setLeader(credentials.get("leader"));
organization.setContactPhone(credentials.get("contactPhone"));
organization.setDisplayOrder(Integer.parseInt(credentials.get("displayOrder")));
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm");
String currentTime = sdf.format(new Date());
System.out.println(currentTime);
organization.setCreatedTime(currentTime);
Organization organizationAdd = organizationService.add(organization);
System.out.println(organizationAdd);
return organizationAdd;
}
@PostMapping("/deleteOrganization")
public String delete(@RequestBody Map<String, String> credentials) {
organizationService.delete(Long.valueOf(credentials.get("organizationId")));
return "success";
}
@PostMapping("/update")
public Organization update(@RequestBody Organization organization) {
return organizationService.update(organization);
}
@PostMapping("/getOrganizationById")
public Organization getById(@RequestBody Map<String, String> credentials) {
return organizationService.getById(Long.valueOf(credentials.get("organizationId")));
}
//ublic
}

View File

@ -0,0 +1,70 @@
package org.cmh.backend.OrganizationManagement.model;
import jakarta.persistence.*;
import lombok.Data;
import lombok.Getter;
import lombok.Setter;
@Table(name = "organizations")
@Entity
public class Organization {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Setter
@Getter
private long organizationId; // 部门ID作为数据库表的主键
@Setter
@Getter
@ManyToOne
@JoinColumn(name = "parent_organization_id")
private Organization parentOrganization; // 上级部门如果有的话
@Setter
@Getter
private String organizationName; // 部门名称
@Setter
@Getter
private int displayOrder; // 显示排序
@Setter
@Getter
private String leader; // 负责人
@Setter
@Getter
private String contactPhone; // 联系电话
@Setter
@Getter
private String email; // 邮箱
@Setter
@Getter
private boolean organizationStatus;
@Setter
@Getter
private String createdTime;
public Organization() {
}
public Organization(Organization organization, String organizationName, int displayOrder, String leader, String contactPhone, String email, boolean organizationStatus) {
this.parentOrganization = organization;
this.organizationName = organizationName;
this.displayOrder = displayOrder;
this.leader = leader;
this.contactPhone = contactPhone;
this.email = email;
this.organizationStatus = organizationStatus;
}
@Override
public String toString() {
return "Organization{" +
"organizationId=" + organizationId +
", parentOrganization='" + parentOrganization + '\'' +
", organizationName='" + organizationName + '\'' +
", displayOrder=" + displayOrder +
", leader='" + leader + '\'' +
", contactPhone='" + contactPhone + '\'' +
", email='" + email + '\'' +
", organizationStatus='" + organizationStatus + '\'' +
'}';
}
}

View File

@ -0,0 +1,20 @@
package org.cmh.backend.OrganizationManagement.repository;
import org.aspectj.weaver.ast.Or;
import org.cmh.backend.OrganizationManagement.model.Organization;
import org.cmh.backend.OrganizationManagement.service.OrganizationService;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;
import java.util.List;
@Repository
public interface OrganizationRepository extends JpaRepository<Organization, Long> {
List<Organization> findAll();
Organization save(Organization organization);
void deleteById(Long id);
Organization findByOrganizationId(Long id);
Organization findByOrganizationName(String name);
}

View File

@ -0,0 +1,36 @@
package org.cmh.backend.OrganizationManagement.service;
import org.cmh.backend.OrganizationManagement.model.Organization;
import org.cmh.backend.OrganizationManagement.repository.OrganizationRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class OrganizationService {
@Autowired
private OrganizationRepository organizationRepository;
public List<Organization> listAll(){
return organizationRepository.findAll();
}
public Organization add(Organization organization){
return organizationRepository.save(organization);
}
public Organization update(Organization organization){
return organizationRepository.save(organization);
}
public String delete(Long id){
organizationRepository.deleteById(id);
return "success";
}
public Organization getById(Long organizationId){
return organizationRepository.findByOrganizationId(organizationId);
}
public Organization getByName(String name){
return organizationRepository.findByOrganizationName(name);
}
}