WarehouseService.php 3.7 KB

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