..
This commit is contained in:
		
							
								
								
									
										58
									
								
								app/JsonRpc/Service/CampusService.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								app/JsonRpc/Service/CampusService.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | ||||
| <?php | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace App\JsonRpc\Service; | ||||
|  | ||||
| use Aether\AetherCrudService; | ||||
| use Aether\AetherModel; | ||||
| use Aether\AetherValidator; | ||||
| use Aether\Exception\BusinessException; | ||||
| use App\Model\Campus; | ||||
| use App\Validator\CampusValidator; | ||||
| use Hyperf\Di\Annotation\Inject; | ||||
|  | ||||
| class CampusService extends AetherCrudService | ||||
| { | ||||
|     #[Inject] | ||||
|     protected Campus $campusModel; | ||||
|  | ||||
|     #[Inject] | ||||
|     protected CampusValidator $campusValidator; | ||||
|  | ||||
|     /** | ||||
|      * 获取省份列表. | ||||
|      */ | ||||
|     public function getProvinces(): array | ||||
|     { | ||||
|         return $this->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; | ||||
|     } | ||||
| } | ||||
| @@ -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; | ||||
|     } | ||||
| } | ||||
|   | ||||
							
								
								
									
										28
									
								
								app/JsonRpc/Service/TeacherService.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								app/JsonRpc/Service/TeacherService.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | ||||
| <?php | ||||
|  | ||||
| namespace App\JsonRpc\Service; | ||||
|  | ||||
| use Aether\AetherCrudService; | ||||
| use Aether\AetherModel; | ||||
| use Aether\AetherValidator; | ||||
| use App\Model\Teacher; | ||||
| use App\Validator\TeacherValidator; | ||||
| use Hyperf\Di\Annotation\Inject; | ||||
|  | ||||
| class TeacherService extends AetherCrudService | ||||
| { | ||||
|     #[Inject] | ||||
|     protected Teacher $teacherModel; | ||||
|     #[Inject] | ||||
|     protected TeacherValidator $teacherValidator; | ||||
|  | ||||
|     protected function getModel(): AetherModel | ||||
|     { | ||||
|         return $this->teacherModel; | ||||
|     } | ||||
|  | ||||
|     protected function getValidator(): AetherValidator | ||||
|     { | ||||
|         return $this->teacherValidator; | ||||
|     } | ||||
| } | ||||
| @@ -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 ''; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -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 | ||||
|   | ||||
| @@ -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', | ||||
|                 ], | ||||
|   | ||||
| @@ -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(女)', | ||||
|   | ||||
							
								
								
									
										24
									
								
								composer.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										24
									
								
								composer.lock
									
									
									
										generated
									
									
									
								
							| @@ -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" | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Aether
					Aether