641a4ab7383dfd8bab0a8de6a16f189fddef0328.svn-base 18 KB

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