key_public.go 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  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.KeyPair, error) {
  22. return s.attack(ctx)
  23. }
  24. func (s *curveKeyPublic) attack(ctx context.Context) (*curveKeyPair, 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() != nil && pp.X().Cmp(s.p.X()) == 0 && pp.Y().Cmp(s.p.Y()) == 0 {
  32. pair := &curveKeyPair{
  33. curve: c,
  34. pub: s,
  35. priv: &curveKeyPrivate{
  36. x: tmp,
  37. },
  38. }
  39. return pair, nil
  40. }
  41. select {
  42. case <-ctx.Done():
  43. return nil, errors.New("атака на метод диффи-хеллмана провалена: время вышло")
  44. default:
  45. tmp = tools.Add64(tmp, 1)
  46. }
  47. }
  48. return nil, errors.New("атака на метод диффи-хеллмана провалена: ключ найти не удалось")
  49. }