func parseAssignRequest(r *xio.PacketReader) (*assignRequest, error) { var err error yid := uint32(0) if yid, err = r.Read32(); err != nil { return nil, errors.New("assign.read yid") } coolen := uint64(0) if coolen, err = r.Read7BitValue64(); err != nil { return nil, errors.New("assign.read cookie.len") } else if coolen != cookies.CookieSize { return nil, errors.New("assign.bad cookie.len") } coobuf := make([]byte, cookies.CookieSize) if err = r.ReadBytes(coobuf); err != nil { return nil, errors.New("assign.read cookie.value") } size := uint64(0) if size, err = r.Read7BitValue64(); err != nil { return nil, errors.New("assign.read pid.size") } else if size == 0 || size > uint64(r.Len()) { return nil, errors.New("assign.bad pid.size") } pid := sha256.Sum256(r.Bytes()[:size]) if len(pid) != 0x20 { return nil, errors.New("assign.bad pid.len") } if size, err = r.Read7BitValue64(); err != nil { return nil, errors.New("assign.read pubkey.len") } else if size <= 2 { return nil, errors.New("assign.too small pubkey.len") } else { size -= 2 if size > uint64(r.Len()) { return nil, errors.New("assign.too big pubkey.len") } if err := r.Skip(2); err != nil { return nil, errors.New("assign.skip useless") } } pubkey := make([]byte, int(size)) if err = r.ReadBytes(pubkey); err != nil { return nil, errors.New("assign.read pubkey") } if size, err = r.Read7BitValue64(); err != nil { return nil, errors.New("assign.read initiator.len") } else if size == 0 || size > uint64(r.Len()) { return nil, errors.New("assign.bad initiator.len") } initiator := make([]byte, int(size)) if err = r.ReadBytes(initiator); err != nil { return nil, errors.New("assign.read initiator") } return &assignRequest{yid, string(pid[:]), coobuf, pubkey, initiator}, nil }