curve_key_pair.go 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. package dhellman
  2. import (
  3. "errors"
  4. "git.ali33.ru/fcg-xvii/curve/v2"
  5. "git.ali33.ru/fcg-xvii/curve/v2/tools"
  6. )
  7. func randomCurveKeyPair(curve *tools.Curve) (*curveKeyPair, error) {
  8. pair := curveKeyPair{
  9. curve: curve,
  10. }
  11. var err error
  12. if pair.priv, err = randomCurveKeyPrivate(curve); err != nil {
  13. return nil, err
  14. }
  15. var pub *tools.Point
  16. if pub, err = curve.G().Mul(pair.priv.x); err != nil {
  17. return nil, err
  18. }
  19. pair.pub = &curveKeyPublic{
  20. p: pub,
  21. }
  22. return &pair, nil
  23. }
  24. type curveKeyPair struct {
  25. priv *curveKeyPrivate
  26. pub *curveKeyPublic
  27. curve *tools.Curve
  28. }
  29. func (s *curveKeyPair) KeyPrivate() curve.KeyPrivate {
  30. return s.priv
  31. }
  32. func (s *curveKeyPair) KeyPublic() curve.KeyPublic {
  33. return s.pub
  34. }
  35. func (s *curveKeyPair) MessageEncode(data []byte, args ...any) (curve.Message, error) {
  36. if len(args) == 0 {
  37. return nil, errors.New("Не найден публичный ключ принимающей стороны")
  38. }
  39. pub, check := args[0].(*curveKeyPublic)
  40. if !check {
  41. return nil, errors.New("Неверный тип аргумента - публичный ключ принимающей стороны")
  42. }
  43. encoded, err := s.messageEncode(data, pub)
  44. if err != nil {
  45. return nil, err
  46. }
  47. mes := &message{
  48. encoded: encoded,
  49. }
  50. return mes, err
  51. }
  52. func (s *curveKeyPair) MessageDecode(mes curve.Message, args ...any) ([]byte, error) {
  53. if len(args) == 0 {
  54. return nil, errors.New("Не найден публичный ключ отправляющей стороны")
  55. }
  56. pub, check := args[0].(*curveKeyPublic)
  57. if !check {
  58. return nil, errors.New("Неверный тип аргумента - публичный ключ отправляющей стороны")
  59. }
  60. return s.messageDecode(mes.Encoded(), pub)
  61. }
  62. func (s *curveKeyPair) messageEncode(data []byte, pub *curveKeyPublic) ([]byte, error) {
  63. sec, err := s.priv.secret(pub, s.curve)
  64. if err != nil {
  65. return nil, err
  66. }
  67. return aesEncode(data, sec)
  68. }
  69. func (s *curveKeyPair) messageDecode(encoded []byte, pub *curveKeyPublic) ([]byte, error) {
  70. sec, err := s.priv.secret(pub, s.curve)
  71. if err != nil {
  72. return nil, err
  73. }
  74. return aesEncode(encoded, sec)
  75. }