diff --git a/app/JsonRpc/Service/CampusService.php b/app/JsonRpc/Service/CampusService.php new file mode 100644 index 0000000..5728841 --- /dev/null +++ b/app/JsonRpc/Service/CampusService.php @@ -0,0 +1,58 @@ +campusModel->level(1) + ->enabled() + ->orderBy('name') + ->get(['id', 'name', 'province']) + ->toArray(); + } + + /** + * 根据省份获取城市列表. + * @throws BusinessException + */ + public function getCitiesByProvince(string $province): array + { + return $this->campusModel->level(2) + ->province($province) + ->enabled() + ->orderBy('name') + ->get(['id', 'name', 'city']) + ->toArray(); + } + + protected function getModel(): AetherModel + { + return $this->campusModel; + } + + protected function getValidator(): AetherValidator + { + return $this->campusValidator; + } +} diff --git a/app/JsonRpc/Service/DataService.php b/app/JsonRpc/Service/DataService.php index d6af3d8..162e278 100644 --- a/app/JsonRpc/Service/DataService.php +++ b/app/JsonRpc/Service/DataService.php @@ -4,6 +4,9 @@ declare(strict_types=1); namespace App\JsonRpc\Service; +use Aether\AetherCrudService; +use Aether\AetherModel; +use Aether\AetherValidator; use Aether\Exception\BusinessException; use App\Exception\CampusNotFound; use App\Exception\TeacherNotFound; @@ -31,12 +34,18 @@ class DataService implements DataServiceInterface #[Inject] protected TeacherValidator $teacherValidator; + #[Inject] + protected CampusService $campusService; + + #[Inject] + protected TeacherService $teacherService; + /** * 获取校区列表. */ public function getCampuses(array $data): array { - return $this->campusModel->list($data); + return $this->campusService->list($data); } /** @@ -108,12 +117,25 @@ class DataService implements DataServiceInterface ->toArray(); } + public function getCampusByIds(array $ids): array + { + if (empty($ids)) { + return []; + } + return $this->campusModel + ->whereIn('id', $ids) + ->where('status', 1) + ->get() + ->keyBy('id') + ->toArray(); + } + /** * 获取教师列表. */ public function getTeachers(array $data): array { - return $this->teacherModel->list($data); + return $this->teacherService->list($data); } /** @@ -158,4 +180,14 @@ class DataService implements DataServiceInterface { return $this->teacherModel->deleteById($id); } + + protected function getModel(): AetherModel + { + return $this->campusModel; + } + + protected function getValidator(): AetherValidator + { + return $this->teacherValidator; + } } diff --git a/app/JsonRpc/Service/TeacherService.php b/app/JsonRpc/Service/TeacherService.php new file mode 100644 index 0000000..4b8a66a --- /dev/null +++ b/app/JsonRpc/Service/TeacherService.php @@ -0,0 +1,28 @@ +teacherModel; + } + + protected function getValidator(): AetherValidator + { + return $this->teacherValidator; + } +} \ No newline at end of file diff --git a/app/Model/Campus.php b/app/Model/Campus.php index cee9dca..a802ffe 100644 --- a/app/Model/Campus.php +++ b/app/Model/Campus.php @@ -5,6 +5,8 @@ declare(strict_types=1); namespace App\Model; use Aether\AetherModel; +use Aether\Contract\TreeableInterface; +use Aether\Traits\AetherTree; use Carbon\Carbon; use Hyperf\Database\Model\Builder; use Hyperf\Database\Model\Relations\BelongsTo; @@ -26,8 +28,9 @@ use Hyperf\Database\Model\Relations\HasMany; * @property Carbon $updated_at * @property Carbon $deleted_at */ -class Campus extends AetherModel +class Campus extends AetherModel implements TreeableInterface { + use AetherTree; protected ?string $table = 'da_campus'; protected array $fillable = [ @@ -52,10 +55,12 @@ class Campus extends AetherModel ]; protected array $search = [ + 'name' => 'like', 'level' => '=', 'parent_id' => '=', 'city' => 'like', 'province' => 'like', + 'status' => '=', ]; protected array|bool|string $sortable = false; @@ -119,4 +124,14 @@ class Campus extends AetherModel ->where('status', 1) ->whereNull('deleted_at'); } + + protected function getParentIdField(): string + { + return 'parent_id'; + } + + protected function getSortField(): string + { + return ''; + } } diff --git a/app/Model/Teacher.php b/app/Model/Teacher.php index d122a56..cbb8dbf 100644 --- a/app/Model/Teacher.php +++ b/app/Model/Teacher.php @@ -22,7 +22,7 @@ use Hyperf\Database\Model\Relations\BelongsTo; * @property string $introduction 教师简介 * @property int $campus_id 所属校区ID * @property int $status 状态:0-禁用,1-启用 - * @property int $sort_order 排序 + * @property int $sort 排序 * @property Carbon $created_at * @property Carbon $updated_at * @property Carbon $deleted_at diff --git a/app/Validator/CampusValidator.php b/app/Validator/CampusValidator.php index c4967bc..d5dbbdd 100644 --- a/app/Validator/CampusValidator.php +++ b/app/Validator/CampusValidator.php @@ -32,7 +32,7 @@ class CampusValidator extends AetherValidator ], 'update' => [ 'rules' => [ - 'id' => 'required|integer|min:1', + // 'id' => 'required|integer|min:1', 'name' => 'required|string|max:255', 'parent_id' => 'nullable|integer|min:0', 'level' => 'nullable|integer|in:1,2,3', @@ -41,7 +41,7 @@ class CampusValidator extends AetherValidator 'address' => 'nullable|string|max:500', ], 'messages' => [ - 'id.required' => '校区ID不能为空', + // 'id.required' => '校区ID不能为空', 'name.required' => '校区名称不能为空', 'level.in' => '层级只能是1、2、3', ], diff --git a/app/Validator/TeacherValidator.php b/app/Validator/TeacherValidator.php index 1562724..29fb3ca 100644 --- a/app/Validator/TeacherValidator.php +++ b/app/Validator/TeacherValidator.php @@ -32,7 +32,7 @@ class TeacherValidator extends AetherValidator ], 'update' => [ 'rules' => [ - 'id' => 'required|integer|min:1', + // 'id' => 'required|integer|min:1', 'name' => 'nullable|string|max:50', 'age' => 'nullable|integer|min:18|max:65', 'gender' => 'nullable|integer|in:1,2', @@ -41,7 +41,7 @@ class TeacherValidator extends AetherValidator 'teach_subject' => 'nullable|string|max:100', ], 'messages' => [ - 'id.required' => '教师ID不能为空', + // 'id.required' => '教师ID不能为空', 'age.min' => '年龄不能小于18岁', 'age.max' => '年龄不能大于65岁', 'gender.in' => '性别只能是1(男)或2(女)', diff --git a/composer.lock b/composer.lock index 7d20ef9..d5eb186 100644 --- a/composer.lock +++ b/composer.lock @@ -12,7 +12,7 @@ "source": { "type": "git", "url": "https://gitee.com/devAether666/aether-hyperf.git", - "reference": "b01e07101e6a4ee1f6f6d6e6496961c47f34d663" + "reference": "92a7f6c9a0b7b1addff990dee69a74977a1f4db2" }, "require": { "hyperf/db-connection": "~3.1.0", @@ -52,7 +52,7 @@ } ], "description": "Aether Hyperf Common Components", - "time": "2025-10-15T06:26:58+00:00" + "time": "2025-10-16T11:02:15+00:00" }, { "name": "carbonphp/carbon-doctrine-types", @@ -129,7 +129,7 @@ "source": { "type": "git", "url": "https://gitee.com/devAether666/dhd-contract.git", - "reference": "3ea8fcdd7efd083fba689c7b191e60078a772e53" + "reference": "c95c40536f0ff311cf5e0fd6bfaefe6f752f0726" }, "require": { "hyperf/database": "~3.1.0", @@ -157,7 +157,7 @@ } ], "description": "DHD Micro Service Contract Package", - "time": "2025-10-14T01:32:08+00:00" + "time": "2025-10-16T10:15:18+00:00" }, { "name": "doctrine/deprecations", @@ -3175,16 +3175,16 @@ }, { "name": "hyperf/nacos", - "version": "v3.1.61", + "version": "v3.1.62.1", "source": { "type": "git", "url": "https://github.com/hyperf/nacos.git", - "reference": "4e2833c5acc697fcacb2427649d99f85c3318de6" + "reference": "d294a20c4fb1616707d51ac68b55443d01d888de" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/hyperf/nacos/zipball/4e2833c5acc697fcacb2427649d99f85c3318de6", - "reference": "4e2833c5acc697fcacb2427649d99f85c3318de6", + "url": "https://api.github.com/repos/hyperf/nacos/zipball/d294a20c4fb1616707d51ac68b55443d01d888de", + "reference": "d294a20c4fb1616707d51ac68b55443d01d888de", "shasum": "" }, "require": { @@ -3225,7 +3225,7 @@ ], "support": { "issues": "https://github.com/hyperf/nacos/issues", - "source": "https://github.com/hyperf/nacos/tree/v3.1.61" + "source": "https://github.com/hyperf/nacos/tree/v3.1.62.1" }, "funding": [ { @@ -3237,7 +3237,7 @@ "type": "open_collective" } ], - "time": "2025-09-03T05:52:19+00:00" + "time": "2025-10-14T03:31:00+00:00" }, { "name": "hyperf/paginator", @@ -10851,6 +10851,6 @@ "platform": { "php": ">=8.1" }, - "platform-dev": [], - "plugin-api-version": "2.0.0" + "platform-dev": {}, + "plugin-api-version": "2.6.0" }