Vanetza
Loading...
Searching...
No Matches
ecc_point.cpp
1#include <vanetza/security/ecc_point.hpp>
2#include <vanetza/security/ecdsa256.hpp>
3#include <vanetza/security/public_key.hpp>
4#include <boost/variant/apply_visitor.hpp>
5#include <boost/variant/static_visitor.hpp>
6
7namespace vanetza
8{
9namespace security
10{
11
12class EccPointVisitor : public boost::static_visitor<ByteBuffer>
13{
14public:
15 template<typename T>
16 ByteBuffer operator()(const T& point)
17 {
18 return point.x;
19 }
20};
21
22ByteBuffer convert_for_signing(const EccPoint& ecc_point)
23{
24 EccPointVisitor visit;
25 return boost::apply_visitor(visit, ecc_point);
26}
27
28class EccPointLengthVisitor : public boost::static_visitor<std::size_t>
29{
30public:
31 std::size_t operator()(const X_Coordinate_Only& x_only) const
32 {
33 return x_only.x.size();
34 }
35
36 std::size_t operator()(const Compressed_Lsb_Y_0& y0) const
37 {
38 return y0.x.size();
39 }
40
41 std::size_t operator()(const Compressed_Lsb_Y_1& y1) const
42 {
43 return y1.x.size();
44 }
45
46 std::size_t operator()(const Uncompressed& unc) const
47 {
48 return unc.x.size() + unc.y.size();
49 }
50};
51
52std::size_t get_length(const EccPoint& point)
53{
54 EccPointLengthVisitor visitor;
55 return boost::apply_visitor(visitor, point);
56}
57
58EccPoint compress_public_key(const PublicKey& public_key)
59{
60 switch (public_key.compression)
61 {
62 case KeyCompression::NoCompression:
63 if (!public_key.y.empty() && public_key.y.back() & 0x01) {
64 return Compressed_Lsb_Y_1 {public_key.x };
65 } else {
66 return Compressed_Lsb_Y_0 {public_key.x };
67 }
68 case KeyCompression::Y0:
69 return Compressed_Lsb_Y_0 {public_key.x };
70 case KeyCompression::Y1:
71 return Compressed_Lsb_Y_1 {public_key.x };
72 default:
73 return Compressed_Lsb_Y_0 {};
74 }
75}
76
77EccPoint compress_public_key(const ecdsa256::PublicKey& public_key)
78{
79 if (!public_key.y.empty() && public_key.y.back() & 0x01) {
80 return Compressed_Lsb_Y_1 { ByteBuffer { public_key.x.begin(), public_key.x.end() } };
81 } else {
82 return Compressed_Lsb_Y_0 { ByteBuffer { public_key.x.begin(), public_key.x.end() } };
83 }
84}
85
86} // namespace security
87} // namespace vanetza
Compressed_Lsb_Y_0 specified in TS 103 097 v1.2.1 in section 4.2.5.
Definition ecc_point.hpp:24
Compressed_Lsb_Y_1 specified in TS 103 097 v1.2.1 in section 4.2.5.
Definition ecc_point.hpp:30