order('sort', 'asc') ->field('id, name, nickname, sex, avatar, birth, height, weight, status, create_time, update_time') ->select() ->toArray(); // 记录操作日志 $this->logSuccess('宝贝管理', '获取宝贝信息', ['data' => $babylist]); return json([ 'code' => 200, 'msg' => '获取成功', 'data' => $babylist ]); } catch (DbException $e) { // 记录失败日志 $this->logFail('宝贝管理', '获取宝贝信息', $e->getMessage()); return json([ 'code' => 500, 'msg' => '获取失败:' . $e->getMessage(), 'data' => [] ]); } } /** * 创建宝贝信息 * @return Json */ public function createBaby() { try { // 获取请求参数 $data = $this->request->param(); // 准备宝贝数据 $babyData = [ 'name' => $data['name'], 'nickname' => $data['nickname'], 'sex' => $data['sex'], 'birth' => $data['birth'], 'height' => $data['height'], 'weight' => $data['weight'], 'avatar' => $data['avatar'], 'status' => $data['status'], 'create_time' => date('Y-m-d H:i:s'), ]; // 创建宝贝信息 $result = AppsBabys::insertGetId($babyData); if ($result === false) { return json([ 'code' => 500, 'msg' => '创建失败' ]); } // 记录操作日志 $this->logSuccess('宝贝管理', '创建宝贝信息', ['id' => $result]); return json([ 'code' => 200, 'msg' => '创建成功', 'data' => ['id' => $result] ]); } catch (ValidateException $e) { // 记录失败日志 $this->logFail('宝贝管理', '创建宝贝信息', $e->getMessage()); return json([ 'code' => 400, 'msg' => $e->getError() ]); } catch (DbException $e) { // 记录失败日志 $this->logFail('宝贝管理', '创建宝贝信息', $e->getMessage()); return json([ 'code' => 500, 'msg' => '创建失败:' . $e->getMessage() ]); } } /** * 编辑宝贝信息 * @param int $id Baby ID * @return Json */ public function editBaby(int $id) { try { // 获取请求参数 $data = $this->request->param(); // 检查宝贝信息是否存在 $baby = AppsBabys::where('id', $id) ->where('delete_time', null) ->find(); if (!$baby) { return json([ 'code' => 404, 'msg' => '宝贝信息不存在' ]); } // 准备更新数据 $updateData = [ 'name' => $data['name'], 'nickname' => $data['nickname'], 'sex' => $data['sex'], 'birth' => $data['birth'], 'height' => $data['height'], 'weight' => $data['weight'], 'avatar' => $data['avatar'], 'status' => $data['status'], 'update_time' => date('Y-m-d H:i:s'), ]; // 执行更新 AppsBabys::where('id', $id)->update($updateData); // 获取更新后的宝贝信息 $updatedBaby = AppsBabys::where('id', $id)->find(); // 记录操作日志 $this->logSuccess('宝贝管理', '更新宝贝信息', ['id' => $id]); return json([ 'code' => 200, 'msg' => '更新成功', 'data' => $updatedBaby ? $updatedBaby->toArray() : [] ]); } catch (ValidateException $e) { // 记录失败日志 $this->logFail('宝贝管理', '更新宝贝信息', $e->getMessage()); return json([ 'code' => 400, 'msg' => $e->getError() ]); } catch (DbException $e) { // 记录失败日志 $this->logFail('宝贝管理', '更新宝贝信息', $e->getMessage()); return json([ 'code' => 500, 'msg' => '更新失败:' . $e->getMessage() ]); } } /** * 删除宝贝信息 * @param int $id Baby ID * @return Json */ public function deleteBaby(int $id) { try { // 检查宝贝信息是否存在 $baby = AppsBabys::where('id', $id) ->where('delete_time', null) ->find(); if (!$baby) { return json([ 'code' => 404, 'msg' => '宝贝信息不存在' ]); } // 逻辑删除宝贝信息 $result = AppsBabys::where('id', $id) ->where('delete_time', null) ->update([ 'delete_time' => date('Y-m-d H:i:s'), 'update_time' => date('Y-m-d H:i:s') ]); if ($result === false) { return json([ 'code' => 500, 'msg' => '删除失败' ]); } // 记录操作日志 $this->logSuccess('宝贝管理', '删除宝贝信息', ['id' => $id]); return json([ 'code' => 200, 'msg' => '删除成功' ]); } catch (DbException $e) { // 记录失败日志 $this->logFail('宝贝管理', '删除宝贝信息', $e->getMessage()); return json([ 'code' => 500, 'msg' => '删除失败:' . $e->getMessage() ]); } } }