8927283a5f75bd38ca3d712b0fbdb46bf880343f.svn-base 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652
  1. package util
  2. import (
  3. "../../pkg/logging"
  4. "../../pkg/setting"
  5. "../../routers/restful"
  6. "errors"
  7. "fmt"
  8. "strconv"
  9. )
  10. // @Summary 现代牧业EAS对接 备件,出入库
  11. type BillLaid struct { // 销售出库&其它出库 &采购入库 & 其他入库
  12. BizType BillNumber `json:"bizType"` //业务类型
  13. BizDate string `json:"bizDate"` //业务日期
  14. Description string `json:"description"` //摘要
  15. PaymentType BillNumber `json:"paymentType"` // 付款方式
  16. TransactionType BillNumber `json:"transactionType"` // 事务类型
  17. Number string `json:"number"` // 单据编号
  18. Entry []BillEntry `json:"entry"` //
  19. StorageOrgUnit BillNumber `json:"storageOrgUnit"` //库存组织
  20. Supplier BillNumber `json:"supplier"` //供应商
  21. Currency BillNumber `json:"currency"` // 币别
  22. Creator BillNumber `json:"creator"` //创建者
  23. }
  24. type BillNumber struct {
  25. Number string `json:"number"`
  26. }
  27. type BillEntry struct {
  28. ActualPrice string `json:"actualPrice"` //实际单价
  29. ActualTaxPrice string `json:"actualTaxPrice"` //实际含税单价
  30. UnitActualCost string `json:"unitActualCost"` //单位实际成本
  31. UnitPurchaseCost string `json:"unitPurchaseCost"` //单位采购成本
  32. TaxPrice string `json:"taxPrice"` //含税单价
  33. BalanceSupplier BillNumber `json:"balanceSupplier"` //结算供应商
  34. Price string `json:"price"` //单价
  35. ActualCost string `json:"actualCost"` //实际成本
  36. PurchaseCost string `json:"purchaseCost"` //采购成本
  37. Amount string `json:"amount"` // 金额
  38. TaxAmount string `json:"taxAmount"` // 价税合计
  39. ContractNumber string `json:"contractNumber"` // 合同号
  40. Warehouse BillNumber `json:"warehouse"` // 仓库
  41. Unit BillNumber `json:"unit"` // 单位
  42. Material BillNumber `json:"material"` //物料
  43. Qty string `json:"qty"` //数量
  44. StoreType BillNumber`json:"storeType"`//库存类型
  45. StoreStatus BillNumber`json:"storeStatus"`//库存状态
  46. }
  47. type BillUse struct { //领料出库&生产入库
  48. Head BillUseHead `json:"head"`
  49. Entrys []BillUseEntrys `json:"entrys"`
  50. }
  51. type BillUseHead struct {
  52. BillNumber string `json:"billNumber"` //单据编号
  53. BizDate string `json:"bizDate"` //业务日期
  54. BizTypeNumber string `json:"bizTypeNumber"` //业务类型
  55. TransactionType string `json:"transactionType"` //事务类型
  56. Department string `json:"department"` //部门
  57. SupplyStorageOrg string `json:"supplyStorageOrg"` //供方库存组织
  58. StorageOrg string `json:"storageOrg"` //需方库存组织
  59. CostCenter string `json:"costCenter"` //成本中心
  60. Remark string `json:"remark"` //摘要
  61. Creator string `json:"creator"` //创建者
  62. }
  63. type BillUseEntrys struct {
  64. MaterielNumber string `json:"materielNumber"` // 物料
  65. Lot string `json:"lot"` //批次
  66. Amount string `json:"amount"` //数量
  67. MeteredUnit string `json:"meteredUnit"` //单位
  68. WareHouse string `json:"wareHouse"` //需方仓库
  69. Location string `json:"location"` //需方库位
  70. Picker string `json:"picker"` // 领料员
  71. EntryRemark string `json:"entryRemark"` //备注
  72. MasterDepartment string `json:"masterDepartment"` //主制部门
  73. EntryCostCenter string `json:"entryCostCenter"` //成本中心
  74. }
  75. type Parts struct { // 备件
  76. MaterialNumber string `json:"materialNumber"`
  77. MaterialName string `json:"materialName"`
  78. MaterialGroup string `json:"materialGroup"`
  79. Model string `json:"model"`
  80. BaseUnit string `json:"baseUnit"`
  81. Status int `json:"status"`
  82. KaClass string `json:"kaClass"`
  83. //kaClass int32 `json:"kaClass"`
  84. //planningMode int32 `json:"planningMode"`
  85. }
  86. func EASBillSync(typeIN int, billCode interface{}, statue string) error {
  87. defer func() {
  88. if err := recover(); err != nil {
  89. logging.Error("EASBillSync recover err :", err)
  90. }
  91. }()
  92. fmt.Println("++++++++++++++++", typeIN, billCode)
  93. var err error
  94. schema := ""
  95. id := ""
  96. switch typeIN {
  97. case 1: // 入库
  98. schema = "bigpartlaid"
  99. id,err = BigpartLaid(billCode, "syncEASPpartlaid", "006")
  100. case 2: // 出库
  101. schema = "bigpartUse"
  102. id,err = BigpartUse(billCode, "syncEASPpartuse", "100")
  103. case 3,10: //退库
  104. schema = "bigpartquit"
  105. if typeIN == 3{
  106. s,err := restful.Engine.SQL("select id from bigpartquit where useForm=? and issync = 0 order by id limit 1",billCode).QueryString()
  107. if len(s) > 0 && err == nil{
  108. billCode = s[0]["id"]
  109. }
  110. }
  111. id,err = BigpartUse(billCode, "syncEASPpartquit", "100")
  112. case 4: //退货
  113. schema = "bigpartrefund"
  114. id,err = BigpartLaid(billCode, "syncEASPpartrefund", "006")
  115. case 5: //备件
  116. schema = "parts"
  117. id = billCode.(string)
  118. err = CheckEASWebServiceParts(statue, "syncEASParts",billCode.(string))
  119. case 6: //调拨入库&出库
  120. schema = "bigparttransfer"
  121. id,err = BigpartLaid(billCode, "syncEASPpartlaid", "008")
  122. case 7: //仅调拨出库
  123. schema = "bigpartUse"
  124. id,err = BigpartUseTransfer(billCode, "syncEASPpartuse", "009")
  125. default:
  126. return errors.New("未知处理类型")
  127. }
  128. tx := restful.Engine.NewSession()
  129. err1 := tx.Begin()
  130. if err1 != nil {
  131. logging.Error("tx.Begin 事务启动失败__error:", err1)
  132. }
  133. defer func() {
  134. switch {
  135. case err1 != nil:
  136. if tx != nil {
  137. tx.Rollback()
  138. }
  139. default:
  140. if tx != nil {
  141. err = tx.Commit()
  142. }
  143. }
  144. if tx != nil {
  145. tx.Close()
  146. }
  147. }()
  148. if err != nil {
  149. logging.Info("EASBillSync err", err)
  150. fmt.Println("EASBillSync err", err)
  151. sql := "update "+schema+" set msg = ? where id =?"
  152. _,err1 =tx.Exec(sql, err.Error(),id)
  153. return err
  154. }
  155. if id == ""{
  156. return nil
  157. }
  158. sql := "update "+schema+" set issync = 1 where id =?"
  159. _,err1 =tx.Exec(sql, id)
  160. return err
  161. }
  162. func CheckEASWebServiceParts(statue, sqlname,id string) error {
  163. if statue == "1" {
  164. valuesMap, err := restful.Engine.SQL("SELECT sqlstr,params FROM apisql WHERE sqlname = ? limit 1", sqlname).QueryString()
  165. sqls := ""
  166. if err == nil && len(valuesMap) > 0 {
  167. sqls = valuesMap[0]["sqlstr"]
  168. }
  169. ress, err := restful.Engine.SQL(sqls, id).QueryString()
  170. if len(ress) == 0 {
  171. logging.Error("CheckEASWebServiceParts select len is 0", len(ress))
  172. return errors.New("查询结果为空")
  173. }
  174. if err != nil {
  175. logging.Error("CheckEASWebServiceParts select err", err)
  176. return err
  177. }
  178. //
  179. //ress, err := restful.Engine.SQL(`SELECT partCode materialNumber,NAME materialName,
  180. // (SELECT VALUE FROM dictlist WHERE pid = 44 AND label = parts.unit) baseUnit,
  181. // LEFT(partCode,11) materialGroup,specification model
  182. // FROM parts WHERE id = ?`, id).QueryString()
  183. //if len(ress) == 0 {
  184. // logging.Error("CheckEASWebServiceParts select len is 0", len(ress))
  185. // return errors.New("查询结果为空")
  186. //}
  187. //if err != nil {
  188. // logging.Error("CheckEASWebServiceParts select err", err)
  189. // return err
  190. //}
  191. var parts = Parts{}
  192. parts.BaseUnit = ress[0]["baseUnit"]
  193. parts.MaterialGroup = ress[0]["materialGroup"]
  194. parts.MaterialName = ress[0]["materialName"]
  195. parts.MaterialNumber = ress[0]["materialNumber"]
  196. parts.KaClass = ress[0]["kaClass"]
  197. parts.Model = ress[0]["model"]
  198. parts.Status = 0
  199. //sessionid, err := EASWebServiceLogin()
  200. //if err != nil {
  201. // logging.Error("EASWebServiceLogin", err)
  202. // return err
  203. //}
  204. singelChan <- struct{}{}
  205. sessionid := <- sessionidChan
  206. if len(sessionid)<7 || sessionid[:6] == "error:"{
  207. return errors.New("eas登录失败")
  208. }
  209. // 先判断备件与单据是否要分两个地址同步(一个正式线一个测试线)
  210. if setting.ServerSetting.EasUrlTem != ""{
  211. sessionid,err = EASWebServiceLogin(setting.ServerSetting.EasUrlTem)
  212. if err != nil || len(sessionid)<7 {
  213. return errors.New("eas登录失败")
  214. }
  215. }
  216. err = EASWebServicInsertParts(sessionid, parts,setting.ServerSetting.EasUrlTem)
  217. if err != nil {
  218. logging.Error("EASWebServicInsertParts", err)
  219. return err
  220. }
  221. //err = EASWebServiceLogout()
  222. //if err != nil {
  223. // logging.Error("EASWebServiceLogout", err)
  224. //}
  225. }
  226. return nil
  227. //}
  228. }
  229. func BigpartUse(billCode interface{}, sqlname, billType string) (string,error) {
  230. valuesMap, err := restful.Engine.SQL("SELECT sqlstr,params FROM apisql WHERE sqlname = ? limit 1", sqlname).QueryString()
  231. sqls := ""
  232. if err == nil && len(valuesMap) > 0 {
  233. sqls = valuesMap[0]["sqlstr"]
  234. }
  235. ress, err := restful.Engine.SQL(sqls, billCode).QueryString()
  236. if len(ress) == 0 {
  237. logging.Error("BigpartUse select len is 0", len(ress))
  238. return "",errors.New("查询结果为空")
  239. }
  240. if err != nil {
  241. logging.Error("BigpartUse select err", err)
  242. return "",err
  243. }
  244. id := ress[0]["id"]
  245. pu := BillUse{}
  246. pu.Head.BillNumber = ress[0]["BillNumber"]
  247. pu.Head.BizDate = ress[0]["BizDate"]
  248. pu.Head.BizTypeNumber = ress[0]["BizTypeNumber"]
  249. pu.Head.TransactionType = ress[0]["TransactionType"]
  250. pu.Head.Department = ress[0]["Department"]
  251. pu.Head.SupplyStorageOrg = ress[0]["SupplyStorageOrg"]
  252. pu.Head.StorageOrg = ress[0]["StorageOrg"]
  253. pu.Head.Creator = ress[0]["Creator"]
  254. pu.Head.Remark = ress[0]["Remark"]
  255. pu.Head.CostCenter = ress[0]["Department"]
  256. //pu.Head.entryCostCenter
  257. isZeroStock := false //是否零库存
  258. en := make([]BillUseEntrys, len(ress))
  259. count := 0
  260. for key, res := range ress {
  261. if res["isZeroStock"] == "1" {
  262. isZeroStock = true
  263. count ++
  264. }
  265. en[key].Amount = res["Amount"]
  266. en[key].EntryRemark = res["EntryRemark"]
  267. en[key].Lot = res["Lot"]
  268. en[key].MaterielNumber = res["MaterielNumber"]
  269. en[key].MeteredUnit = res["MeteredUnit"]
  270. en[key].Picker = res["Picker"]
  271. en[key].WareHouse = res["WareHouse"]
  272. en[key].Location = res["Location"]
  273. en[key].MasterDepartment = ress[0]["Department"]
  274. en[key].EntryCostCenter = ress[0]["Department"]
  275. //en[key].Location="0202001"
  276. //en[key].WareHouse ="0202001"
  277. }
  278. pu.Entrys = en
  279. pujson, _ := json.Marshal(pu)
  280. //sessionid, err := EASWebServiceLogin()
  281. //if err != nil {
  282. // logging.Error("EASWebServiceLogin", err)
  283. // return id,err
  284. //}
  285. singelChan <- struct{}{}
  286. sessionid := <- sessionidChan
  287. if len(sessionid)<7 || sessionid[:6] == "error:"{
  288. return id,errors.New("eas登录失败")
  289. }
  290. //零库存出库,先进行入库,每个供应商一个入库单
  291. if isZeroStock {
  292. pls := make([]BillLaid, 0)
  293. pl := BillLaid{}
  294. pl.Number = ress[0]["BillNumber"] + "-RK"
  295. pl.TransactionType = BillNumber{
  296. Number: "001",
  297. }
  298. pl.BizDate = ress[0]["BizDate1"]
  299. pl.BizType = BillNumber{
  300. Number: "110",
  301. }
  302. pl.Currency = BillNumber{
  303. Number: "BB01",
  304. }
  305. pl.PaymentType = BillNumber{
  306. Number: "004",
  307. }
  308. pl.StorageOrgUnit = BillNumber{
  309. Number: ress[0]["SupplyStorageOrg"],
  310. }
  311. pl.Supplier = BillNumber{
  312. Number: ress[0]["BalanceSupplier"],
  313. }
  314. pl.Creator = BillNumber{
  315. Number: ress[0]["Creator"],
  316. }
  317. en := make([]BillEntry, 0)
  318. count = 0
  319. temp := ""
  320. cou := 1
  321. code := pl.Number
  322. for _, res := range ress {
  323. if res["isZeroStock"] == "0" {
  324. continue
  325. }
  326. if temp == "" {
  327. temp = res["BalanceSupplier"]
  328. }
  329. if temp != res["BalanceSupplier"]{
  330. pl.Entry = en
  331. pls = append(pls, pl)
  332. pl.Number = code +"-"+ strconv.Itoa(cou)
  333. pl.Supplier = BillNumber{
  334. Number: res["BalanceSupplier"],
  335. }
  336. cou ++
  337. temp = res["BalanceSupplier"]
  338. en = make([]BillEntry, 0)
  339. }
  340. pl.Supplier = BillNumber{
  341. Number: res["BalanceSupplier"],
  342. }
  343. ent := BillEntry{}
  344. ent.Amount = res["SumPrice"]
  345. ent.Qty = res["Amount"]
  346. ent.ActualCost = res["SumPrice"]
  347. ent.ActualPrice = res["Price"]
  348. ent.ActualTaxPrice = res["Price"]
  349. ent.BalanceSupplier = BillNumber{
  350. Number: res["BalanceSupplier"],
  351. }
  352. ent.ContractNumber = res["ContractNumber"]
  353. ent.Material = BillNumber{
  354. Number: res["MaterielNumber"],
  355. }
  356. ent.Price = res["Price"]
  357. ent.PurchaseCost = res["SumPrice"]
  358. ent.TaxAmount = res["SumPrice"]
  359. ent.TaxPrice = res["Price"]
  360. ent.Unit = BillNumber{
  361. Number: res["MeteredUnit"],
  362. }
  363. ent.UnitActualCost = res["SumPrice"]
  364. ent.UnitPurchaseCost = res["Price"]
  365. ent.Warehouse = BillNumber{
  366. Number: res["WareHouse"],
  367. }
  368. en = append(en,ent)
  369. }
  370. pl.Entry = en
  371. pls = append(pls, pl)
  372. pljson, _ := json.Marshal(pls)
  373. //println(string(pljson))
  374. err = EASWebServicInsertPartsuselaid(sessionid, string(pljson), "006")
  375. if err != nil {
  376. logging.Error("EASWebServicInsertPartsuselaid", err)
  377. return id,err
  378. }
  379. }
  380. err = EASWebServicInsertPartsuselaid(sessionid, string(pujson), billType)
  381. if err != nil {
  382. logging.Error("EASWebServicInsertPartsuselaid", err)
  383. return id,err
  384. }
  385. //EASWebServiceLogout()
  386. return id,nil
  387. }
  388. func BigpartUseTransfer(billCode interface{}, sqlname, billType string)(string,error) {
  389. valuesMap, err := restful.Engine.SQL("SELECT sqlstr,params FROM apisql WHERE sqlname = ? limit 1", sqlname).QueryString()
  390. sqls := ""
  391. if err == nil && len(valuesMap) > 0 {
  392. sqls = valuesMap[0]["sqlstr"]
  393. }
  394. ress, err := restful.Engine.SQL(sqls, billCode).QueryString()
  395. if len(ress) == 0 {
  396. logging.Error("BigpartUse select len is 0", len(ress))
  397. return "",errors.New("查询结果为空")
  398. }
  399. if err != nil {
  400. logging.Error("BigpartUse select err", err)
  401. return "",err
  402. }
  403. id := ress[0]["id"]
  404. pus := make([]BillLaid, 0)
  405. pu := BillLaid{}
  406. pu.Number = ress[0]["BillNumber"]
  407. pu.TransactionType = BillNumber{
  408. Number: ress[0]["TransactionType"],
  409. }
  410. pu.BizDate = ress[0]["BizDate1"]
  411. pu.BizType = BillNumber{
  412. Number: ress[0]["BizTypeNumber"],
  413. }
  414. pu.Currency = BillNumber{
  415. Number: "BB01",
  416. }
  417. pu.PaymentType = BillNumber{
  418. Number: ress[0]["PaymentType"],
  419. }
  420. pu.StorageOrgUnit = BillNumber{
  421. Number: ress[0]["SupplyStorageOrg"],
  422. }
  423. pu.Supplier = BillNumber{
  424. Number: ress[0]["BalanceSupplier"],
  425. }
  426. pu.Description = ress[0]["Description"]
  427. pu.Creator = BillNumber{
  428. Number: ress[0]["Creator"],
  429. }
  430. en := make([]BillEntry, len(ress))
  431. isZeroStock := false
  432. for key, res := range ress {
  433. //if res["isZeroStock"] == "1" {
  434. // continue
  435. //} else {
  436. isZeroStock = true
  437. //}
  438. en[key].Amount = res["SumPrice"]
  439. en[key].Qty = res["Amount"]
  440. en[key].ActualCost = res["SumPrice"]
  441. en[key].ActualPrice = res["Price"]
  442. en[key].ActualTaxPrice = res["Price"]
  443. en[key].BalanceSupplier = BillNumber{
  444. Number: res["BalanceSupplier"],
  445. }
  446. en[key].ContractNumber = res["ContractNumber"]
  447. en[key].Material = BillNumber{
  448. Number: res["MaterielNumber"],
  449. }
  450. en[key].Price = res["Price"]
  451. en[key].PurchaseCost = res["SumPrice"]
  452. en[key].TaxAmount = res["SumPrice"]
  453. en[key].TaxPrice = res["Price"]
  454. en[key].Unit = BillNumber{
  455. Number: res["MeteredUnit"],
  456. }
  457. en[key].UnitActualCost = res["SumPrice"]
  458. en[key].UnitPurchaseCost = res["Price"]
  459. en[key].Warehouse = BillNumber{
  460. Number: res["WareHouse"],
  461. }
  462. en[key].StoreType= BillNumber{
  463. Number: "G",
  464. }
  465. en[key].StoreStatus= BillNumber{
  466. Number: "1",
  467. }
  468. }
  469. if isZeroStock {
  470. pu.Entry = en
  471. pus = append(pus, pu)
  472. pujson, _ := json.Marshal(pus)
  473. //sessionid, err := EASWebServiceLogin()
  474. //if err != nil {
  475. // logging.Error("EASWebServiceLogin", err)
  476. // return err
  477. //}
  478. singelChan <- struct{}{}
  479. sessionid := <- sessionidChan
  480. if len(sessionid)<7 || sessionid[:6] == "error:"{
  481. return id,errors.New("eas登录失败")
  482. }
  483. err = EASWebServicInsertPartsuselaid(sessionid, string(pujson), billType)
  484. if err != nil {
  485. logging.Error("EASWebServicInsertPartsuselaid", err)
  486. return id,err
  487. }
  488. //EASWebServiceLogout()
  489. }
  490. tx := restful.Engine.NewSession()
  491. err = tx.Begin()
  492. if err != nil {
  493. logging.Error("tx.Begin 事务启动失败__error:", err)
  494. }
  495. defer func() {
  496. switch {
  497. case err != nil:
  498. fmt.Println("__error:", err)
  499. if tx != nil {
  500. tx.Rollback()
  501. }
  502. default:
  503. if tx != nil {
  504. err = tx.Commit()
  505. }
  506. }
  507. if tx != nil {
  508. tx.Close()
  509. }
  510. }()
  511. sql := "update bigpartUse set issync = 1 where id =?"
  512. _,err =tx.Exec(sql, id)
  513. return id,err
  514. }
  515. func BigpartLaid(billCode interface{}, sqlname, billtype string) (string,error ) {
  516. valuesMap, err := restful.Engine.SQL("SELECT sqlstr,params FROM apisql WHERE sqlname = ? limit 1", sqlname).QueryString() //"syncEASPpartlaid"
  517. sqls := ""
  518. if err == nil && len(valuesMap) > 0 {
  519. sqls = valuesMap[0]["sqlstr"]
  520. }
  521. ress, err := restful.Engine.SQL(sqls, billCode).QueryString()
  522. if len(ress) == 0 {
  523. logging.Error("BigpartLaid select len is 0", len(ress))
  524. return "",errors.New("查询结果为空")
  525. }
  526. if err != nil {
  527. logging.Error("BigpartLaid select err", err)
  528. return "",err
  529. }
  530. id := ress[0]["id"]
  531. pls := make([]BillLaid, 0)
  532. pl := BillLaid{}
  533. pl.Number = ress[0]["BillNumber"]
  534. pl.TransactionType = BillNumber{
  535. Number: ress[0]["TransactionType"],
  536. }
  537. pl.BizDate = ress[0]["BizDate"]
  538. pl.BizType = BillNumber{
  539. Number: ress[0]["BizType"],
  540. }
  541. pl.Currency = BillNumber{
  542. Number: ress[0]["Currency"],
  543. }
  544. pl.PaymentType = BillNumber{
  545. Number: ress[0]["PaymentType"],
  546. }
  547. pl.StorageOrgUnit = BillNumber{
  548. Number: ress[0]["StorageOrgUnit"],
  549. }
  550. pl.Supplier = BillNumber{
  551. Number: ress[0]["BalanceSupplier"],
  552. }
  553. pl.Description = ress[0]["Description"]
  554. pl.Creator = BillNumber{
  555. Number: ress[0]["Creator"],
  556. }
  557. en := make([]BillEntry, len(ress))
  558. isZeroStock := false
  559. for key, res := range ress { // 零库存入库跳过
  560. if res["isZeroStock"] == "1" {
  561. continue
  562. } else {
  563. isZeroStock = true
  564. }
  565. pl.Supplier = BillNumber{
  566. Number: res["BalanceSupplier"],
  567. }
  568. en[key].Amount = res["Amount"]
  569. en[key].Qty = res["Qty"]
  570. en[key].ActualCost = res["ActualCost"]
  571. en[key].ActualPrice = res["ActualPrice"]
  572. en[key].ActualTaxPrice = res["ActualTaxPrice"]
  573. en[key].BalanceSupplier = BillNumber{
  574. Number: res["BalanceSupplier"],
  575. }
  576. en[key].ContractNumber = res["ContractNumber"]
  577. en[key].Material = BillNumber{
  578. Number: res["Material"],
  579. }
  580. en[key].Price = res["Price"]
  581. en[key].PurchaseCost = res["PurchaseCost"]
  582. en[key].TaxAmount = res["TaxAmount"]
  583. en[key].TaxPrice = res["TaxPrice"]
  584. en[key].Unit = BillNumber{
  585. Number: res["Unit"],
  586. }
  587. en[key].UnitActualCost = res["UnitActualCost"]
  588. en[key].UnitPurchaseCost = res["UnitPurchaseCost"]
  589. en[key].Warehouse = BillNumber{
  590. Number: res["Warehouse"],
  591. }
  592. }
  593. if isZeroStock {
  594. pl.Entry = en
  595. pls = append(pls, pl)
  596. pujson, _ := json.Marshal(pls)
  597. //sessionid, err := EASWebServiceLogin()
  598. //if err != nil {
  599. // logging.Error("EASWebServiceLogin", err)
  600. // return id,err
  601. //}
  602. singelChan <- struct{}{}
  603. sessionid := <- sessionidChan
  604. if len(sessionid)<7 || sessionid[:6] == "error:"{
  605. return id,errors.New("eas登录失败")
  606. }
  607. err = EASWebServicInsertPartsuselaid(sessionid, string(pujson), billtype)
  608. if err != nil {
  609. logging.Error("EASWebServicInsertPartsuselaid", err)
  610. return id,err
  611. }
  612. if billtype == "008" { // 为调拨入库时
  613. _,err = BigpartUseTransfer(ress[0]["useCode"], "syncEASPpartuse", "009")
  614. }
  615. //err = EASWebServiceLogout()
  616. //if err != nil {
  617. // fmt.Println("EASWebServiceLogout",err)
  618. //}
  619. }
  620. return id,nil
  621. }