WarehouseService.php 3.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <?php
  2. namespace App\Services;
  3. use App\OracleBasCustomer;
  4. use App\Owner;
  5. use App\Warehouse;
  6. use Illuminate\Support\Collection;
  7. use Carbon\Carbon;
  8. use Illuminate\Support\Facades\Cache;
  9. use App\Traits\ServiceAppAop;
  10. Class WarehouseService
  11. {
  12. use ServiceAppAop;
  13. /** @var CacheService $cacheService */
  14. private $cacheService;
  15. function __construct(){
  16. $this->instant($this->cacheService,'CacheService');
  17. }
  18. public function getSelection($column = ['id', 'name'])
  19. {
  20. return Warehouse::query()->select($column)->get();
  21. }
  22. public function firstOrCreate(array $params, array $values = null)
  23. {
  24. if ($values) return Warehouse::query()->firstOrCreate($params, $values);
  25. return Warehouse::query()->firstOrCreate($params);
  26. }
  27. public function getByWmsOrders($orderHeaders)
  28. {
  29. $wareHouse_Ids=array_diff(array_unique(data_get($orderHeaders,'*.warehouseid')),['',' ','*',null]);
  30. $wareHouses=Warehouse::query()->whereIn('code',$wareHouse_Ids)->get();
  31. if(count($wareHouse_Ids)>$wareHouses->count()){
  32. $需要添加_仓库编码=[];
  33. foreach ($wareHouse_Ids as $warehouse_id) {
  34. if($wareHouses->where('code')->count()==0){
  35. $需要添加_仓库编码[]=$warehouse_id;
  36. }
  37. }
  38. $create_wareHouse=$this->syncWmsWareHouse($需要添加_仓库编码);
  39. $wareHouses = $wareHouses->concat($create_wareHouse ?? []);
  40. }
  41. return $wareHouses;
  42. }
  43. public function syncWmsWareHouse($warehouse_ids)
  44. {
  45. $collet = new Collection();
  46. if(!$warehouse_ids)return null;
  47. /** @var Collection $oracleBasCustomers */
  48. $oracleBasCustomers=app(OracleBasCustomerService::class)->getWareHouse($warehouse_ids);
  49. $warehouses=Warehouse::query()->whereIn('code',data_get($oracleBasCustomers,'*.customerid'))->get();
  50. $oracleBasCustomers=$oracleBasCustomers->filter(function($oracleBasCustomer)use($warehouses){
  51. return $warehouses->where('code',$oracleBasCustomer->warehouseid)->count()==0;
  52. });
  53. foreach ($oracleBasCustomers as $oracleBasCustomer){
  54. $params =[
  55. 'code' => $oracleBasCustomer->customerid,
  56. 'name' => $oracleBasCustomer->descr_c
  57. ];
  58. try {
  59. $wereHouse = Warehouse::query()->create($params);
  60. $collet->push($wereHouse);
  61. app('LogService')->log(__METHOD__,__FUNCTION__,'创建 warehouse success'.json_encode($wereHouse));
  62. } catch (\Exception $e) {
  63. app('LogService')->log(__METHOD__,__FUNCTION__,'创建 warehouse error'.json_encode($params).json_encode($e->getMessage()));
  64. }
  65. }
  66. return $collet;
  67. }
  68. public function insert($fillables){
  69. return Warehouse::query()->insert($fillables);
  70. }
  71. public function getWareHouseByCodes($codes)
  72. {
  73. $collect = collect();
  74. if(count($codes)==0)return $collect;
  75. foreach ($codes as $code) {
  76. $collect->push($this->getWareHouseByCode($code));
  77. }
  78. return $collect;
  79. }
  80. public function getWareHouseByCode($code){
  81. return Cache::remember("WareHouse_{$code}",config('cache.expirations.warehouse'),function()use($code){
  82. $wareHouse = Warehouse::query()->where('code',$code)->first();
  83. if($wareHouse)return $wareHouse;
  84. return null;
  85. });
  86. }
  87. }