mirror of
https://github.com/status-im/keycard-go.git
synced 2025-01-23 02:09:05 +00:00
add path arg to sign
This commit is contained in:
parent
d95853db0f
commit
9d48af884d
@ -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
|
||||||
}
|
}
|
||||||
|
18
commands.go
18
commands.go
@ -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,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user