refactor(app): 优化邮件模板

master
cody 3 months ago
parent 1fc528a2e3
commit 3a8b3f9e9a

@ -85,48 +85,83 @@ class MeetRepository
*/ */
public function appointment($model, $appointmentConfig, &$out) public function appointment($model, $appointmentConfig, &$out)
{ {
$startDateTime = new \DateTime($model->start_time);
$endDateTime = new \DateTime($model->end_time);
$meetOther = json_decode($appointmentConfig->room, true); $meetOther = json_decode($appointmentConfig->room, true);
$url = $this->baseUrl . '/services/api/BookingService.aspx'; $url = $this->baseUrl . '/services/api/BookingService.aspx';
$header[] = 'Content-Type: application/json'; $header[] = 'Content-Type: application/json';
$allMeetIds = [];
$allResults = [];
$currentDate = clone $startDateTime;
while ($currentDate->format('Y-m-d') <= $endDateTime->format('Y-m-d')) {
$dayStart = clone $currentDate;
$dayEnd = clone $currentDate;
$dayEnd->setTime(23, 59, 59);
if ($currentDate->format('Y-m-d') === $startDateTime->format('Y-m-d')) {
$dayStart = clone $startDateTime;
}
if ($currentDate->format('Y-m-d') === $endDateTime->format('Y-m-d')) {
$dayEnd = clone $endDateTime;
}
$params = [ $params = [
'account' => $this->account, 'account' => $this->account,
'password' => md5($this->password), 'password' => md5($this->password),
'roomName' => $appointmentConfig->name, 'roomName' => $appointmentConfig->name,
'roomCode' => $meetOther['code'], 'roomCode' => $meetOther['code'],
'roomAddress' => $meetOther['address'], 'roomAddress' => $meetOther['address'],
'beginTime' => $model->start_time, 'beginTime' => $dayStart->format('Y-m-d H:i:s'),
'endTime' => $model->end_time, 'endTime' => $dayEnd->format('Y-m-d H:i:s'),
'speaker' => $model->name, 'speaker' => $model->name,
'subject' => empty($model->content) ? '预约会议室' : $model->content, 'subject' => empty($model->content) ? '预约会议室' : $model->content,
'booker' => "{$model->name};{$model->mobile};", 'booker' => "{$model->name};{$model->mobile};",
'attendance' => "{$model->name};{$model->mobile};", 'attendance' => "{$model->name};{$model->mobile};",
'signUrl' => '' 'signUrl' => ''
]; ];
$result = []; $result = [];
$finally = 0; $finally = 0;
try { try {
$resultJson = httpCurl($url, 'GET', $params, $header); $resultJson = httpCurl($url, 'GET', $params, $header);
$out = $resultJson;
$result = json_decode($resultJson, true); $result = json_decode($resultJson, true);
if ($result['success']) { if ($result['success']) {
$finally = 1; $finally = 1;
$meetIds = explode(',', $model->meet_id); $allMeetIds[] = $result['data'];
array_push($meetIds, $result['data']); $allResults[] = $result;
$meetIds = array_filter($meetIds); ThirdAppointmentLog::add($model->id, 0, $model->user_id, $url, $params, $result, $finally, '会议室预约-' . $currentDate->format('Y-m-d'));
$model->meet_id = implode(',', $meetIds);
$model->save();
ThirdAppointmentLog::add($model->id, 0, $model->user_id, $url, $params, $result, $finally, '会议室预约');
return true;
} else { } else {
$out = $resultJson; $out = $resultJson;
ThirdAppointmentLog::add($model->id, 0, $model->user_id, $url, $params, $result, $finally, '会议室预约'); ThirdAppointmentLog::add($model->id, 0, $model->user_id, $url, $params, $result, $finally, '会议室预约-' . $currentDate->format('Y-m-d'));
return false; return false;
} }
} catch (\Exception $e) { } catch (\Exception $e) {
$out = $e->getMessage(); $out = $e->getMessage();
ThirdAppointmentLog::add($model->id, 0, $model->user_id, $url, $params, $result, $finally, '会议室预约'); ThirdAppointmentLog::add($model->id, 0, $model->user_id, $url, $params, $result, $finally, '会议室预约-' . $currentDate->format('Y-m-d'));
return false; return false;
} }
$currentDate->modify('+1 day');
}
if (!empty($allMeetIds)) {
$meetIds = explode(',', $model->meet_id);
$meetIds = array_merge($meetIds, $allMeetIds);
$meetIds = array_filter($meetIds);
$model->meet_id = implode(',', $meetIds);
$model->save();
$out = json_encode($allResults, JSON_UNESCAPED_UNICODE);
return true;
}
return false;
} }
/** /**

Loading…
Cancel
Save