-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
1. 新增数据库业务逻辑类 2. 新增数据库控制器类 3. 新增数据库单元测试 Signed-off-by: Alan Yeh <[email protected]>
- Loading branch information
Showing
6 changed files
with
880 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
123 changes: 123 additions & 0 deletions
123
...hboard/src/main/java/central/studio/dashboard/controller/system/param/DatabaseParams.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,123 @@ | ||
/* | ||
* MIT License | ||
* | ||
* Copyright (c) 2022-present Alan Yeh <[email protected]> | ||
* | ||
* Permission is hereby granted, free of charge, to any person obtaining a copy | ||
* of this software and associated documentation files (the "Software"), to deal | ||
* in the Software without restriction, including without limitation the rights | ||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
* copies of the Software, and to permit persons to whom the Software is | ||
* furnished to do so, subject to the following conditions: | ||
* | ||
* The above copyright notice and this permission notice shall be included in all | ||
* copies or substantial portions of the Software. | ||
* | ||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||
* SOFTWARE. | ||
*/ | ||
|
||
package central.studio.dashboard.controller.system.param; | ||
|
||
import central.data.system.DatabaseInput; | ||
import central.util.Listx; | ||
import central.validation.Label; | ||
import central.validation.group.Insert; | ||
import central.validation.group.Update; | ||
import jakarta.validation.Valid; | ||
import jakarta.validation.constraints.*; | ||
import lombok.AllArgsConstructor; | ||
import lombok.Builder; | ||
import lombok.Data; | ||
import lombok.NoArgsConstructor; | ||
|
||
import java.util.List; | ||
|
||
/** | ||
* Database Params | ||
* <p> | ||
* 数据库入参 | ||
* | ||
* @author Alan Yeh | ||
* @since 2024/10/20 | ||
*/ | ||
@Data | ||
@Builder | ||
@NoArgsConstructor | ||
@AllArgsConstructor | ||
public class DatabaseParams { | ||
|
||
@Label("主键") | ||
@Null(groups = Insert.class) | ||
@NotBlank(groups = Update.class) | ||
@Size(min = 1, max = 32, groups = Insert.class) | ||
private String id; | ||
|
||
@Label("应用主键") | ||
@NotNull | ||
@Size(min = 1, max = 32) | ||
private String applicationId; | ||
|
||
@Label("标识") | ||
@NotBlank | ||
@Size(min = 1, max = 32) | ||
@Pattern(regexp = "^[0-9a-zA-Z_-]+$", message = "${label}[${property}]只能由数字、英文字母、中划线、下划线组成") | ||
@Pattern(regexp = "^(?!-)(?!_).*$", message = "${label}[${property}]不能由中划线或下划线开头") | ||
@Pattern(regexp = "^(?!.*?[-_]$).*$", message = "${label}[${property}]不能由中划线或下划线结尾") | ||
@Pattern(regexp = "^(?!.*(--).*$).*$", message = "${label}[${property}]不能出现连续中划线") | ||
@Pattern(regexp = "^(?!.*(__).*$).*$", message = "${label}[${property}]不能出现连续下划线") | ||
@Pattern(regexp = "^(?!.*(-_|_-).*$).*$", message = "${label}[${property}]不能出现连续中划线、下划线") | ||
private String code; | ||
|
||
@Label("名称") | ||
@NotBlank | ||
@Size(min = 1, max = 50) | ||
private String name; | ||
|
||
@Label("类型") | ||
@NotBlank | ||
@Size(min = 1, max = 32) | ||
private String type; | ||
|
||
@Label("是否启用") | ||
@NotNull | ||
private Boolean enabled; | ||
|
||
@Label("备注") | ||
@Size(max = 1024) | ||
private String remark; | ||
|
||
@Label("主数据库") | ||
@NotNull | ||
@Valid | ||
private DatabasePropertiesParams master; | ||
|
||
@Label("从数据库") | ||
@Valid | ||
private List<DatabasePropertiesParams> slaves; | ||
|
||
@Label("初始化参数") | ||
@NotBlank | ||
@Size(min = 1, max = 5 * 1024 * 1024) | ||
private String params; | ||
|
||
public DatabaseInput toInput() { | ||
return DatabaseInput.builder() | ||
.id(this.getId()) | ||
.applicationId(this.getApplicationId()) | ||
.code(this.getCode()) | ||
.name(this.getName()) | ||
.type(this.getType()) | ||
.enabled(this.getEnabled()) | ||
.remark(this.getRemark()) | ||
.master(this.getMaster().toInput()) | ||
.slaves(Listx.asStream(this.getSlaves()).map(DatabasePropertiesParams::toInput).toList()) | ||
.params(this.getParams()) | ||
.build(); | ||
} | ||
} |
75 changes: 75 additions & 0 deletions
75
.../main/java/central/studio/dashboard/controller/system/param/DatabasePropertiesParams.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
/* | ||
* MIT License | ||
* | ||
* Copyright (c) 2022-present Alan Yeh <[email protected]> | ||
* | ||
* Permission is hereby granted, free of charge, to any person obtaining a copy | ||
* of this software and associated documentation files (the "Software"), to deal | ||
* in the Software without restriction, including without limitation the rights | ||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
* copies of the Software, and to permit persons to whom the Software is | ||
* furnished to do so, subject to the following conditions: | ||
* | ||
* The above copyright notice and this permission notice shall be included in all | ||
* copies or substantial portions of the Software. | ||
* | ||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||
* SOFTWARE. | ||
*/ | ||
|
||
package central.studio.dashboard.controller.system.param; | ||
|
||
import central.data.system.DatabasePropertiesInput; | ||
import central.validation.Label; | ||
import jakarta.validation.constraints.NotBlank; | ||
import jakarta.validation.constraints.Size; | ||
import lombok.AllArgsConstructor; | ||
import lombok.Builder; | ||
import lombok.Data; | ||
import lombok.NoArgsConstructor; | ||
|
||
/** | ||
* Database Properties Params | ||
* <p> | ||
* 数据库配置入参 | ||
* | ||
* @author Alan Yeh | ||
* @since 2024/10/20 | ||
*/ | ||
@Data | ||
@Builder | ||
@NoArgsConstructor | ||
@AllArgsConstructor | ||
public class DatabasePropertiesParams { | ||
@Label("驱动") | ||
@NotBlank | ||
@Size(min = 1, max = 1024) | ||
private String driver; | ||
|
||
@Label("连接字符串") | ||
@NotBlank | ||
@Size(min = 1, max = 1024) | ||
private String url; | ||
|
||
@Label("用户名") | ||
@Size(max = 50) | ||
private String username; | ||
|
||
@Label("密码") | ||
@Size(max = 50) | ||
private String password; | ||
|
||
public DatabasePropertiesInput toInput() { | ||
return DatabasePropertiesInput.builder() | ||
.driver(this.getDriver()) | ||
.url(this.getUrl()) | ||
.username(this.getUsername()) | ||
.password(this.getPassword()) | ||
.build(); | ||
} | ||
} |
83 changes: 83 additions & 0 deletions
83
...ard/src/main/java/central/studio/dashboard/controller/system/query/DatabasePageQuery.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,83 @@ | ||
/* | ||
* MIT License | ||
* | ||
* Copyright (c) 2022-present Alan Yeh <[email protected]> | ||
* | ||
* Permission is hereby granted, free of charge, to any person obtaining a copy | ||
* of this software and associated documentation files (the "Software"), to deal | ||
* in the Software without restriction, including without limitation the rights | ||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
* copies of the Software, and to permit persons to whom the Software is | ||
* furnished to do so, subject to the following conditions: | ||
* | ||
* The above copyright notice and this permission notice shall be included in all | ||
* copies or substantial portions of the Software. | ||
* | ||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||
* SOFTWARE. | ||
*/ | ||
|
||
package central.studio.dashboard.controller.system.query; | ||
|
||
import central.data.system.Database; | ||
import central.lang.Stringx; | ||
import central.sql.query.Conditions; | ||
import central.starter.web.query.PageQuery; | ||
import central.validation.Label; | ||
import jakarta.validation.constraints.NotBlank; | ||
import lombok.Data; | ||
import lombok.EqualsAndHashCode; | ||
|
||
import java.io.Serial; | ||
|
||
/** | ||
* Database Page Query | ||
* <p> | ||
* 数据库分页查询 | ||
* | ||
* @author Alan Yeh | ||
* @since 2024/10/20 | ||
*/ | ||
@Data | ||
@EqualsAndHashCode(callSuper = true) | ||
public class DatabasePageQuery extends PageQuery<Database> { | ||
Check warning on line 48 in central-dashboard/src/main/java/central/studio/dashboard/controller/system/query/DatabasePageQuery.java
|
||
@Serial | ||
private static final long serialVersionUID = 5563847496249217986L; | ||
|
||
@NotBlank | ||
@Label("应用主键") | ||
private String applicationId; | ||
|
||
@Label("标识") | ||
private String code; | ||
|
||
@Label("名称") | ||
private String name; | ||
|
||
@Override | ||
public Conditions<Database> build() { | ||
var conditions = Conditions.of(Database.class); | ||
|
||
conditions.eq(Database::getApplicationId, this.getApplicationId()); | ||
|
||
// 精确搜索 | ||
if (Stringx.isNotBlank(this.getCode())) { | ||
conditions.like(Database::getCode, this.getCode()); | ||
} | ||
if (Stringx.isNotBlank(this.getName())) { | ||
conditions.like(Database::getName, this.getName()); | ||
} | ||
|
||
// 模糊搜索 | ||
for (var keyword : this.getKeywords()) { | ||
conditions.and(filter -> filter.like(Database::getCode, keyword).or().like(Database::getName, keyword)); | ||
} | ||
|
||
return conditions; | ||
} | ||
} |
Oops, something went wrong.