| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388 |
- <?php
- namespace service\cron;
- use Jenssegers\Date\Date;
- //共用的一些属性和方法提取出来做来公共trait类
- trait ManagesFrequencies
- {
- /**
- * 设置任务执行周期
- *
- * @param string $expression
- * @return $this
- */
- public function expression($expression)
- {
- $this->expression = $expression;
- return $this;
- }
- /**
- * 设置区间时间
- *
- * @param string $startTime
- * @param string $endTime
- * @return $this
- */
- public function between($startTime, $endTime)
- {
- return $this->when($this->inTimeInterval($startTime, $endTime));
- }
- /**
- * 排除区间时间
- *
- * @param string $startTime
- * @param string $endTime
- * @return $this
- */
- public function unlessBetween($startTime, $endTime)
- {
- return $this->skip($this->inTimeInterval($startTime, $endTime));
- }
- private function inTimeInterval($startTime, $endTime)
- {
- return function () use ($startTime, $endTime) {
- return Date::now($this->timezone)->between(
- Date::parse($startTime, $this->timezone),
- Date::parse($endTime, $this->timezone),
- true
- );
- };
- }
- /**
- * 按小时执行
- *
- * @return $this
- */
- public function hourly()
- {
- return $this->spliceIntoPosition(1, 0);
- }
- /**
- * 按小时延期执行
- *
- * @param int $offset
- * @return $this
- */
- public function hourlyAt($offset)
- {
- return $this->spliceIntoPosition(1, $offset);
- }
- /**
- * 按天执行
- *
- * @return $this
- */
- public function daily()
- {
- return $this->spliceIntoPosition(1, 0)
- ->spliceIntoPosition(2, 0);
- }
- /**
- * 指定时间执行
- *
- * @param string $time
- * @return $this
- */
- public function at($time)
- {
- return $this->dailyAt($time);
- }
- /**
- * 指定时间执行
- *
- * @param string $time
- * @return $this
- */
- public function dailyAt($time)
- {
- $segments = explode(':', $time);
- return $this->spliceIntoPosition(2, (int) $segments[0])
- ->spliceIntoPosition(1, count($segments) == 2 ? (int) $segments[1] : '0');
- }
- /**
- * 每天执行两次
- *
- * @param int $first
- * @param int $second
- * @return $this
- */
- public function twiceDaily($first = 1, $second = 13)
- {
- $hours = $first . ',' . $second;
- return $this->spliceIntoPosition(1, 0)
- ->spliceIntoPosition(2, $hours);
- }
- /**
- * 工作日执行
- *
- * @return $this
- */
- public function weekdays()
- {
- return $this->spliceIntoPosition(5, '1-5');
- }
- /**
- * 周末执行
- *
- * @return $this
- */
- public function weekends()
- {
- return $this->spliceIntoPosition(5, '0,6');
- }
- /**
- * 星期一执行
- *
- * @return $this
- */
- public function mondays()
- {
- return $this->days(1);
- }
- /**
- * 星期二执行
- *
- * @return $this
- */
- public function tuesdays()
- {
- return $this->days(2);
- }
- /**
- * 星期三执行
- *
- * @return $this
- */
- public function wednesdays()
- {
- return $this->days(3);
- }
- /**
- * 星期四执行
- *
- * @return $this
- */
- public function thursdays()
- {
- return $this->days(4);
- }
- /**
- * 星期五执行
- *
- * @return $this
- */
- public function fridays()
- {
- return $this->days(5);
- }
- /**
- * 星期六执行
- *
- * @return $this
- */
- public function saturdays()
- {
- return $this->days(6);
- }
- /**
- * 星期天执行
- *
- * @return $this
- */
- public function sundays()
- {
- return $this->days(0);
- }
- /**
- * 按周执行
- *
- * @return $this
- */
- public function weekly()
- {
- return $this->spliceIntoPosition(1, 0)
- ->spliceIntoPosition(2, 0)
- ->spliceIntoPosition(5, 0);
- }
- /**
- * 指定每周的时间执行
- *
- * @param int $day
- * @param string $time
- * @return $this
- */
- public function weeklyOn($day, $time = '0:0')
- {
- $this->dailyAt($time);
- return $this->spliceIntoPosition(5, $day);
- }
- /**
- * 按月执行
- *
- * @return $this
- */
- public function monthly()
- {
- return $this->spliceIntoPosition(1, 0)
- ->spliceIntoPosition(2, 0)
- ->spliceIntoPosition(3, 1);
- }
- /**
- * 指定每月的执行时间
- *
- * @param int $day
- * @param string $time
- * @return $this
- */
- public function monthlyOn($day = 1, $time = '0:0')
- {
- $this->dailyAt($time);
- return $this->spliceIntoPosition(3, $day);
- }
- /**
- * 每月执行两次
- *
- * @param int $first
- * @param int $second
- * @return $this
- */
- public function twiceMonthly($first = 1, $second = 16)
- {
- $days = $first . ',' . $second;
- return $this->spliceIntoPosition(1, 0)
- ->spliceIntoPosition(2, 0)
- ->spliceIntoPosition(3, $days);
- }
- /**
- * 按季度执行
- *
- * @return $this
- */
- public function quarterly()
- {
- return $this->spliceIntoPosition(1, 0)
- ->spliceIntoPosition(2, 0)
- ->spliceIntoPosition(3, 1)
- ->spliceIntoPosition(4, '*/3');
- }
- /**
- * 按年执行
- *
- * @return $this
- */
- public function yearly()
- {
- return $this->spliceIntoPosition(1, 0)
- ->spliceIntoPosition(2, 0)
- ->spliceIntoPosition(3, 1)
- ->spliceIntoPosition(4, 1);
- }
- /**
- * 每分钟执行
- *
- * @return $this
- */
- public function everyMinute()
- {
- return $this->spliceIntoPosition(1, '*');
- }
- /**
- * 每5分钟执行
- *
- * @return $this
- */
- public function everyFiveMinutes()
- {
- return $this->spliceIntoPosition(1, '*/5');
- }
- /**
- * 每10分钟执行
- *
- * @return $this
- */
- public function everyTenMinutes()
- {
- return $this->spliceIntoPosition(1, '*/10');
- }
- /**
- * 每30分钟执行
- *
- * @return $this
- */
- public function everyThirtyMinutes()
- {
- return $this->spliceIntoPosition(1, '0,30');
- }
- /**
- * 按周设置天执行
- *
- * @param array|mixed $days
- * @return $this
- */
- public function days($days)
- {
- $days = is_array($days) ? $days : func_get_args();
- return $this->spliceIntoPosition(5, implode(',', $days));
- }
- /**
- * 设置时区
- *
- * @param \DateTimeZone|string $timezone
- * @return $this
- */
- public function timezone($timezone)
- {
- $this->timezone = $timezone;
- return $this;
- }
- protected function spliceIntoPosition($position, $value)
- {
- $segments = explode(' ', $this->expression);
- $segments[$position - 1] = $value;
- return $this->expression(implode(' ', $segments));
- }
- }
|