DocWaveHeaderService.php 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. <?php
  2. namespace App\Services;
  3. use App\ValueStore;
  4. use Carbon\Carbon;
  5. use Illuminate\Support\Facades\Cache;
  6. use Illuminate\Support\Facades\DB;
  7. use Yajra\Oci8\Query\OracleBuilder;
  8. Class DocWaveHeaderService
  9. {
  10. public function get(array $params, $rule = [])
  11. {
  12. /** @var OracleBuilder $query */
  13. $query = DB::connection("oracle")->table("doc_wave_header")->orderBy("edittime");
  14. foreach ($params as $column=>$param){
  15. if (isset($rule[$column]))$query = $this->rule($query,$rule[$column],$column,$param);
  16. else $query->where($column,$param);
  17. }
  18. return $query->get();
  19. }
  20. private function rule(OracleBuilder $query, $rule, $column, $value)
  21. {
  22. switch ($rule){
  23. case "gtOrEqual":
  24. $query->where($column,">=",$value);
  25. break;
  26. case "gt":
  27. $query->where($column,">",$value);
  28. break;
  29. case "raw":
  30. $query->whereRaw($value);
  31. break;
  32. case "in":
  33. $query->whereIn($column,$value);
  34. break;
  35. }
  36. return $query;
  37. }
  38. public function getSyncDate()
  39. {
  40. $valueStore = ValueStore::query()->where("name","wave_last_sync_date")->first();
  41. return $valueStore->value ?? Carbon::now()->subSeconds(65)->toDateTimeString();
  42. }
  43. public function setSyncDate(string $value)
  44. {
  45. $valueStore = ValueStore::query()->where("name","wave_last_sync_date");
  46. return $valueStore->update(["value"=>$value]);
  47. }
  48. }