add path arg to sign

This commit is contained in:
Andrea Franz 2019-11-14 12:46:15 +01:00
parent d95853db0f
commit 9d48af884d
No known key found for this signature in database
GPG Key ID: 4F0D2F2D9DE7F29D
2 changed files with 33 additions and 3 deletions

View File

@ -269,7 +269,21 @@ func (cs *CommandSet) SetPinlessPath(path string) error {
} }
func (cs *CommandSet) Sign(data []byte) (*types.Signature, error) { func (cs *CommandSet) Sign(data []byte) (*types.Signature, error) {
cmd, err := NewCommandSign(data, P1SignCurrentKey) cmd, err := NewCommandSign(data, P1SignCurrentKey, "")
if err != nil {
return nil, err
}
resp, err := cs.sc.Send(cmd)
if err = cs.checkOK(resp, err); err != nil {
return nil, err
}
return types.ParseSignature(data, resp.Data)
}
func (cs *CommandSet) SignWithPath(data []byte, path string) (*types.Signature, error) {
cmd, err := NewCommandSign(data, P1SignDerive, path)
if err != nil { if err != nil {
return nil, err return nil, err
} }
@ -283,7 +297,7 @@ func (cs *CommandSet) Sign(data []byte) (*types.Signature, error) {
} }
func (cs *CommandSet) SignPinless(data []byte) (*types.Signature, error) { func (cs *CommandSet) SignPinless(data []byte) (*types.Signature, error) {
cmd, err := NewCommandSign(data, P1SignPinless) cmd, err := NewCommandSign(data, P1SignPinless, "")
if err != nil { if err != nil {
return nil, err return nil, err
} }

View File

@ -270,11 +270,27 @@ func NewCommandSetPinlessPath(pathStr string) (*apdu.Command, error) {
), nil ), nil
} }
func NewCommandSign(data []byte, p1 uint8) (*apdu.Command, error) { func NewCommandSign(data []byte, p1 uint8, pathStr string) (*apdu.Command, error) {
if len(data) != 32 { if len(data) != 32 {
return nil, fmt.Errorf("data length must be 32, got %d", len(data)) return nil, fmt.Errorf("data length must be 32, got %d", len(data))
} }
if p1 == P1SignDerive || p1 == P1SignDeriveAndMakeCurrent {
_, path, err := derivationpath.Decode(pathStr)
if err != nil {
return nil, err
}
pathData := new(bytes.Buffer)
for _, segment := range path {
if err := binary.Write(pathData, binary.BigEndian, segment); err != nil {
return nil, err
}
}
data = append(data, pathData.Bytes()...)
}
return apdu.NewCommand( return apdu.NewCommand(
globalplatform.ClaGp, globalplatform.ClaGp,
InsSign, InsSign,