Skip to content

Commit

Permalink
control: pluggable segment signer (scionproto#4460)
Browse files Browse the repository at this point in the history
Make the segment signer pluggable. This decouples the beacon extender
from the trust signer implementation and allows plugging in different
implementations.
  • Loading branch information
oncilla authored Dec 29, 2023
1 parent 0871860 commit e476aa8
Show file tree
Hide file tree
Showing 6 changed files with 32 additions and 15 deletions.
2 changes: 1 addition & 1 deletion control/beaconing/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ go_library(
"//pkg/private/prom:go_default_library",
"//pkg/private/serrors:go_default_library",
"//pkg/private/util:go_default_library",
"//pkg/proto/crypto:go_default_library",
"//pkg/segment:go_default_library",
"//pkg/segment/extensions/digest:go_default_library",
"//pkg/segment/extensions/epic:go_default_library",
Expand All @@ -37,7 +38,6 @@ go_library(
"//private/segment/verifier:go_default_library",
"//private/topology:go_default_library",
"//private/tracing:go_default_library",
"//private/trust:go_default_library",
"@com_github_opentracing_opentracing_go//:go_default_library",
],
)
Expand Down
21 changes: 16 additions & 5 deletions control/beaconing/extender.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,17 +26,28 @@ import (
"github.com/scionproto/scion/pkg/metrics"
"github.com/scionproto/scion/pkg/private/serrors"
"github.com/scionproto/scion/pkg/private/util"
cryptopb "github.com/scionproto/scion/pkg/proto/crypto"
seg "github.com/scionproto/scion/pkg/segment"
"github.com/scionproto/scion/pkg/segment/extensions/digest"
"github.com/scionproto/scion/pkg/segment/extensions/epic"
"github.com/scionproto/scion/pkg/slayers/path"
"github.com/scionproto/scion/private/trust"
)

// SignerGen generates signers and returns their expiration time.
type SignerGen interface {
// Generate generates a signer it.
Generate(ctx context.Context) (trust.Signer, error)
Generate(ctx context.Context) (Signer, error)
}

type Signer interface {
Sign(context.Context, []byte, ...[]byte) (*cryptopb.SignedMessage, error)
GetExpiration() time.Time
}

type SignerGenFunc func(ctx context.Context) (Signer, error)

func (f SignerGenFunc) Generate(ctx context.Context) (Signer, error) {
return f(ctx)
}

// Extender extends path segments.
Expand Down Expand Up @@ -104,14 +115,14 @@ func (s *DefaultExtender) Extend(
}
// Make sure the hop expiration time is not longer than the signer expiration time.
expTime := s.MaxExpTime()
if ts.Add(path.ExpTimeToDuration(expTime)).After(signer.Expiration) {
if ts.Add(path.ExpTimeToDuration(expTime)).After(signer.GetExpiration()) {
metrics.GaugeSet(s.SegmentExpirationDeficient, 1)
var err error
expTime, err = path.ExpTimeFromDuration(signer.Expiration.Sub(ts))
expTime, err = path.ExpTimeFromDuration(signer.GetExpiration().Sub(ts))
if err != nil {
return serrors.WrapStr(
"calculating expiry time from signer expiration time", err,
"signer_expiration", signer.Expiration,
"signer_expiration", signer.GetExpiration(),
)
}
} else {
Expand Down
2 changes: 1 addition & 1 deletion control/beaconing/writer_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -349,7 +349,7 @@ type testSignerGen struct {
Signer trust.Signer
}

func (s testSignerGen) Generate(ctx context.Context) (trust.Signer, error) {
func (s testSignerGen) Generate(ctx context.Context) (beaconing.Signer, error) {
return s.Signer, nil
}

Expand Down
16 changes: 9 additions & 7 deletions control/cmd/control/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -780,13 +780,15 @@ func realMain(ctx context.Context) error {
},
SegmentRegister: beaconinggrpc.Registrar{Dialer: dialer},
BeaconStore: beaconStore,
SignerGen: signer.SignerGen,
Inspector: inspector,
Metrics: metrics,
DRKeyEngine: drkeyEngine,
MACGen: macGen,
NextHopper: topo,
StaticInfo: func() *beaconing.StaticInfoCfg { return staticInfo },
SignerGen: beaconing.SignerGenFunc(func(ctx context.Context) (beaconing.Signer, error) {
return signer.SignerGen.Generate(ctx)
}),
Inspector: inspector,
Metrics: metrics,
DRKeyEngine: drkeyEngine,
MACGen: macGen,
NextHopper: topo,
StaticInfo: func() *beaconing.StaticInfoCfg { return staticInfo },

OriginationInterval: globalCfg.BS.OriginationInterval.Duration,
PropagationInterval: globalCfg.BS.PropagationInterval.Duration,
Expand Down
2 changes: 1 addition & 1 deletion pkg/experimental/hiddenpath/beaconwriter_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -356,7 +356,7 @@ type testSignerGen struct {
Signer trust.Signer
}

func (s testSignerGen) Generate(ctx context.Context) (trust.Signer, error) {
func (s testSignerGen) Generate(ctx context.Context) (beaconing.Signer, error) {
return s.Signer, nil
}

Expand Down
4 changes: 4 additions & 0 deletions private/trust/signer.go
Original file line number Diff line number Diff line change
Expand Up @@ -135,6 +135,10 @@ func (s Signer) validate(ctx context.Context, now time.Time) error {
return nil
}

func (s Signer) GetExpiration() time.Time {
return s.Expiration
}

func (s Signer) Equal(o Signer) bool {
return s.IA.Equal(o.IA) &&
bytes.Equal(s.SubjectKeyID, o.SubjectKeyID) &&
Expand Down

0 comments on commit e476aa8

Please sign in to comment.