You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

common_global_end_request_codec.go 1.9 kB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. /*
  2. * Licensed to the Apache Software Foundation (ASF) under one or more
  3. * contributor license agreements. See the NOTICE file distributed with
  4. * this work for additional information regarding copyright ownership.
  5. * The ASF licenses this file to You under the Apache License, Version 2.0
  6. * (the "License"); you may not use this file except in compliance with
  7. * the License. You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. */
  17. package codec
  18. import (
  19. "github.com/fagongzi/goetty"
  20. )
  21. import (
  22. "github.com/seata/seata-go/pkg/protocol/message"
  23. )
  24. type CommonGlobalEndRequestCodec struct {
  25. }
  26. func (c *CommonGlobalEndRequestCodec) Encode(in interface{}) []byte {
  27. req, _ := in.(message.AbstractGlobalEndRequest)
  28. buf := goetty.NewByteBuf(0)
  29. Write16String(req.Xid, buf)
  30. Write16String(string(req.ExtraData), buf)
  31. return buf.RawBuf()
  32. }
  33. func (c *CommonGlobalEndRequestCodec) Decode(in []byte) interface{} {
  34. res := message.AbstractGlobalEndRequest{}
  35. buf := goetty.NewByteBuf(len(in))
  36. buf.Write(in)
  37. var xidLen int
  38. if buf.Readable() >= 2 {
  39. xidLen = int(ReadUInt16(buf))
  40. }
  41. if buf.Readable() >= xidLen {
  42. xidBytes := make([]byte, xidLen)
  43. xidBytes = Read(buf, xidBytes)
  44. res.Xid = string(xidBytes)
  45. }
  46. var extraDataLen int
  47. if buf.Readable() >= 2 {
  48. extraDataLen = int(ReadUInt16(buf))
  49. }
  50. if buf.Readable() >= extraDataLen {
  51. extraDataBytes := make([]byte, xidLen)
  52. extraDataBytes = Read(buf, extraDataBytes)
  53. res.ExtraData = extraDataBytes
  54. }
  55. return res
  56. }

Go Implementation For Seata