Merge pull request #1217 from tgerring/rpcsign

Fix RPC sign
This commit is contained in:
Jeffrey Wilcke 2015-06-09 06:19:39 -07:00
commit 60b780c21b
2 changed files with 74 additions and 13 deletions

View File

@ -172,13 +172,8 @@ type NewSigArgs struct {
} }
func (args *NewSigArgs) UnmarshalJSON(b []byte) (err error) { func (args *NewSigArgs) UnmarshalJSON(b []byte) (err error) {
var obj []json.RawMessage var obj []interface{}
var ext struct {
From string
Data string
}
// Decode byte slice to array of RawMessages
if err := json.Unmarshal(b, &obj); err != nil { if err := json.Unmarshal(b, &obj); err != nil {
return NewDecodeParamError(err.Error()) return NewDecodeParamError(err.Error())
} }
@ -188,21 +183,26 @@ func (args *NewSigArgs) UnmarshalJSON(b []byte) (err error) {
return NewInsufficientParamsError(len(obj), 1) return NewInsufficientParamsError(len(obj), 1)
} }
// Decode 0th RawMessage to temporary struct from, ok := obj[0].(string)
if err := json.Unmarshal(obj[0], &ext); err != nil { if !ok {
return NewDecodeParamError(err.Error()) return NewInvalidTypeError("from", "not a string")
} }
args.From = from
if len(ext.From) == 0 { if len(args.From) == 0 {
return NewValidationError("from", "is required") return NewValidationError("from", "is required")
} }
if len(ext.Data) == 0 { data, ok := obj[1].(string)
if !ok {
return NewInvalidTypeError("data", "not a string")
}
args.Data = data
if len(args.Data) == 0 {
return NewValidationError("data", "is required") return NewValidationError("data", "is required")
} }
args.From = ext.From
args.Data = ext.Data
return nil return nil
} }

View File

@ -2508,3 +2508,64 @@ func TestSourceArgsEmpty(t *testing.T) {
t.Error(str) t.Error(str)
} }
} }
func TestSigArgs(t *testing.T) {
input := `["0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b", "0x0"]`
expected := new(NewSigArgs)
expected.From = "0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b"
expected.Data = "0x0"
args := new(NewSigArgs)
if err := json.Unmarshal([]byte(input), &args); err != nil {
t.Error(err)
}
}
func TestSigArgsEmptyData(t *testing.T) {
input := `["0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b", ""]`
args := new(NewSigArgs)
str := ExpectValidationError(json.Unmarshal([]byte(input), args))
if len(str) > 0 {
t.Error(str)
}
}
func TestSigArgsDataType(t *testing.T) {
input := `["0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b", 13]`
args := new(NewSigArgs)
str := ExpectInvalidTypeError(json.Unmarshal([]byte(input), args))
if len(str) > 0 {
t.Error(str)
}
}
func TestSigArgsEmptyFrom(t *testing.T) {
input := `["", "0x0"]`
args := new(NewSigArgs)
str := ExpectValidationError(json.Unmarshal([]byte(input), args))
if len(str) > 0 {
t.Error(str)
}
}
func TestSigArgsFromType(t *testing.T) {
input := `[false, "0x0"]`
args := new(NewSigArgs)
str := ExpectInvalidTypeError(json.Unmarshal([]byte(input), args))
if len(str) > 0 {
t.Error(str)
}
}
func TestSigArgsEmpty(t *testing.T) {
input := `[]`
args := new(NewSigArgs)
str := ExpectInsufficientParamsError(json.Unmarshal([]byte(input), args))
if len(str) > 0 {
t.Error(str)
}
}