2018-10-05 13:53:35 +02:00
|
|
|
package globalplatform
|
2018-10-02 13:25:04 +02:00
|
|
|
|
|
|
|
import (
|
2019-03-01 18:44:07 +01:00
|
|
|
"github.com/status-im/keycard-go/apdu"
|
|
|
|
"github.com/status-im/keycard-go/hexutils"
|
2018-10-02 13:25:04 +02:00
|
|
|
)
|
|
|
|
|
2019-03-05 12:00:23 +01:00
|
|
|
// SecureChannel wraps another channel and sends wrapped commands using SCP02Wrapper.
|
2018-10-02 13:25:04 +02:00
|
|
|
type SecureChannel struct {
|
2018-10-05 13:53:35 +02:00
|
|
|
session *Session
|
2018-10-02 13:25:04 +02:00
|
|
|
c Channel
|
2019-03-05 12:00:23 +01:00
|
|
|
w *SCP02Wrapper
|
2018-10-02 13:25:04 +02:00
|
|
|
}
|
|
|
|
|
2018-10-05 16:40:32 +02:00
|
|
|
// NewSecureChannel returns a new SecureChannel based on a session and wrapping a Channel c.
|
2018-10-05 13:53:35 +02:00
|
|
|
func NewSecureChannel(session *Session, c Channel) *SecureChannel {
|
2018-10-02 13:25:04 +02:00
|
|
|
return &SecureChannel{
|
|
|
|
session: session,
|
|
|
|
c: c,
|
2019-03-06 10:43:37 +01:00
|
|
|
w: NewSCP02Wrapper(session.Keys().Mac()),
|
2018-10-02 13:25:04 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-05 16:40:32 +02:00
|
|
|
// Send sends wrapped commands to the inner channel.
|
2018-10-02 13:25:04 +02:00
|
|
|
func (c *SecureChannel) Send(cmd *apdu.Command) (*apdu.Response, error) {
|
|
|
|
rawCmd, err := cmd.Serialize()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2018-10-05 11:35:56 +02:00
|
|
|
logger.Debug("wrapping apdu command", "hex", hexutils.BytesToHexWithSpaces(rawCmd))
|
2018-10-02 13:25:04 +02:00
|
|
|
wrappedCmd, err := c.w.Wrap(cmd)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return c.c.Send(wrappedCmd)
|
|
|
|
}
|