WarehouseService.php 3.6 KB

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