curve_key_public.go 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. package dhellman
  2. import (
  3. "context"
  4. "errors"
  5. "math/big"
  6. "git.ali33.ru/fcg-xvii/curve/v2"
  7. "git.ali33.ru/fcg-xvii/curve/v2/tools"
  8. "git.ali33.ru/fcg-xvii/go-tools/json"
  9. )
  10. type curveKeyPublic struct {
  11. p *tools.Point
  12. }
  13. func (s *curveKeyPublic) Map() json.Map {
  14. return json.Map{
  15. "p": s.p,
  16. }
  17. }
  18. func (s *curveKeyPublic) MarshalJSON() ([]byte, error) {
  19. return s.Map().JSON(), nil
  20. }
  21. func (s *curveKeyPublic) Attack(ctx context.Context) (curve.KeyPrivate, error) {
  22. return s.attack(ctx)
  23. }
  24. func (s *curveKeyPublic) attack(ctx context.Context) (*curveKeyPrivate, error) {
  25. c := s.p.Curve()
  26. tmp := big.NewInt(1)
  27. for {
  28. if tmp.Cmp(tools.Add64(c.P(), -1)) == 0 {
  29. break
  30. }
  31. if pp, err := c.G().Mul(tmp); err == nil && pp.X().Cmp(s.p.X()) == 0 {
  32. return &curveKeyPrivate{
  33. x: tmp,
  34. }, nil
  35. }
  36. select {
  37. case <-ctx.Done():
  38. return nil, errors.New("атака на метод диффи-хеллмана провалена: время вышло")
  39. default:
  40. tmp = tools.Add64(tmp, 1)
  41. }
  42. }
  43. return nil, errors.New("атака на метод диффи-хеллмана провалена: время вышло")
  44. }